Skip to content

Conversation

@crazy-max
Copy link
Member

@crazy-max crazy-max commented Oct 28, 2025

This adds a Sigstore class to sign BuildKit provenance blobs and be able to verify each provenance subject with this signature using Cosign. It supports uploading to transparency log or not. Mainly for private repositories or if user opts in for it.

Tested in https://github.com/docker/actions-toolkit/actions/runs/18942704165/job/54085464143

Bundle with rekor looks like this:

{
  "mediaType":"application/vnd.dev.sigstore.bundle.v0.3+json",
  "verificationMaterial":{
    "certificate":{
      "rawBytes":"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"
    },
    "tlogEntries":[
      {
        "logIndex":"654932898",
        "logId":{
          "keyId":"wNI9atQGlz+VWfO6LRygH4QUfY/8W4RFwiT5i5WRgB0="
        },
        "kindVersion":{
          "kind":"dsse",
          "version":"0.0.1"
        },
        "integratedTime":"1761831916",
        "inclusionPromise":{
          "signedEntryTimestamp":"MEQCIH+Wm4NxjOsOsR8fG8WRr2MgXfBQOLYHIULiWipMgDX1AiAp3+HfU1K6JN18g3ApMMKb3+eAjgD3sjiGVAL6JGPr9Q=="
        },
        "inclusionProof":{
          "logIndex":"533028636",
          "rootHash":"Xqe2AFl1D/MAElNUl0uAmq/d9zEcGCsMVHlv+kWTjNI=",
          "treeSize":"533028643",
          "hashes":[
            "Eto/UElYM0pFjtMh4cTTy4Ooyz+/ASqj6zOGhSPCf24=",
            "x6I+R28HuT2Rgb4jhv/zoMMpLfXiAAiBZJQ99tAv52I=",
            "NcwV5VeBXPLkMZ+OG7sctpUPIiVjPpcmkZDxhNV3BzU=",
            "HOQmO6NOzJwMqx3nGyK5lZKLEdjZMZ8LPp1+hQ8t2ys=",
            "Gmb+YTGI+JMiyzOhvSjo0zhTCaDn3SLbg4ckmhCZT00=",
            "8t/Cc6TYqFutMhh6vuuye3hVW69PiJsR8UWjiUREGio=",
            "jzslDwVaFeIFFDA8v4b90rcdd67cJZF3rei0wMDRgvA=",
            "h0PC/L+bJheRj+7lbe6FZIRk6qSOjY89RCzk68UfIxo=",
            "n63yVvosS/eeh7AS0KvjteYRw4Uchl1/huGEpFBZ6XE=",
            "DvuaM248kJHre6DeK8C1xEHitYpnNfsbyEOTCeo0Ank=",
            "UUaZpRXqHr4AJW4zmeFB/gfxkTBu8sr4ppK4zPG1Xr8=",
            "0H3S/uULaI8QBbe9mC2CJAshUKjf7nQKbG9xjniTqI0=",
            "QIhICE3/Pk/JM+yc6YDYHyW50RqtqS8vNHRXMuhfvfU=",
            "kgvEJpIutBAoiKUq/YymF38h3i1di6Lk66Y+btaf+qI=",
            "rImjSAJ6dww7qxq1BcJQ3ytVA+H0ptXB+UQbIlojNXo=",
            "/ZlzrGPS0eq2rjgtegMbCBBRoQ9PIxVWEx+ZymODyyw=",
            "oUpQPKjwnG3jhQtgDGLtyjyTJmrqoENa8C6gx+qWIls=",
            "HAOTg+Fg3H1Ej24mw+P9lXfi+4mPL5EKwAd4aNQOV6M=",
            "2Wv4GiithwNukRKV06clevnQQYCzXmSS/+/OJtXgsXQ=",
            "1mfy94KpcItqshH9+gwqV6jccupcaMpVsF28New8zDY=",
            "vS7O4ozHIQZJWBiov+mkpI27GE8zAmVCEkRcP3NDyNE="
          ],
          "checkpoint":{
            "envelope":"rekor.sigstore.dev - 1193050959916656506\n533028643\nXqe2AFl1D/MAElNUl0uAmq/d9zEcGCsMVHlv+kWTjNI=\n\n— rekor.sigstore.dev wNI9ajBFAiEAg/xQd2FsJ/v5zlDSean7gyTGJOgN/VFCpXA/jVQC1lUCIBNkuG6B20FpDbqmLdHcVmHEighIUBwhxAzlxdtfrnbW\n"
          }
        },
        "canonicalizedBody":"eyJhcGlWZXJzaW9uIjoiMC4wLjEiLCJraW5kIjoiZHNzZSIsInNwZWMiOnsiZW52ZWxvcGVIYXNoIjp7ImFsZ29yaXRobSI6InNoYTI1NiIsInZhbHVlIjoiNzg5ZmNiODdmZDEyNDBhYjlhZTJjZjlhMmI4YzVkNzE4ZDIwNTQ3N2MyNzYyODEyNmZhMTAzZWJiMWRhYjMzMCJ9LCJwYXlsb2FkSGFzaCI6eyJhbGdvcml0aG0iOiJzaGEyNTYiLCJ2YWx1ZSI6ImNjZGQ5NmRjNWM2ZWQ3NTA1MDZkNjExYmU3MTQyMmQwNGY2N2YyNzM2M2NjMzZmOWJmNGQ0NTAzMzdkMjIyZTIifSwic2lnbmF0dXJlcyI6W3sic2lnbmF0dXJlIjoiTUVZQ0lRQ3h1dVNuRHNqM0oyUC9CVFhGVmRONTd0WkxWUHF6WmRRRGJrVlNEU21lVUFJaEFPZWc5UkYra1JOTTllRm1NbzB5Sk5ZS1ZJT1dPL0xFWEtLWi9kSmcvS05QIiwidmVyaWZpZXIiOiJMUzB0TFMxQ1JVZEpUaUJEUlZKVVNVWkpRMEZVUlMwdExTMHRDazFKU1VjdlJFTkRRbTlIWjBGM1NVSkJaMGxWVTBsR01ITkVjWFkwUWxCbWRHcExXRzF6UVZaUGVrd3pkalZKZDBObldVbExiMXBKZW1vd1JVRjNUWGNLVG5wRlZrMUNUVWRCTVZWRlEyaE5UV015Ykc1ak0xSjJZMjFWZFZwSFZqSk5ValIzU0VGWlJGWlJVVVJGZUZaNllWZGtlbVJIT1hsYVV6RndZbTVTYkFwamJURnNXa2RzYUdSSFZYZElhR05PVFdwVmVFMUVUWGROVkUwd1RsUkZNbGRvWTA1TmFsVjRUVVJOZDAxVVRURk9WRVV5VjJwQlFVMUdhM2RGZDFsSUNrdHZXa2w2YWpCRFFWRlpTVXR2V2tsNmFqQkVRVkZqUkZGblFVVXhSMll6ZGtwclEybFpkaloxV1ROM2RHVjFkWGd3V1doaGRISllOV0V2Y0ZObldtVUthMEp5YTFSTU4yUkhRM0p6ZUc5bVRISjNMMjQyTURseWRuVjViblZQVkUxeGF6YzVLM2hZYnk5R1pYRlVZM2xHYTNGUFEwSmhRWGRuWjFkalRVRTBSd3BCTVZWa1JIZEZRaTkzVVVWQmQwbElaMFJCVkVKblRsWklVMVZGUkVSQlMwSm5aM0pDWjBWR1FsRmpSRUY2UVdSQ1owNVdTRkUwUlVablVWVmtZakZzQ205ME5FZElhSEpDY0VvMEswOTJiMDlIVTFnelJ6VnZkMGgzV1VSV1VqQnFRa0puZDBadlFWVXpPVkJ3ZWpGWmEwVmFZalZ4VG1wd1MwWlhhWGhwTkZrS1drUTRkMkYzV1VSV1VqQlNRVkZJTDBKSFJYZFlORnBrWVVoU01HTklUVFpNZVRsdVlWaFNiMlJYU1hWWk1qbDBUREpTZGxreWRHeGphVGxvV1ROU2NBcGlNalY2VEZoU2RtSXllSEpoV0ZGMlRHMWtjR1JIYURGWmFUa3pZak5LY2xwdGVIWmtNMDEyWkVkV2VtUkROVFZpVjNoQlkyMVdiV041T1c5YVYwWnJDbU41T1hwaFYyUjFZVmMxYmt4WFNuTmlNa3A2VFVSclIwTnBjMGRCVVZGQ1p6YzRkMEZSUlVWTE1tZ3daRWhDZWs5cE9IWmtSemx5V2xjMGRWbFhUakFLWVZjNWRXTjVOVzVoV0ZKdlpGZEtNV015Vm5sWk1qbDFaRWRXZFdSRE5XcGlNakIzU0hkWlMwdDNXVUpDUVVkRWRucEJRa0ZuVVZKa01qbDVZVEphY3dwaU0yUm1Xa2RzZW1OSFJqQlpNbWQzVG1kWlMwdDNXVUpDUVVkRWRucEJRa0YzVVc5YVJHTXpXWHBPYWsxcVp6UmFhbXQ0V2tSc2FrMUVaelZQVkVWNkNrNVVWbWhOUkdNeFRsZE5ORTlVV1hkTlYwcHFXWHBTYUU1cVFWTkNaMjl5UW1kRlJVRlpUeTlOUVVWRlFrRlNNRnBZVGpCTlExRkhRMmx6UjBGUlVVSUtaemM0ZDBGUlZVVkdiVkoyV1RKMGJHTnBPV2haTTFKd1lqSTFla3hZVW5aaU1uaHlZVmhSZDBwbldVdExkMWxDUWtGSFJIWjZRVUpDWjFGWlkyMVdiUXBqZVRsdldsZEdhMk41T1hwaFYyUjFZVmMxYmt4WFNuTmlNa3A2VFVSelIwTnBjMGRCVVZGQ1p6YzRkMEZSWjBWTVVYZHlZVWhTTUdOSVRUWk1lVGt3Q21JeWRHeGlhVFZvV1ROU2NHSXlOWHBNYldSd1pFZG9NVmx1Vm5wYVdFcHFZakkxTUZwWE5UQk1iVTUyWWxSQ2RFSm5iM0pDWjBWRlFWbFBMMDFCUlVvS1FrWTRUVmhYYURCa1NFSjZUMms0ZGxveWJEQmhTRlpwVEcxT2RtSlRPV3RpTWs1eVdsaEpkbGxYVGpCaFZ6bDFZM2t4TUdJeU9YTmhNbXd3VEhrMWJncGhXRkp2WkZkSmRtUXlPWGxoTWxwellqTmtla3d6VW14ak0xRjFaVmN4YzFGSVNteGFiazEyWVVkV2FGcElUWFpqTW14dVltMXNkVnA1TVdsaVJ6bHBDbU42UVRSQ1oyOXlRbWRGUlVGWlR5OU5RVVZMUWtOdlRVdEhVVE5PTWsxNldYcEpORTlIV1RWTlYxRTFXWHBCTkU5VWEzaE5lbFV4V1ZSQk0wNVVWbW9LVDBSck1rMUVSbWxaTWswd1dWUlpkMGhSV1V0TGQxbENRa0ZIUkhaNlFVSkRkMUZRUkVFeGJtRllVbTlrVjBsMFlVYzVlbVJIVm10TlJHdEhRMmx6UndwQlVWRkNaemM0ZDBGUmQwVkxkM2R3WVVoU01HTklUVFpNZVRsdVlWaFNiMlJYU1hWWk1qbDBUREpTZGxreWRHeGphVGxvV1ROU2NHSXlOWHBNV0ZKMkNtSXllSEpoV0ZGM1QwRlpTMHQzV1VKQ1FVZEVkbnBCUWtSUlVYRkVRMmhyVG5wa2FrMHlUWGxQUkdodFQxUkdhMDlYVFhkUFJHczFUVlJOTVU1WFJYY0tUbnBWTVZsNlp6Vk9ha0Y0V1cxT2FrNUhSVEpOUTJkSFEybHpSMEZSVVVKbk56aDNRVkUwUlVkbmQxbGpiVlp0WTNrNWIxcFhSbXRqZVRsNllWZGtkUXBoVnpWdVRGZEtjMkl5U25wTlFtdEhRMmx6UjBGUlVVSm5OemgzUVZFNFJVTjNkMHBPVkdjMVRXcFpORTlFVlhsTlEydEhRMmx6UjBGUlVVSm5OemgzQ2tGU1FVVkhkM2RhWVVoU01HTklUVFpNZVRsdVlWaFNiMlJYU1hWWk1qbDBUREpTZGxreWRHeGpha0ZZUW1kdmNrSm5SVVZCV1U4dlRVRkZVa0pCYTAwS1FucFZNRTFxYXpCT2VrRjNZbEZaUzB0M1dVSkNRVWRFZG5wQlFrVm5VbVpFUmpGdlpFaFNkMk42YjNaTU1tUndaRWRvTVZscE5XcGlNakIyV2tjNWFncGhNbFo1VERKR2FtUkhiSFppYmsxMFpFYzVkbUpIZEhCa1F6aDFXakpzTUdGSVZtbE1NMlIyWTIxMGJXSkhPVE5qZVRrd1dsaE9NRXh1YkhSaVJVSjVDbHBYV25wTU1taHNXVmRTZWt3elRuQmFNalZ3WW0xamRGbHRlSFpaYmsxM1QwRlpTMHQzV1VKQ1FVZEVkbnBCUWtWM1VYRkVRMmhyVG5wa2FrMHlUWGtLVDBSb2JVOVVSbXRQVjAxM1QwUnJOVTFVVFRGT1YwVjNUbnBWTVZsNlp6Vk9ha0Y0V1cxT2FrNUhSVEpOUTBWSFEybHpSMEZSVVVKbk56aDNRVkpSUlFwRmQzZFNaREk1ZVdFeVduTmlNMlJtV2tkc2VtTkhSakJaTW1kM1dGRlpTMHQzV1VKQ1FVZEVkbnBCUWtaUlVsQkVSVEZ2WkVoU2QyTjZiM1pNTW1Sd0NtUkhhREZaYVRWcVlqSXdkbHBIT1dwaE1sWjVUREpHYW1SSGJIWmliazEwWkVjNWRtSkhkSEJrUXpsb1dUTlNjR0l5TlhwTU0wb3hZbTVOZGsxVVp6VUtUa1JKTTAxRVVYaE9hbFYyV1ZoU01GcFhNWGRrU0UxMlRWUkJWMEpuYjNKQ1owVkZRVmxQTDAxQlJWZENRV2ROUW01Q01WbHRlSEJaZWtOQ2FYZFpTd3BMZDFsQ1FrRklWMlZSU1VWQloxSTVRa2h6UVdWUlFqTkJUakE1VFVkeVIzaDRSWGxaZUd0bFNFcHNiazUzUzJsVGJEWTBNMnA1ZEM4MFpVdGpiMEYyQ2t0bE5rOUJRVUZDYldwV1pHc3ZkMEZCUVZGRVFVVm5kMUpuU1doQlVFUlVTa3RIU25KUVRtSlFkak5QU25OTldUSXdLekpOYUVadFVXcHVkWFJwTDNFS2VURnpTbnA2VWtwQmFVVkJNM1pGWTNGbU1Fb3ZOVlkyTnpVMmJIQnhha2t6ZVVGNVRGbFpiSEphY2xwamExbzFNRE5qTWxKb1VYZERaMWxKUzI5YVNRcDZhakJGUVhkTlJHRlJRWGRhWjBsNFFVOVBXa1JRY214MmJXbEVkelJUVG5KU1oyTk1hbE5xWVV4ME1UQTFSWEJLVWs4eVYyb3JPRmhQTTNRd1RVWTVDbFZFZGk5cWVsUkNPSGRZVVRVeWFIbFZkMGw0UVU5WVNGWjNNRzVHUWtaeWFYSlFSRmgwVEhSWlZuSXJVWEZoTVVKSVEzWjVRelZMYjFaM2QzWnpZbkVLY0RKcWNrRkROMjB3VDJWSVZVeENjM0Z3Ym1odFFUMDlDaTB0TFMwdFJVNUVJRU5GVWxSSlJrbERRVlJGTFMwdExTMEsifV19fQ=="
      }
    ],
    "timestampVerificationData":{
      "rfc3161Timestamps":[
        {
          "signedTimestamp":"MIICyjADAgEAMIICwQYJKoZIhvcNAQcCoIICsjCCAq4CAQMxDTALBglghkgBZQMEAgEwgbgGCyqGSIb3DQEJEAEEoIGoBIGlMIGiAgEBBgkrBgEEAYO/MAIwMTANBglghkgBZQMEAgEFAAQgOyWnaL3bgidShwH9RXVa++cb/eB/WzafrkyuRwmlUEQCFQCVDJ5OpfoVE6bO6HyG1WC5LbPIcBgPMjAyNTEwMzAxMzQ1MTZaMAMCAQGgMqQwMC4xFTATBgNVBAoTDHNpZ3N0b3JlLmRldjEVMBMGA1UEAxMMc2lnc3RvcmUtdHNhoAAxggHbMIIB1wIBATBRMDkxFTATBgNVBAoTDHNpZ3N0b3JlLmRldjEgMB4GA1UEAxMXc2lnc3RvcmUtdHNhLXNlbGZzaWduZWQCFDoTVC8MkGHuvMFDL8uKjosqI4sMMAsGCWCGSAFlAwQCAaCB/DAaBgkqhkiG9w0BCQMxDQYLKoZIhvcNAQkQAQQwHAYJKoZIhvcNAQkFMQ8XDTI1MTAzMDEzNDUxNlowLwYJKoZIhvcNAQkEMSIEIIdEoLwGTrHVgf/9LdfGjXnpzm4wy1p3u5HZLj7Oo/ZZMIGOBgsqhkiG9w0BCRACLzF/MH0wezB5BCCF+Se8B6tiysO0Q1bBDvyBssaIP9p6uebYcNnROs0FtzBVMD2kOzA5MRUwEwYDVQQKEwxzaWdzdG9yZS5kZXYxIDAeBgNVBAMTF3NpZ3N0b3JlLXRzYS1zZWxmc2lnbmVkAhQ6E1QvDJBh7rzBQy/Lio6LKiOLDDAKBggqhkjOPQQDAgRnMGUCMHyaKDR6RvlETZe+d6wTcOzmsAMnPK2kQaZj0KMe5Ps26tionFWgBJRGHegZzu8VkwIxANI94n7j6FY2gxY8nDVD8rtO8oIHIK8h2mfTUUMiILyUa0lsS/Ze08IdcIhSPhX98A=="
        }
      ]
    }
  },
  "dsseEnvelope":{
    "payload":"{
  "_type": "https://in-toto.io/Statement/v0.1",
  "predicateType": "https://slsa.dev/provenance/v1",
  "subject": [
    {
      "name": "hello.txt",
      "digest": {
        "sha256": "1b37929e66644beb58b3d28d44fba0d82aa90cab03c55a492adb81fe6e833ec8"
      }
    }
  ],
  "predicate": {
    "buildDefinition": {
      "buildType": "https://github.com/moby/buildkit/blob/master/docs/attestations/slsa-definitions.md",
      "resolvedDependencies": [
        {
          "uri": "pkg:docker/docker/buildkit-syft-scanner@stable-1",
          "digest": {
            "sha256": "e930c2697be77cb7271d316ecfa78768b5eac73de3b16018ed38eb0ea0b5a7cb"
          }
        },
        {
          "uri": "pkg:docker/alpine@latest?platform=linux%2Famd64",
          "digest": {
            "sha256": "4b7ce07002c69e8f3d704a9c5d6fd3053be500b7f1c69fc0d80990c2ad8dd412"
          }
        },
        {
          "uri": "https://github.com/docker/github-builder-test.git#bdb96fcfe8cc9e3a54800bc2537a4d4a14f0c5fe",
          "digest": {
            "sha1": "bdb96fcfe8cc9e3a54800bc2537a4d4a14f0c5fe"
          }
        }
      ],
      "externalParameters": {
        "configSource": {
          "uri": "https://github.com/docker/github-builder-test.git#bdb96fcfe8cc9e3a54800bc2537a4d4a14f0c5fe",
          "digest": {
            "sha1": "bdb96fcfe8cc9e3a54800bc2537a4d4a14f0c5fe"
          },
          "path": "hello.Dockerfile"
        },
        "request": {
          "frontend": "dockerfile.v0",
          "secrets": [
            {
              "id": "GIT_AUTH_HEADER",
              "optional": true
            },
            {
              "id": "GIT_AUTH_TOKEN",
              "optional": true
            }
          ]
        }
      },
      "internalParameters": {
        "buildConfig": {
          "digestMapping": {
            "sha256:23dcbc3cce701a8a9bbb1e33f2ea88304527a4a935c89c4564af698095463ac2": "step3",
            "sha256:3192c1bd53f90cca959db778dcee30edc9a79f8cd3f9a2c54adc4606507fd3b6": "step0",
            "sha256:7f1c9e959980ea3e2cf4af8ef97b6c3797a0926752b436bff11474e436defe7f": "step1",
            "sha256:c8737331fb8e5f5bcb6b22320012d975057514982c788e63db13332a4219b984": "step2"
          },
          "llbDefinition": [
            {
              "id": "step0",
              "op": {
                "Op": {
                  "source": {
                    "identifier": "docker-image://docker.io/library/alpine:latest@sha256:4b7ce07002c69e8f3d704a9c5d6fd3053be500b7f1c69fc0d80990c2ad8dd412"
                  }
                },
                "constraints": {},
                "platform": {
                  "Architecture": "amd64",
                  "OS": "linux"
                }
              }
            },
            {
              "id": "step1",
              "inputs": [
                "step0:0"
              ],
              "op": {
                "Op": {
                  "exec": {
                    "meta": {
                      "args": [
                        "/bin/sh",
                        "-c",
                        "echo \"Hello, World! This is ${TARGETPLATFORM}\" \u003e /hello.txt"
                      ],
                      "cwd": "/",
                      "env": [
                        "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin",
                        "TARGETPLATFORM=linux/amd64"
                      ],
                      "removeMountStubsRecursive": true
                    },
                    "mounts": [
                      {
                        "dest": "/"
                      }
                    ]
                  }
                },
                "constraints": {},
                "platform": {
                  "Architecture": "amd64",
                  "OS": "linux"
                }
              }
            },
            {
              "id": "step2",
              "inputs": [
                "step1:0"
              ],
              "op": {
                "Op": {
                  "file": {
                    "actions": [
                      {
                        "Action": {
                          "copy": {
                            "allowEmptyWildcard": true,
                            "allowWildcard": true,
                            "createDestPath": true,
                            "dest": "/",
                            "dirCopyContents": true,
                            "followSymlink": true,
                            "mode": -1,
                            "src": "/hello.txt",
                            "timestamp": -1
                          }
                        },
                        "input": -1,
                        "output": 0,
                        "secondaryInput": 0
                      }
                    ]
                  }
                },
                "constraints": {}
              }
            },
            {
              "id": "step3",
              "inputs": [
                "step2:0"
              ],
              "op": {
                "Op": {}
              }
            }
          ]
        },
        "builderPlatform": "linux/amd64",
        "github_actor": "crazy-max",
        "github_actor_id": "1951866",
        "github_event_name": "workflow_dispatch",
        "github_event_payload": {
          "enterprise": {
            "avatar_url": "https://avatars.githubusercontent.com/b/19176?v=4",
            "created_at": "2022-12-30T23:53:17Z",
            "description": null,
            "html_url": "https://github.com/enterprises/docker",
            "id": 19176,
            "name": "Docker",
            "node_id": "E_kgDNSug",
            "slug": "docker",
            "updated_at": "2025-10-20T20:39:05Z",
            "website_url": null
          },
          "inputs": null,
          "organization": {
            "avatar_url": "https://avatars.githubusercontent.com/u/5429470?v=4",
            "description": "Docker helps developers bring their ideas to life by conquering the complexity of app development.",
            "events_url": "https://api.github.com/orgs/docker/events",
            "hooks_url": "https://api.github.com/orgs/docker/hooks",
            "id": 5429470,
            "issues_url": "https://api.github.com/orgs/docker/issues",
            "login": "docker",
            "members_url": "https://api.github.com/orgs/docker/members{/member}",
            "node_id": "MDEyOk9yZ2FuaXphdGlvbjU0Mjk0NzA=",
            "public_members_url": "https://api.github.com/orgs/docker/public_members{/member}",
            "repos_url": "https://api.github.com/orgs/docker/repos",
            "url": "https://api.github.com/orgs/docker"
          },
          "ref": "refs/heads/main",
          "repository": {
            "allow_forking": true,
            "archive_url": "https://api.github.com/repos/docker/github-builder-test/{archive_format}{/ref}",
            "archived": false,
            "assignees_url": "https://api.github.com/repos/docker/github-builder-test/assignees{/user}",
            "blobs_url": "https://api.github.com/repos/docker/github-builder-test/git/blobs{/sha}",
            "branches_url": "https://api.github.com/repos/docker/github-builder-test/branches{/branch}",
            "clone_url": "https://github.com/docker/github-builder-test.git",
            "collaborators_url": "https://api.github.com/repos/docker/github-builder-test/collaborators{/collaborator}",
            "comments_url": "https://api.github.com/repos/docker/github-builder-test/comments{/number}",
            "commits_url": "https://api.github.com/repos/docker/github-builder-test/commits{/sha}",
            "compare_url": "https://api.github.com/repos/docker/github-builder-test/compare/{base}...{head}",
            "contents_url": "https://api.github.com/repos/docker/github-builder-test/contents/{+path}",
            "contributors_url": "https://api.github.com/repos/docker/github-builder-test/contributors",
            "created_at": "2025-08-19T08:08:29Z",
            "custom_properties": {},
            "default_branch": "main",
            "deployments_url": "https://api.github.com/repos/docker/github-builder-test/deployments",
            "description": "Test repo for https://github.com/docker/github-builder-experimental",
            "disabled": false,
            "downloads_url": "https://api.github.com/repos/docker/github-builder-test/downloads",
            "events_url": "https://api.github.com/repos/docker/github-builder-test/events",
            "fork": false,
            "forks": 0,
            "forks_count": 0,
            "forks_url": "https://api.github.com/repos/docker/github-builder-test/forks",
            "full_name": "docker/github-builder-test",
            "git_commits_url": "https://api.github.com/repos/docker/github-builder-test/git/commits{/sha}",
            "git_refs_url": "https://api.github.com/repos/docker/github-builder-test/git/refs{/sha}",
            "git_tags_url": "https://api.github.com/repos/docker/github-builder-test/git/tags{/sha}",
            "git_url": "git://github.com/docker/github-builder-test.git",
            "has_discussions": false,
            "has_downloads": true,
            "has_issues": false,
            "has_pages": false,
            "has_projects": false,
            "has_wiki": false,
            "homepage": null,
            "hooks_url": "https://api.github.com/repos/docker/github-builder-test/hooks",
            "html_url": "https://github.com/docker/github-builder-test",
            "id": 1040594287,
            "is_template": false,
            "issue_comment_url": "https://api.github.com/repos/docker/github-builder-test/issues/comments{/number}",
            "issue_events_url": "https://api.github.com/repos/docker/github-builder-test/issues/events{/number}",
            "issues_url": "https://api.github.com/repos/docker/github-builder-test/issues{/number}",
            "keys_url": "https://api.github.com/repos/docker/github-builder-test/keys{/key_id}",
            "labels_url": "https://api.github.com/repos/docker/github-builder-test/labels{/name}",
            "language": "Dockerfile",
            "languages_url": "https://api.github.com/repos/docker/github-builder-test/languages",
            "license": null,
            "merges_url": "https://api.github.com/repos/docker/github-builder-test/merges",
            "milestones_url": "https://api.github.com/repos/docker/github-builder-test/milestones{/number}",
            "mirror_url": null,
            "name": "github-builder-test",
            "node_id": "R_kgDOPgY1bw",
            "notifications_url": "https://api.github.com/repos/docker/github-builder-test/notifications{?since,all,participating}",
            "open_issues": 0,
            "open_issues_count": 0,
            "owner": {
              "avatar_url": "https://avatars.githubusercontent.com/u/5429470?v=4",
              "events_url": "https://api.github.com/users/docker/events{/privacy}",
              "followers_url": "https://api.github.com/users/docker/followers",
              "following_url": "https://api.github.com/users/docker/following{/other_user}",
              "gists_url": "https://api.github.com/users/docker/gists{/gist_id}",
              "gravatar_id": "",
              "html_url": "https://github.com/docker",
              "id": 5429470,
              "login": "docker",
              "node_id": "MDEyOk9yZ2FuaXphdGlvbjU0Mjk0NzA=",
              "organizations_url": "https://api.github.com/users/docker/orgs",
              "received_events_url": "https://api.github.com/users/docker/received_events",
              "repos_url": "https://api.github.com/users/docker/repos",
              "site_admin": false,
              "starred_url": "https://api.github.com/users/docker/starred{/owner}{/repo}",
              "subscriptions_url": "https://api.github.com/users/docker/subscriptions",
              "type": "Organization",
              "url": "https://api.github.com/users/docker",
              "user_view_type": "public"
            },
            "private": true,
            "pulls_url": "https://api.github.com/repos/docker/github-builder-test/pulls{/number}",
            "pushed_at": "2025-10-30T10:04:10Z",
            "releases_url": "https://api.github.com/repos/docker/github-builder-test/releases{/id}",
            "size": 25,
            "ssh_url": "git@github.com:docker/github-builder-test.git",
            "stargazers_count": 0,
            "stargazers_url": "https://api.github.com/repos/docker/github-builder-test/stargazers",
            "statuses_url": "https://api.github.com/repos/docker/github-builder-test/statuses/{sha}",
            "subscribers_url": "https://api.github.com/repos/docker/github-builder-test/subscribers",
            "subscription_url": "https://api.github.com/repos/docker/github-builder-test/subscription",
            "svn_url": "https://github.com/docker/github-builder-test",
            "tags_url": "https://api.github.com/repos/docker/github-builder-test/tags",
            "teams_url": "https://api.github.com/repos/docker/github-builder-test/teams",
            "topics": [],
            "trees_url": "https://api.github.com/repos/docker/github-builder-test/git/trees{/sha}",
            "updated_at": "2025-10-30T10:04:14Z",
            "url": "https://api.github.com/repos/docker/github-builder-test",
            "visibility": "internal",
            "watchers": 0,
            "watchers_count": 0,
            "web_commit_signoff_required": false
          },
          "sender": {
            "avatar_url": "https://avatars.githubusercontent.com/u/1951866?v=4",
            "events_url": "https://api.github.com/users/crazy-max/events{/privacy}",
            "followers_url": "https://api.github.com/users/crazy-max/followers",
            "following_url": "https://api.github.com/users/crazy-max/following{/other_user}",
            "gists_url": "https://api.github.com/users/crazy-max/gists{/gist_id}",
            "gravatar_id": "",
            "html_url": "https://github.com/crazy-max",
            "id": 1951866,
            "login": "crazy-max",
            "node_id": "MDQ6VXNlcjE5NTE4NjY=",
            "organizations_url": "https://api.github.com/users/crazy-max/orgs",
            "received_events_url": "https://api.github.com/users/crazy-max/received_events",
            "repos_url": "https://api.github.com/users/crazy-max/repos",
            "site_admin": false,
            "starred_url": "https://api.github.com/users/crazy-max/starred{/owner}{/repo}",
            "subscriptions_url": "https://api.github.com/users/crazy-max/subscriptions",
            "type": "User",
            "url": "https://api.github.com/users/crazy-max",
            "user_view_type": "public"
          },
          "workflow": ".github/workflows/ci.yml"
        },
        "github_job": "build",
        "github_ref": "refs/heads/main",
        "github_ref_name": "main",
        "github_ref_protected": "false",
        "github_ref_type": "branch",
        "github_repository": "docker/github-builder-test",
        "github_repository_id": "1040594287",
        "github_repository_owner": "docker",
        "github_repository_owner_id": "5429470",
        "github_run_attempt": "1",
        "github_run_id": "18937328894",
        "github_run_number": "183",
        "github_runner_arch": "X64",
        "github_runner_environment": "github-hosted",
        "github_runner_image_os": "ubuntu24",
        "github_runner_image_version": "20250929.60.1",
        "github_runner_name": "GitHub Actions 1002376925",
        "github_runner_os": "Linux",
        "github_runner_tracking_id": "github_7c0a7521-2999-41e5-af30-b7f0681f204f",
        "github_server_url": "https://github.com",
        "github_triggering_actor": "crazy-max",
        "github_workflow": "ci",
        "github_workflow_ref": "docker/github-builder-test/.github/workflows/ci.yml@refs/heads/main",
        "github_workflow_sha": "bdb96fcfe8cc9e3a54800bc2537a4d4a14f0c5fe"
      }
    },
    "runDetails": {
      "builder": {
        "id": "https://github.com/docker/github-builder-test/actions/runs/18937328894/attempts/1"
      },
      "metadata": {
        "invocationID": "7qg2yuux3iklv02ktbmbtwgeb",
        "startedOn": "2025-10-30T10:19:52.868710505Z",
        "finishedOn": "2025-10-30T10:19:57.635810119Z",
        "buildkit_metadata": {
          "source": {
            "locations": {
              "step0": {
                "locations": [
                  {
                    "ranges": [
                      {
                        "start": {
                          "line": 1
                        },
                        "end": {
                          "line": 1
                        }
                      }
                    ]
                  }
                ]
              },
              "step1": {
                "locations": [
                  {
                    "ranges": [
                      {
                        "start": {
                          "line": 3
                        },
                        "end": {
                          "line": 3
                        }
                      }
                    ]
                  }
                ]
              },
              "step2": {
                "locations": [
                  {
                    "ranges": [
                      {
                        "start": {
                          "line": 7
                        },
                        "end": {
                          "line": 7
                        }
                      }
                    ]
                  }
                ]
              }
            },
            "infos": [
              {
                "filename": "hello.Dockerfile",
                "language": "Dockerfile",
                "data": "RlJPTSBhbHBpbmUgQVMgYmFzZQpBUkcgVEFSR0VUUExBVEZPUk0KUlVOIGVjaG8gIkhlbGxvLCBXb3JsZCEgVGhpcyBpcyAke1RBUkdFVFBMQVRGT1JNfSIgPiAvaGVsbG8udHh0CkFSRyBCVUlMREtJVF9TQk9NX1NDQU5fU1RBR0U9dHJ1ZQoKRlJPTSBzY3JhdGNoCkNPUFkgLS1mcm9tPWJhc2UgL2hlbGxvLnR4dCAvCg==",
                "llbDefinition": [
                  {
                    "id": "step0",
                    "op": {
                      "Op": {
                        "source": {
                          "identifier": "git://github.com/docker/github-builder-test.git#bdb96fcfe8cc9e3a54800bc2537a4d4a14f0c5fe",
                          "attrs": {
                            "git.authheadersecret": "GIT_AUTH_HEADER",
                            "git.authtokensecret": "GIT_AUTH_TOKEN",
                            "git.fullurl": "https://github.com/docker/github-builder-test.git"
                          }
                        }
                      },
                      "constraints": {}
                    }
                  },
                  {
                    "id": "step1",
                    "op": {
                      "Op": {}
                    },
                    "inputs": [
                      "step0:0"
                    ]
                  }
                ],
                "digestMapping": {
                  "sha256:47540f0959d81a7ff2fc9742b9ef0bb37d7eca99c13aa6df83b883d06e808ef2": "step0",
                  "sha256:96933c546ff00debd500304305864192fcb51d348e8c41b6a6e1569a051e66ed": "step1"
                }
              }
            ]
          },
          "layers": {
            "step0:0": [
              [
                {
                  "mediaType": "application/vnd.oci.image.layer.v1.tar+gzip",
                  "digest": "sha256:2d35ebdb57d9971fea0cac1582aa78935adf8058b2cc32db163c98822e5dfa1b",
                  "size": 3802452
                }
              ]
            ]
          }
        },
        "buildkit_completeness": {
          "request": true,
          "resolvedDependencies": true
        }
      }
    }
  }
}",
    "payloadType":"application/vnd.in-toto+json",
    "signatures":[
      {
        "sig":"MEYCIQCxuuSnDsj3J2P/BTXFVdN57tZLVPqzZdQDbkVSDSmeUAIhAOeg9RF+kRNM9eFmMo0yJNYKVIOWO/LEXKKZ/dJg/KNP"
      }
    ]
  }
}

Rekor log: https://search.sigstore.dev/?logIndex=654932898

@crazy-max crazy-max changed the title [WIP] signing for attestations manifest and artifact blobs [WIP] signing for provenance blobs Oct 28, 2025
@crazy-max crazy-max force-pushed the signing branch 3 times, most recently from b586554 to 750943e Compare October 28, 2025 14:56
@crazy-max

This comment was marked as resolved.

@crazy-max crazy-max changed the title [WIP] signing for provenance blobs Signing for provenance blobs Oct 28, 2025
@crazy-max crazy-max changed the title Signing for provenance blobs signing for provenance blobs Oct 28, 2025
@crazy-max crazy-max requested a review from tonistiigi October 29, 2025 09:01
@crazy-max crazy-max force-pushed the signing branch 2 times, most recently from 6f9eebc to d30a63c Compare October 29, 2025 09:09
@crazy-max crazy-max marked this pull request as ready for review October 29, 2025 09:12
@crazy-max crazy-max changed the title signing for provenance blobs sigstore class to sign buildkit provenance blobs Oct 29, 2025
expect(res[provenancePath].bundle).toBeDefined();
expect(res[provenancePath].certificate).toBeDefined();
expect(res[provenancePath].tlogID).toBeDefined();
expect(res[provenancePath].attestationID).not.toBeDefined();
Copy link
Member Author

@crazy-max crazy-max Oct 29, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@tonistiigi attestationID is not defined here as I don't use the GitHub Attestation API to post the provenance there. Wonder if we could have an opt for this? Could be useful for verification of released binaries (tag events) like https://github.com/cli/cli does: https://github.com/cli/cli/attestations

@crazy-max crazy-max force-pushed the signing branch 5 times, most recently from ba40ba4 to 955ab47 Compare October 30, 2025 13:42
@crazy-max crazy-max changed the title sigstore class to sign buildkit provenance blobs sigstore class to sign and verify buildkit provenance blobs Oct 30, 2025
Signed-off-by: CrazyMax <1951866+crazy-max@users.noreply.github.com>
Signed-off-by: CrazyMax <1951866+crazy-max@users.noreply.github.com>
Signed-off-by: CrazyMax <1951866+crazy-max@users.noreply.github.com>
@crazy-max crazy-max merged commit b4f8e5f into docker:main Nov 3, 2025
285 of 291 checks passed
@crazy-max crazy-max deleted the signing branch November 3, 2025 08:34
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant