Skip to content

CICD: Add SLSA build attestation to release workflow #3563

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Closed
wants to merge 1 commit into from

Conversation

eliheady
Copy link
Contributor

@eliheady eliheady commented May 4, 2025

This adds a new workflow job to the release drafter workflow that calls the generic SLSA builder in the SLSA Framework project.

The draft_release job is modified to include a new step to generate sha256 digests according to the expected input of the SLSA builder.

The release assets will include a new file called multiple.intoto.jsonl that can be used to verify the build artifacts against the recorded digests. This is what it will look like on the releases page:

Screenshot 2025-05-04 at 7 36 30 AM

This was tested in a private fork because I didn't want to introduce any confusion around DNSControl releases in the public Rekor logs. I will give read access to interested reviewers.

Example artifacts are attached. Manual verification steps:

checksums.txt
multiple.intoto.jsonl.txt

Note the attestation document has been renamed just for attaching to this issue, GitHub blocks jsonl (?)

slsa-verifier verify-artifact \
  --provenance-path multiple.intoto.jsonl.txt \
  --source-uri github.com/eliheady/nodnsctrlo \
  --source-tag v4.19.0-slsa checksums.txt
Verified build using builder "https://github.com/slsa-framework/slsa-github-generator/.github/workflows/generator_generic_slsa3.yml@refs/tags/v2.1.0" at commit 12d7c7f89c902899a290dd9c6bbe3d37cb78ba97
Verifying artifact checksums.txt: PASSED

PASSED: SLSA verification passed

Release changelog section

  • CICD: Add SLSA build attestation to release workflow

@eliheady eliheady marked this pull request as ready for review May 4, 2025 15:04
@eliheady
Copy link
Contributor Author

eliheady commented May 4, 2025

This resolves #3468

@tlimoncelli
Copy link
Contributor

I don't know much about SLSA but know that this kind of thing is important. Thanks for the PR!

I'd like advice on how to bring this into production.

@eliheady
Copy link
Contributor Author

eliheady commented May 5, 2025

Full transparency, I'm not a GHA or SLSA expert. But there wasn't much to it. I merged something (nearly the same as) this PR into main to make the workflow changes take effect, then pushed a new tag which triggers the normal release flow. The attestation step runs after the build is finished and sha256 digests produced at the end of the draft_release job.

I don't think it is necessary to follow the way I did it -- it could be tested before including it in a real release. Since this is not a new workflow, I believe as long as the workflow changes are included in the tag that the release is built from you could experiment without an official release. For instance, I guess you could create a v0.0.0-test-slsa tag from this commit, which should trigger the release workflow because its tag pattern would match. The draft release that gets created should have the multiple.intoto.jsonl document attached once the slsa job runs.

I'll try out that test procedure to make sure I am not wasting your time :)

@eliheady eliheady force-pushed the elih-slsa-provenance branch from da12da1 to 06ecb5c Compare May 5, 2025 15:55
* add SLSA generator call after release step

* add SLSA info and verification doc

* add SLSA badge to Readme

* Fix attestation doc filename, limit digest generation to files below dist/
@eliheady eliheady force-pushed the elih-slsa-provenance branch from 06ecb5c to 643b8be Compare May 5, 2025 17:20
@eliheady
Copy link
Contributor Author

eliheady commented May 5, 2025

I confirmed the test plan I loosely outlined does work to initiate the modified workflow. This could be used if you want to test the revised release steps and confirm the attestation document is produced as expected.

git tag v0.0.0-test-slsa 643b8be7dfa85ec984a521cc17f25da6c1dc0f13
git push --tags

643b8be is the rebased squashed commit I just pushed to this PR branch.

Then review GH Actions for new workflow stages:
Screenshot 2025-05-05 at 1 25 22 PM

Then you could cancel or let it finish and review the attestation document as desired. If you let it run, the SLSA builder in the called workflow will submit the attestation to the public Rekor log, so there will be a history and signed digests associated with the unpublished release. I don't think that should matter, I just wanted to point it out.

@eliheady
Copy link
Contributor Author

eliheady commented May 5, 2025

well, I apologize for the noise here. That test run in the private fork failed during the called SLSA workflow. I am investigating. I probably missed something when I was rebasing on the upstream main.

@eliheady
Copy link
Contributor Author

eliheady commented May 5, 2025

https://github.com/eliheady/nodnsctrlo/actions/runs/14842598300 is a successful test release of this PR (plus the required one-line change for running against a private repo). I am leaving that test fork private because I'm not comfortable producing builds and a public release alongside the official releases of the project.

As mentioned in 3468, this change doesn't produce SLSA attestation for the container images. I intend to make further changes to include that (if possible) in the same release workflow. If you'd prefer to wait to merge this until the docker images are also covered, it's fine with me to move this to draft status or sit on it. Also ok by me to have this merged when you are inclined to do so, with or without the container portion. I will work on it sometime this week either way.

I appreciate you taking the time to consider this Tom!

@tlimoncelli
Copy link
Contributor

I ran it as v0.0.0... and it created a separate release. Is that intended? I'd rather have it as part of the main release.

screencapture_2025-05-05_15 49 07

The json is:

{
  "mediaType": "application/vnd.dev.sigstore.bundle.v0.3+json",
  "verificationMaterial": {
    "certificate": {
      "rawBytes": "MIIHSzCCBtKgAwIBAgIUbzsIoXqjU1dNbF4wodHOAL0qUuYwCgYIKoZIzj0EAwMwNzEVMBMGA1UEChMMc2lnc3RvcmUuZGV2MR4wHAYDVQQDExVzaWdzdG9yZS1pbnRlcm1lZGlhdGUwHhcNMjUwNTA1MTkyNzE1WhcNMjUwNTA1MTkzNzE1WjAAMFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEc69rNe/nQVpSn++6QumSKn/D7zB+d0Ghl5tSPqypRWas9MRhZHyd2eCDNBKSxt8q+PWvBNf2Q99OB1iSz6oMwKOCBfEwggXtMA4GA1UdDwEB/wQEAwIHgDATBgNVHSUEDDAKBggrBgEFBQcDAzAdBgNVHQ4EFgQUJAehuvDJY9cwo383KYV+sxvc/nowHwYDVR0jBBgwFoAU39Ppz1YkEZb5qNjpKFWixi4YZD8wgYQGA1UdEQEB/wR6MHiGdmh0dHBzOi8vZ2l0aHViLmNvbS9zbHNhLWZyYW1ld29yay9zbHNhLWdpdGh1Yi1nZW5lcmF0b3IvLmdpdGh1Yi93b3JrZmxvd3MvZ2VuZXJhdG9yX2dlbmVyaWNfc2xzYTMueW1sQHJlZnMvdGFncy92Mi4xLjAwOQYKKwYBBAGDvzABAQQraHR0cHM6Ly90b2tlbi5hY3Rpb25zLmdpdGh1YnVzZXJjb250ZW50LmNvbTASBgorBgEEAYO/MAECBARwdXNoMDYGCisGAQQBg78wAQMEKDY0M2I4YmU3ZGZhODVlYzk4NGE1MjFjYzE3ZjI1ZGE2YzFkYzBmMTMwLQYKKwYBBAGDvzABBAQfUkVMRUFTRTogTWFrZSByZWxlYXNlIGNhbmRpZGF0ZTAmBgorBgEEAYO/MAEFBBhTdGFja0V4Y2hhbmdlL2Ruc2NvbnRyb2wwKAYKKwYBBAGDvzABBgQacmVmcy90YWdzL3YwLjAuMC10ZXN0LXNsc2EwOwYKKwYBBAGDvzABCAQtDCtodHRwczovL3Rva2VuLmFjdGlvbnMuZ2l0aHVidXNlcmNvbnRlbnQuY29tMIGGBgorBgEEAYO/MAEJBHgMdmh0dHBzOi8vZ2l0aHViLmNvbS9zbHNhLWZyYW1ld29yay9zbHNhLWdpdGh1Yi1nZW5lcmF0b3IvLmdpdGh1Yi93b3JrZmxvd3MvZ2VuZXJhdG9yX2dlbmVyaWNfc2xzYTMueW1sQHJlZnMvdGFncy92Mi4xLjAwOAYKKwYBBAGDvzABCgQqDChmN2RkOGM1NGMyMDY3YmFmYzEyY2E3YTU1NTk1ZDVlZTliNzUyMDRhMB0GCisGAQQBg78wAQsEDwwNZ2l0aHViLWhvc3RlZDA7BgorBgEEAYO/MAEMBC0MK2h0dHBzOi8vZ2l0aHViLmNvbS9TdGFja0V4Y2hhbmdlL2Ruc2NvbnRyb2wwOAYKKwYBBAGDvzABDQQqDCg2NDNiOGJlN2RmYTg1ZWM5ODRhNTIxY2MxN2YyNWRhNmMxZGMwZjEzMCoGCisGAQQBg78wAQ4EHAwacmVmcy90YWdzL3YwLjAuMC10ZXN0LXNsc2EwGAYKKwYBBAGDvzABDwQKDAg2Njk2MzcxNjAwBgorBgEEAYO/MAEQBCIMIGh0dHBzOi8vZ2l0aHViLmNvbS9TdGFja0V4Y2hhbmdlMBcGCisGAQQBg78wAREECQwHMTM5MzE3MTB6BgorBgEEAYO/MAESBGwMamh0dHBzOi8vZ2l0aHViLmNvbS9TdGFja0V4Y2hhbmdlL2Ruc2NvbnRyb2wvLmdpdGh1Yi93b3JrZmxvd3MvcmVsZWFzZV9kcmFmdC55bWxAcmVmcy90YWdzL3YwLjAuMC10ZXN0LXNsc2EwOAYKKwYBBAGDvzABEwQqDCg2NDNiOGJlN2RmYTg1ZWM5ODRhNTIxY2MxN2YyNWRhNmMxZGMwZjEzMBQGCisGAQQBg78wARQEBgwEcHVzaDBfBgorBgEEAYO/MAEVBFEMT2h0dHBzOi8vZ2l0aHViLmNvbS9TdGFja0V4Y2hhbmdlL2Ruc2NvbnRyb2wvYWN0aW9ucy9ydW5zLzE0ODQ0MzUxMzgxL2F0dGVtcHRzLzEwFgYKKwYBBAGDvzABFgQIDAZwdWJsaWMwgYoGCisGAQQB1nkCBAIEfAR6AHgAdgDdPTBqxscRMmMZHhyZZzcCokpeuN48rf+HinKALynujgAAAZah6rRWAAAEAwBHMEUCIQCsMW3Nhjihc954uxQ9rCzx+zV4b5vtEJBfonKwDVqh+wIgPT6/lmpTJYU6kj3clfwuiUDVQl7KvYRETkxC97ePclowCgYIKoZIzj0EAwMDZwAwZAIwCqYerCfR8QMwPpNoPKs2y3Iya9FWb8toiE3duO0GsBVBS9kc1/eVjtC2ie+Oa+FmAjAce8OoKd+t3ABiwNzM/dP2kyM07m4yiG6VX6rlfzLRG9TnknFVpfEmVIUWKwsjrYA="
    },
    "tlogEntries": [
      {
        "logIndex": "207027270",
        "logId": {
          "keyId": "wNI9atQGlz+VWfO6LRygH4QUfY/8W4RFwiT5i5WRgB0="
        },
        "kindVersion": {
          "kind": "dsse",
          "version": "0.0.1"
        },
        "integratedTime": "1746473235",
        "inclusionPromise": {
          "signedEntryTimestamp": "MEYCIQDIe++MahjKO5aZTvx3wtg7LdMxzac1Bwgml8PWHZvyzQIhAN1z57FBJfDaifWz5iXJE/n1i/GjaEW4LrC8wN53LZBl"
        },
        "inclusionProof": {
          "logIndex": "85123008",
          "rootHash": "yJ2yjwJzo2aDerhBkeLmT5oeooBnpVMw5HL6wz8FgeE=",
          "treeSize": "85123009",
          "hashes": [
            "Fe2f15hQTgm0oPP9VzuHPXUTXPOrQTnEldP9G+eRArQ=",
            "w+qAx2hgmVb+aS/X9uiw/ByYJKT2Pxw8RwSmbnYCgek=",
            "Pb/Z333s+bObMbyjoTXfyhD6YGMCC5ePtf4nI1qdC5Y=",
            "sveCbECGAMq/SuZET1Q7/ghrZZAPygh0HKn7wXcDnnw=",
            "vpGBUZyf35w04rMXD4KOPch1szLCF3hQ1ZjRHhML5qs=",
            "BBKiC8nvnANu3P/QSPB2vaa0EaPt5hbX1fqxYJs0fIw=",
            "STRiT5znScYqqjbHUoeSCDancp9yMA1GQyruLcyC0WU=",
            "F2Bk+eQOO/Lqk4MbWWqMLxaniv0cn5DVaH8uShdTvwU=",
            "TEPT8U+UTUa2fotX22CflObssrAOIfxDI3yfjgJhOxU=",
            "0nA3rRXKCPnwIXraGuhSLUXUoR3Z/pZWazoHDwFyFpQ=",
            "wPskhmu15ftxHjrzbc1mbR7g3XCKtM52kdXHazaWvH4=",
            "++1LMuz3tIdW1/pfEfhPfXC4ot1AwDAXDcPyfibzGyc=",
            "7v8qPHNDLerpduaMx06eb/MwgoQwczTn/cYGKX/9wZ4="
          ],
          "checkpoint": {
            "envelope": "rekor.sigstore.dev - 1193050959916656506\n85123009\nyJ2yjwJzo2aDerhBkeLmT5oeooBnpVMw5HL6wz8FgeE=\n\n— rekor.sigstore.dev wNI9ajBFAiBV3DRyH5wBEWCGIvGmB3BrOdEsqEc+iUM2GVVaetCvvwIhAOhHdOcEd2XNwE6xlcOU5X50xXlzfwsmCmhalHipr8qc\n"
          }
        },
        "canonicalizedBody": "eyJhcGlWZXJzaW9uIjoiMC4wLjEiLCJraW5kIjoiZHNzZSIsInNwZWMiOnsiZW52ZWxvcGVIYXNoIjp7ImFsZ29yaXRobSI6InNoYTI1NiIsInZhbHVlIjoiMWYxYzBiZTkzMDk1MDI0NzRmMmMzYTEwMGQzNDJmZjc2YTQ0YjU1MDM4NzQ0NWQxOTJmYzE0NDY4MmRhZTY4OCJ9LCJwYXlsb2FkSGFzaCI6eyJhbGdvcml0aG0iOiJzaGEyNTYiLCJ2YWx1ZSI6IjBlMjMzNjIzZDFmNTcyZTU0YTc0NmQwNWYwNjNjZDJmODU2MmI4NmI2ZGM2MTQwMjkxZTA4YjUwM2I5ODliZDMifSwic2lnbmF0dXJlcyI6W3sic2lnbmF0dXJlIjoiTUVVQ0lRRFBJNHUvNFphWDFRckUwWFpJSEg1V0RrU1F2c3IxVlpPSGYxUUN6MjN2QlFJZ1M5elc1Tk1rY3RZNW16TW44UTQvUW02S3R4Y3NLMU5LR3FuZzBCMEhKNGc9IiwidmVyaWZpZXIiOiJMUzB0TFMxQ1JVZEpUaUJEUlZKVVNVWkpRMEZVUlMwdExTMHRDazFKU1VoVGVrTkRRblJMWjBGM1NVSkJaMGxWWW5welNXOVljV3BWTVdST1lrWTBkMjlrU0U5QlREQnhWWFZaZDBObldVbExiMXBKZW1vd1JVRjNUWGNLVG5wRlZrMUNUVWRCTVZWRlEyaE5UV015Ykc1ak0xSjJZMjFWZFZwSFZqSk5ValIzU0VGWlJGWlJVVVJGZUZaNllWZGtlbVJIT1hsYVV6RndZbTVTYkFwamJURnNXa2RzYUdSSFZYZElhR05PVFdwVmQwNVVRVEZOVkd0NVRucEZNVmRvWTA1TmFsVjNUbFJCTVUxVWEzcE9la1V4VjJwQlFVMUdhM2RGZDFsSUNrdHZXa2w2YWpCRFFWRlpTVXR2V2tsNmFqQkVRVkZqUkZGblFVVmpOamx5VG1VdmJsRldjRk51S3lzMlVYVnRVMHR1TDBRM2VrSXJaREJIYUd3MWRGTUtVSEY1Y0ZKWFlYTTVUVkpvV2toNVpESmxRMFJPUWt0VGVIUTRjU3RRVjNaQ1RtWXlVVGs1VDBJeGFWTjZObTlOZDB0UFEwSm1SWGRuWjFoMFRVRTBSd3BCTVZWa1JIZEZRaTkzVVVWQmQwbElaMFJCVkVKblRsWklVMVZGUkVSQlMwSm5aM0pDWjBWR1FsRmpSRUY2UVdSQ1owNVdTRkUwUlVablVWVktRV1ZvQ25WMlJFcFpPV04zYnpNNE0wdFpWaXR6ZUhaakwyNXZkMGgzV1VSV1VqQnFRa0puZDBadlFWVXpPVkJ3ZWpGWmEwVmFZalZ4VG1wd1MwWlhhWGhwTkZrS1drUTRkMmRaVVVkQk1WVmtSVkZGUWk5M1VqWk5TR2xIWkcxb01HUklRbnBQYVRoMldqSnNNR0ZJVm1sTWJVNTJZbE01ZW1KSVRtaE1WMXA1V1ZjeGJBcGtNamw1WVhrNWVtSklUbWhNVjJSd1pFZG9NVmxwTVc1YVZ6VnNZMjFHTUdJelNYWk1iV1J3WkVkb01WbHBPVE5pTTBweVdtMTRkbVF6VFhaYU1sWjFDbHBZU21oa1J6bDVXREprYkdKdFZubGhWMDVtWXpKNGVsbFVUWFZsVnpGelVVaEtiRnB1VFhaa1IwWnVZM2s1TWsxcE5IaE1ha0YzVDFGWlMwdDNXVUlLUWtGSFJIWjZRVUpCVVZGeVlVaFNNR05JVFRaTWVUa3dZakowYkdKcE5XaFpNMUp3WWpJMWVreHRaSEJrUjJneFdXNVdlbHBZU21waU1qVXdXbGMxTUFwTWJVNTJZbFJCVTBKbmIzSkNaMFZGUVZsUEwwMUJSVU5DUVZKM1pGaE9iMDFFV1VkRGFYTkhRVkZSUW1jM09IZEJVVTFGUzBSWk1FMHlTVFJaYlZVekNscEhXbWhQUkZac1dYcHJORTVIUlRGTmFrWnFXWHBGTTFwcVNURmFSMFV5V1hwR2ExbDZRbTFOVkUxM1RGRlpTMHQzV1VKQ1FVZEVkbnBCUWtKQlVXWUtWV3RXVFZKVlJsUlNWRzluVkZkR2NscFRRbmxhVjNoc1dWaE9iRWxIVG1oaWJWSndXa2RHTUZwVVFXMUNaMjl5UW1kRlJVRlpUeTlOUVVWR1FrSm9WQXBrUjBacVlUQldORmt5YUdoaWJXUnNUREpTZFdNeVRuWmlibEo1WWpKM2QwdEJXVXRMZDFsQ1FrRkhSSFo2UVVKQ1oxRmhZMjFXYldONU9UQlpWMlI2Q2t3eldYZE1ha0YxVFVNeE1GcFlUakJNV0U1ell6SkZkMDkzV1V0TGQxbENRa0ZIUkhaNlFVSkRRVkYwUkVOMGIyUklVbmRqZW05MlRETlNkbUV5Vm5VS1RHMUdhbVJIYkhaaWJrMTFXakpzTUdGSVZtbGtXRTVzWTIxT2RtSnVVbXhpYmxGMVdUSTVkRTFKUjBkQ1oyOXlRbWRGUlVGWlR5OU5RVVZLUWtoblRRcGtiV2d3WkVoQ2VrOXBPSFphTW13d1lVaFdhVXh0VG5aaVV6bDZZa2hPYUV4WFdubFpWekZzWkRJNWVXRjVPWHBpU0U1b1RGZGtjR1JIYURGWmFURnVDbHBYTld4amJVWXdZak5KZGt4dFpIQmtSMmd4V1drNU0ySXpTbkphYlhoMlpETk5kbG95Vm5WYVdFcG9aRWM1ZVZneVpHeGliVlo1WVZkT1ptTXllSG9LV1ZSTmRXVlhNWE5SU0Vwc1dtNU5kbVJIUm01amVUa3lUV2swZUV4cVFYZFBRVmxMUzNkWlFrSkJSMFIyZWtGQ1EyZFJjVVJEYUcxT01sSnJUMGROTVFwT1IwMTVUVVJaTTFsdFJtMVpla1Y1V1RKRk0xbFVWVEZPVkdzeFdrUldiRnBVYkdsT2VsVjVUVVJTYUUxQ01FZERhWE5IUVZGUlFtYzNPSGRCVVhORkNrUjNkMDVhTW13d1lVaFdhVXhYYUhaak0xSnNXa1JCTjBKbmIzSkNaMFZGUVZsUEwwMUJSVTFDUXpCTlN6Sm9NR1JJUW5wUGFUaDJXakpzTUdGSVZta0tURzFPZG1KVE9WUmtSMFpxWVRCV05Ga3lhR2hpYldSc1RESlNkV015VG5aaWJsSjVZakozZDA5QldVdExkMWxDUWtGSFJIWjZRVUpFVVZGeFJFTm5NZ3BPUkU1cFQwZEtiRTR5VW0xWlZHY3hXbGROTlU5RVVtaE9WRWw0V1RKTmVFNHlXWGxPVjFKb1RtMU5lRnBIVFhkYWFrVjZUVU52UjBOcGMwZEJVVkZDQ21jM09IZEJVVFJGU0VGM1lXTnRWbTFqZVRrd1dWZGtla3d6V1hkTWFrRjFUVU14TUZwWVRqQk1XRTV6WXpKRmQwZEJXVXRMZDFsQ1FrRkhSSFo2UVVJS1JIZFJTMFJCWnpKT2Ftc3lUWHBqZUU1cVFYZENaMjl5UW1kRlJVRlpUeTlOUVVWUlFrTkpUVWxIYURCa1NFSjZUMms0ZGxveWJEQmhTRlpwVEcxT2RncGlVemxVWkVkR2FtRXdWalJaTW1ob1ltMWtiRTFDWTBkRGFYTkhRVkZSUW1jM09IZEJVa1ZGUTFGM1NFMVVUVFZOZWtVelRWUkNOa0puYjNKQ1owVkZDa0ZaVHk5TlFVVlRRa2QzVFdGdGFEQmtTRUo2VDJrNGRsb3liREJoU0ZacFRHMU9kbUpUT1ZSa1IwWnFZVEJXTkZreWFHaGliV1JzVERKU2RXTXlUbllLWW01U2VXSXlkM1pNYldSd1pFZG9NVmxwT1ROaU0wcHlXbTE0ZG1RelRYWmpiVlp6V2xkR2VscFdPV3RqYlVadFpFTTFOV0pYZUVGamJWWnRZM2s1TUFwWlYyUjZURE5aZDB4cVFYVk5RekV3V2xoT01FeFlUbk5qTWtWM1QwRlpTMHQzV1VKQ1FVZEVkbnBCUWtWM1VYRkVRMmN5VGtST2FVOUhTbXhPTWxKdENsbFVaekZhVjAwMVQwUlNhRTVVU1hoWk1rMTRUakpaZVU1WFVtaE9iVTE0V2tkTmQxcHFSWHBOUWxGSFEybHpSMEZSVVVKbk56aDNRVkpSUlVKbmQwVUtZMGhXZW1GRVFtWkNaMjl5UW1kRlJVRlpUeTlOUVVWV1FrWkZUVlF5YURCa1NFSjZUMms0ZGxveWJEQmhTRlpwVEcxT2RtSlRPVlJrUjBacVlUQldOQXBaTW1ob1ltMWtiRXd5VW5Wak1rNTJZbTVTZVdJeWQzWlpWMDR3WVZjNWRXTjVPWGxrVnpWNlRIcEZNRTlFVVRCTmVsVjRUWHBuZUV3eVJqQmtSMVowQ21OSVVucE1la1YzUm1kWlMwdDNXVUpDUVVkRWRucEJRa1puVVVsRVFWcDNaRmRLYzJGWFRYZG5XVzlIUTJselIwRlJVVUl4Ym10RFFrRkpSV1pCVWpZS1FVaG5RV1JuUkdSUVZFSnhlSE5qVWsxdFRWcElhSGxhV25walEyOXJjR1YxVGpRNGNtWXJTR2x1UzBGTWVXNTFhbWRCUVVGYVlXZzJjbEpYUVVGQlJRcEJkMEpJVFVWVlEwbFJRM05OVnpOT2FHcHBhR001TlRSMWVGRTVja042ZUN0NlZqUmlOWFowUlVwQ1ptOXVTM2RFVm5Gb0szZEpaMUJVTmk5c2JYQlVDa3BaVlRacmFqTmpiR1ozZFdsVlJGWlJiRGRMZGxsU1JWUnJlRU01TjJWUVkyeHZkME5uV1VsTGIxcEplbW93UlVGM1RVUmFkMEYzV2tGSmQwTnhXV1VLY2tObVVqaFJUWGRRY0U1dlVFdHpNbmt6U1hsaE9VWlhZamgwYjJsRk0yUjFUekJIYzBKV1FsTTVhMk14TDJWV2FuUkRNbWxsSzA5aEswWnRRV3BCWXdwbE9FOXZTMlFyZEROQlFtbDNUbnBOTDJSUU1tdDVUVEEzYlRSNWFVYzJWbGcyY214bWVreFNSemxVYm10dVJsWndaa1Z0VmtsVlYwdDNjMnB5V1VFOUNpMHRMUzB0UlU1RUlFTkZVbFJKUmtsRFFWUkZMUzB0TFMwSyJ9XX19"
      }
    ]
  },
  "dsseEnvelope": {
    "payload": "{"_type":"https://in-toto.io/Statement/v0.1","predicateType":"https://slsa.dev/provenance/v0.2","subject":[{"name":"dist/build_darwin_amd64_v1/dnscontrol","digest":{"sha256":"8a715be95115ab860c70ff8bea92433f688500a3501b606594e5275eb483db6b"}},{"name":"dist/dnscontrol_0.0.0-test-slsa_windows_amd64.zip","digest":{"sha256":"fd2803cfb12b5221cd064adb06c5d1996a45bfaa9cb68eba4afef17a2a16a22c"}},{"name":"dist/dnscontrol-0.0.0-test-slsa.arm64.rpm","digest":{"sha256":"1a957e49a20dd89515aad75d423e0c6968766b18156757da73a277187abccb92"}},{"name":"dist/checksums.txt","digest":{"sha256":"92c658de3908d5fd2e19f5ace152cb867604864ec394b573f9d589291175ed61"}},{"name":"dist/build_windows_arm64_v8.0/dnscontrol.exe","digest":{"sha256":"98f1d6589dc2974c17b167a587c0b8a837e13c9c47564f3f7c2fd0bb5c5ec1ca"}},{"name":"dist/build_freebsd_amd64_v1/dnscontrol","digest":{"sha256":"64d7db26eddf234597d4f65558e165d6193b4bb17b0395bd3b3a1b9249a53e36"}},{"name":"dist/dnscontrol_0.0.0-test-slsa_windows_arm64.zip","digest":{"sha256":"4e7751ecc3f51e3baa91446f3754f02ca83e9bf9c5d7773557738efbbec00c8e"}},{"name":"dist/dnscontrol-0.0.0-test-slsa.x86_64.rpm","digest":{"sha256":"f630d4a880b2777c6017612e7259dfbf42dc46a77d0d1e73727e675def176e27"}},{"name":"dist/build_windows_amd64_v1/dnscontrol.exe","digest":{"sha256":"b7c9a263afaa4fa442d732f9b2611ea432749a934ec63bba33d1ad62b318f917"}},{"name":"dist/build_freebsd_arm64_v8.0/dnscontrol","digest":{"sha256":"538091179740da6a22484791adacf154e4f1182a34afda1bf619fc4e2e65b502"}},{"name":"dist/build_darwin_arm64_v8.0/dnscontrol","digest":{"sha256":"fbe5e94664570f61e7db25006e8292b236c637ac3aa36a3a62f3f128a9f0d225"}},{"name":"dist/dnscontrol_0.0.0-test-slsa_freebsd_arm64.tar.gz","digest":{"sha256":"bbf07cbcfc3b41387f892373512996ba7e5b7fd1af7fbdaec2da518fdd3f395e"}},{"name":"dist/dnscontrol-0.0.0-test-slsa.arm64.deb","digest":{"sha256":"940219adf24d504606c5b942bb05ed78475fb059de490cfb6e3406c5c1601e71"}},{"name":"dist/dnscontrol_0.0.0-test-slsa_freebsd_amd64.tar.gz","digest":{"sha256":"a1668d9eedd4b2659eeb9816ae229e64270aabbe428f19b09b7b85386f9ecfe8"}},{"name":"dist/build_linux_amd64_v1/dnscontrol","digest":{"sha256":"68565d9635fdeeab79ee1c833f5294de00c9a563de922dfacc4140b63e4015cd"}},{"name":"dist/dnscontrol_0.0.0-test-slsa_darwin_all.tar.gz","digest":{"sha256":"21f28458dffd92e9aa31747e0ad636bbf4d56e71e938edb33bcd1a6af3f2fe9e"}},{"name":"dist/dnscontrol_0.0.0-test-slsa_linux_amd64.tar.gz","digest":{"sha256":"66f15eeefac0dfc3bbd449f7895c15f247c444988a160bcdc82a3715dfc1d326"}},{"name":"dist/dnscontrol-0.0.0-test-slsa.amd64.deb","digest":{"sha256":"368cd7849dd7ed58520017c823825d36e8e0cd03dc3792a2361b47cab3716efa"}},{"name":"dist/dnscontrol_0.0.0-test-slsa_linux_arm64.tar.gz","digest":{"sha256":"51529a1e1c541998854d1c14283ae481579de2c04a949a589a05990dac882442"}},{"name":"dist/build_linux_arm64_v8.0/dnscontrol","digest":{"sha256":"58c1135afb7a061a1df003bd6ee4cc09a4670936febfe94496db3c4f261165a3"}},{"name":"dist/build_darwin_all/dnscontrol","digest":{"sha256":"baa8b32cf1647dae8285dd4f559029cac0b29c7defab779482c91785418693ef"}}],"predicate":{"builder":{"id":"https://github.com/slsa-framework/slsa-github-generator/.github/workflows/generator_generic_slsa3.yml@refs/tags/v2.1.0"},"buildType":"https://github.com/slsa-framework/slsa-github-generator/generic@v1","invocation":{"configSource":{"uri":"git+https://github.com/StackExchange/dnscontrol@refs/tags/v0.0.0-test-slsa","digest":{"sha1":"643b8be7dfa85ec984a521cc17f25da6c1dc0f13"},"entryPoint":".github/workflows/release_draft.yml"},"parameters":{"vars":{"AXFRDDNS_DNSSEC_DOMAIN":"with-dnssec.dnscontrol.internal","AXFRDDNS_DOMAIN":"without-dnssec.dnscontrol.internal","AZURE_DNS_DOMAIN":"dnscontrol-azure.com","BIND_DOMAIN":"example.com","CLOUDFLAREAPI_DOMAIN":"dnscontroltest-cf.com","CNR_DOMAIN":"dnscontroltest-cnr.com","DIGITALOCEAN_DOMAIN":"dnscontrol-do.com","DISABLED_POWERDNS_DOMAIN":"dnscontrol-example.com","GANDI_V5_DOMAIN":"dnscontroltest-gandi.com","GCLOUD_DOMAIN":"dnscontroltest-gcloud.com","HEDNS_DOMAIN":"dnscontrol.net","HEXONET_DOMAIN":"yodream.com","MYTHICBEASTS_DOMAIN":"dnscontroltest-mythicbeasts.tuxes.uk","NAMEDOTCOM_DOMAIN":"dnscontrol-ndc.com","NS1_DOMAIN":"dnscontrolintegration.io","ROUTE53_DOMAIN":"dnscontroltest-r53.com","SAKURACLOUD_DOMAIN":"dnscontroltest-sakuracloud.dnsbeer.com","TRANSIP_DOMAIN":"dnscontrol.nl"}},"environment":{"github_actor":"tlimoncelli","github_actor_id":"6293917","github_base_ref":"","github_event_name":"push","github_event_payload":{"after":"643b8be7dfa85ec984a521cc17f25da6c1dc0f13","base_ref":null,"before":"0000000000000000000000000000000000000000","commits":[{"author":{"email":"eliheady@pm.me","name":"Eli Heady","username":"eliheady"},"committer":{"email":"eliheady@pm.me","name":"Eli Heady","username":"eliheady"},"distinct":true,"id":"643b8be7dfa85ec984a521cc17f25da6c1dc0f13","message":"This adds SLSA build attestation to the DNSControl release workflow\n\n* add SLSA generator call after release step\n\n* add SLSA info and verification doc\n\n* add SLSA badge to Readme\n\n* Fix attestation doc filename, limit digest generation to files below dist/","timestamp":"2025-05-05T13:19:45-04:00","tree_id":"0f3be78204324079b4e84aff70ac177f776fd442","url":"https://github.com/StackExchange/dnscontrol/commit/643b8be7dfa85ec984a521cc17f25da6c1dc0f13"}],"compare":"https://github.com/StackExchange/dnscontrol/commit/643b8be7dfa8","created":true,"deleted":false,"enterprise":{"avatar_url":"https://avatars.githubusercontent.com/b/3581?v=4","created_at":"2020-07-06T17:58:13Z","description":"","html_url":"https://github.com/enterprises/stack-overflow","id":3581,"name":"Stack Overflow","node_id":"MDEwOkVudGVycHJpc2UzNTgx","slug":"stack-overflow","updated_at":"2025-05-05T17:52:00Z","website_url":"https://stackoverflow.com/"},"forced":false,"head_commit":{"author":{"email":"eliheady@pm.me","name":"Eli Heady","username":"eliheady"},"committer":{"email":"eliheady@pm.me","name":"Eli Heady","username":"eliheady"},"distinct":true,"id":"643b8be7dfa85ec984a521cc17f25da6c1dc0f13","message":"This adds SLSA build attestation to the DNSControl release workflow\n\n* add SLSA generator call after release step\n\n* add SLSA info and verification doc\n\n* add SLSA badge to Readme\n\n* Fix attestation doc filename, limit digest generation to files below dist/","timestamp":"2025-05-05T13:19:45-04:00","tree_id":"0f3be78204324079b4e84aff70ac177f776fd442","url":"https://github.com/StackExchange/dnscontrol/commit/643b8be7dfa85ec984a521cc17f25da6c1dc0f13"},"organization":{"avatar_url":"https://avatars.githubusercontent.com/u/1393171?v=4","description":"","events_url":"https://api.github.com/orgs/StackExchange/events","hooks_url":"https://api.github.com/orgs/StackExchange/hooks","id":1393171,"issues_url":"https://api.github.com/orgs/StackExchange/issues","login":"StackExchange","members_url":"https://api.github.com/orgs/StackExchange/members{/member}","node_id":"MDEyOk9yZ2FuaXphdGlvbjEzOTMxNzE=","public_members_url":"https://api.github.com/orgs/StackExchange/public_members{/member}","repos_url":"https://api.github.com/orgs/StackExchange/repos","url":"https://api.github.com/orgs/StackExchange"},"pusher":{"email":"tlimoncelli@stackoverflow.com","name":"tlimoncelli"},"ref":"refs/tags/v0.0.0-test-slsa","repository":{"allow_forking":true,"archive_url":"https://api.github.com/repos/StackExchange/dnscontrol/{archive_format}{/ref}","archived":false,"assignees_url":"https://api.github.com/repos/StackExchange/dnscontrol/assignees{/user}","blobs_url":"https://api.github.com/repos/StackExchange/dnscontrol/git/blobs{/sha}","branches_url":"https://api.github.com/repos/StackExchange/dnscontrol/branches{/branch}","clone_url":"https://github.com/StackExchange/dnscontrol.git","collaborators_url":"https://api.github.com/repos/StackExchange/dnscontrol/collaborators{/collaborator}","comments_url":"https://api.github.com/repos/StackExchange/dnscontrol/comments{/number}","commits_url":"https://api.github.com/repos/StackExchange/dnscontrol/commits{/sha}","compare_url":"https://api.github.com/repos/StackExchange/dnscontrol/compare/{base}...{head}","contents_url":"https://api.github.com/repos/StackExchange/dnscontrol/contents/{+path}","contributors_url":"https://api.github.com/repos/StackExchange/dnscontrol/contributors","created_at":1472578950,"custom_properties":{},"default_branch":"main","deployments_url":"https://api.github.com/repos/StackExchange/dnscontrol/deployments","description":"Infrastructure as code for DNS!","disabled":false,"downloads_url":"https://api.github.com/repos/StackExchange/dnscontrol/downloads","events_url":"https://api.github.com/repos/StackExchange/dnscontrol/events","fork":false,"forks":436,"forks_count":436,"forks_url":"https://api.github.com/repos/StackExchange/dnscontrol/forks","full_name":"StackExchange/dnscontrol","git_commits_url":"https://api.github.com/repos/StackExchange/dnscontrol/git/commits{/sha}","git_refs_url":"https://api.github.com/repos/StackExchange/dnscontrol/git/refs{/sha}","git_tags_url":"https://api.github.com/repos/StackExchange/dnscontrol/git/tags{/sha}","git_url":"git://github.com/StackExchange/dnscontrol.git","has_discussions":true,"has_downloads":true,"has_issues":true,"has_pages":true,"has_projects":false,"has_wiki":false,"homepage":"https://dnscontrol.org/","hooks_url":"https://api.github.com/repos/StackExchange/dnscontrol/hooks","html_url":"https://github.com/StackExchange/dnscontrol","id":66963716,"is_template":false,"issue_comment_url":"https://api.github.com/repos/StackExchange/dnscontrol/issues/comments{/number}","issue_events_url":"https://api.github.com/repos/StackExchange/dnscontrol/issues/events{/number}","issues_url":"https://api.github.com/repos/StackExchange/dnscontrol/issues{/number}","keys_url":"https://api.github.com/repos/StackExchange/dnscontrol/keys{/key_id}","labels_url":"https://api.github.com/repos/StackExchange/dnscontrol/labels{/name}","language":"Go","languages_url":"https://api.github.com/repos/StackExchange/dnscontrol/languages","license":{"key":"mit","name":"MIT License","node_id":"MDc6TGljZW5zZTEz","spdx_id":"MIT","url":"https://api.github.com/licenses/mit"},"master_branch":"main","merges_url":"https://api.github.com/repos/StackExchange/dnscontrol/merges","milestones_url":"https://api.github.com/repos/StackExchange/dnscontrol/milestones{/number}","mirror_url":null,"name":"dnscontrol","node_id":"MDEwOlJlcG9zaXRvcnk2Njk2MzcxNg==","notifications_url":"https://api.github.com/repos/StackExchange/dnscontrol/notifications{?since,all,participating}","open_issues":96,"open_issues_count":96,"organization":"StackExchange","owner":{"avatar_url":"https://avatars.githubusercontent.com/u/1393171?v=4","email":null,"events_url":"https://api.github.com/users/StackExchange/events{/privacy}","followers_url":"https://api.github.com/users/StackExchange/followers","following_url":"https://api.github.com/users/StackExchange/following{/other_user}","gists_url":"https://api.github.com/users/StackExchange/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/StackExchange","id":1393171,"login":"StackExchange","name":"StackExchange","node_id":"MDEyOk9yZ2FuaXphdGlvbjEzOTMxNzE=","organizations_url":"https://api.github.com/users/StackExchange/orgs","received_events_url":"https://api.github.com/users/StackExchange/received_events","repos_url":"https://api.github.com/users/StackExchange/repos","site_admin":false,"starred_url":"https://api.github.com/users/StackExchange/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/StackExchange/subscriptions","type":"Organization","url":"https://api.github.com/users/StackExchange","user_view_type":"public"},"private":false,"pulls_url":"https://api.github.com/repos/StackExchange/dnscontrol/pulls{/number}","pushed_at":1746472613,"releases_url":"https://api.github.com/repos/StackExchange/dnscontrol/releases{/id}","size":26603,"ssh_url":"git@github.com:StackExchange/dnscontrol.git","stargazers":3373,"stargazers_count":3373,"stargazers_url":"https://api.github.com/repos/StackExchange/dnscontrol/stargazers","statuses_url":"https://api.github.com/repos/StackExchange/dnscontrol/statuses/{sha}","subscribers_url":"https://api.github.com/repos/StackExchange/dnscontrol/subscribers","subscription_url":"https://api.github.com/repos/StackExchange/dnscontrol/subscription","svn_url":"https://github.com/StackExchange/dnscontrol","tags_url":"https://api.github.com/repos/StackExchange/dnscontrol/tags","teams_url":"https://api.github.com/repos/StackExchange/dnscontrol/teams","topics":["dns","dnscontrol","go","infrastructure-as-code","workflow"],"trees_url":"https://api.github.com/repos/StackExchange/dnscontrol/git/trees{/sha}","updated_at":"2025-05-05T14:29:50Z","url":"https://api.github.com/repos/StackExchange/dnscontrol","visibility":"public","watchers":3373,"watchers_count":3373,"web_commit_signoff_required":false},"sender":{"avatar_url":"https://avatars.githubusercontent.com/u/6293917?v=4","events_url":"https://api.github.com/users/tlimoncelli/events{/privacy}","followers_url":"https://api.github.com/users/tlimoncelli/followers","following_url":"https://api.github.com/users/tlimoncelli/following{/other_user}","gists_url":"https://api.github.com/users/tlimoncelli/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/tlimoncelli","id":6293917,"login":"tlimoncelli","node_id":"MDQ6VXNlcjYyOTM5MTc=","organizations_url":"https://api.github.com/users/tlimoncelli/orgs","received_events_url":"https://api.github.com/users/tlimoncelli/received_events","repos_url":"https://api.github.com/users/tlimoncelli/repos","site_admin":false,"starred_url":"https://api.github.com/users/tlimoncelli/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/tlimoncelli/subscriptions","type":"User","url":"https://api.github.com/users/tlimoncelli","user_view_type":"public"}},"github_head_ref":"","github_ref":"refs/tags/v0.0.0-test-slsa","github_ref_type":"tag","github_repository_id":"66963716","github_repository_owner":"StackExchange","github_repository_owner_id":"1393171","github_run_attempt":"1","github_run_id":"14844351381","github_run_number":"40","github_sha1":"643b8be7dfa85ec984a521cc17f25da6c1dc0f13"}},"metadata":{"buildInvocationID":"14844351381-1","completeness":{"parameters":true,"environment":false,"materials":false},"reproducible":false},"materials":[{"uri":"git+https://github.com/StackExchange/dnscontrol@refs/tags/v0.0.0-test-slsa","digest":{"sha1":"643b8be7dfa85ec984a521cc17f25da6c1dc0f13"}}]}}",
    "payloadType": "application/vnd.in-toto+json",
    "signatures": [
      {
        "sig": "MEUCIQDPI4u/4ZaX1QrE0XZIHH5WDkSQvsr1VZOHf1QCz23vBQIgS9zW5NMkctY5mzMn8Q4/Qm6KtxcsK1NKGqng0B0HJ4g="
      }
    ]
  }
}

@eliheady
Copy link
Contributor Author

eliheady commented May 5, 2025

Hm. A separate release is not the intention. I have reproduced it though, and I'm afraid I just missed that it does this: in my testing I was not consistently deleting the draft releases and it seems the called workflow can reuse a release under some circumstances (that I can't characterize further at the moment). This is obviously not ready for inclusion in the project. I will do some research on this problem.

@eliheady eliheady marked this pull request as draft May 5, 2025 20:31
@tlimoncelli
Copy link
Contributor

Sounds good!

@eliheady
Copy link
Contributor Author

minor update ... I have been working on a different approach using the GitHub attest-build-provenance action, which is also SLSA level 3 compliant if implemented with a reusable workflow.

I think the SLSA builder approach in this current PR is going to be more challenging to implement correctly and has more potential to break. Both goreleaser and the SLSA framework project generator-generic-slsa3.yml create releases, making the duplicate release issue more likely.

The GitHub provenance generator might be a better long-term solution anyway because it is integrated with the GitHub platform. There is not much different for consumers of the attestations (use gh instead of slsa-verifier for local verification).

@eliheady
Copy link
Contributor Author

eliheady commented Jun 5, 2025

I'll be unable to work on DNSControl until sometime later this Summer, so I am going to close this. I don't want to discourage anyone else that wants to take it up in the meantime.

@eliheady eliheady closed this Jun 5, 2025
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.

2 participants