Using GoReleaser and GitHub Actions to release Rust and Zig projects
GoReleaser v2.5 is out with Rust and Zig support - let’s explore how we can use it!
In GoReleaser v0.176.0 (both OSS and Pro), we released the ability to sign Docker images - with cosign in mind, and also did small quality-of-life improvements in the artifact signing feature.
In this post we’ll explore how to quickly add this to your GoReleaser config so your users can verify the artifacts they download.
You’ll need to install cosign, and then generate a key pair with it:
cosign generate-key-pair
It’ll ask for a password and its confirmation - and that’s it.
PS: the private key itself is encrypted, so it’s safe to push it to your git repository if you have a descent password. I recommend using some password generator and create a really big password.
Here things are fairly simple as well, you just need to pass the correct settings to the signs
section, and declare a docker_signs
section as well.
I also recommend setting the checksums.name_template
setting to simply checksums.txt
.
Here’s how it looks like:
checksum:
name_template: 'checksums.txt'
signs:
- cmd: cosign
stdin: '{{ .Env.COSIGN_PWD }}'
args: ["sign-blob", "-key=cosign.key", "-output=${signature}", "${artifact}"]
artifacts: checksum
docker_signs:
- artifacts: manifests
stdin: '{{ .Env.COSIGN_PWD }}'
In this example I’m signing only the checksum
file and the produced Docker manifests, but you can change that as you see fit. Check the documentation on signs and docker signs for more details.
Notice that in this example you would still need to install cosign
, have the cosign.key
in the repository root folder and export the key password as COSIGN_PWD
.
Let’s say you sign only the checksum, as the example above. In that case, your user will need:
cosign.pub
)checksums.txt
file that was uploaded to the releasechecksums.txt.sig
file that was uploaded to the releaseThen, they can verify using cosign
:
cosign verify-blob \
-key cosign.pub \
-signature checksums.txt.sig \
checksums.txt
If the validation succeeds, it means the checksums.txt
was not tampered with, so we can use it to verify the hashes of other files using sha256sum
:
sha256sum --ignore-missing -c checksums.txt
Doing that, we can verify our binaries are correct.
We can also verify the Docker image signature. Here cosign
actually embeds the signature in the image manifest, so we only need the public key used to sign it in order to verify its authenticity:
cosign verify -key cosign.pub user/image
And that’s it!
This is just a quick “how-to” on these new features, I hope you find them useful!
FWIW, GoReleaser itself is also signed with cosign
now! You can check the documentation on how to verify the artifacts here and the Docker images here.
I already had the idea of integrating GoReleaser with cosign
in my backlog, but seeing Engin’s article on how to do it in previous GoReleaser versions gave me the extra motivation I needed to actually sit down and do it.
So, thanks Engin for the article and overall support of OpenSource and GoReleaser, its really appreciated! 🖤