1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-01-24 04:16:27 +02:00

130 lines
3.1 KiB
Markdown
Raw Normal View History

---
title: Signing
series: customization
hideFromIndex: true
weight: 60
---
GoReleaser can sign some or all of the generated artifacts. Signing ensures
that the artifacts have been generated by yourself and your users can verify
that by comparing the generated signature with your public signing key.
Signing works in combination with checksum files and it is generally sufficient
to sign the checksum files only.
The default is configured to create a detached signature for the checksum files
2017-12-20 11:32:21 +01:00
with [GnuPG](https://www.gnupg.org/) and your default key. To enable signing
just add
```yaml
# goreleaser.yml
signs:
- artifacts: checksum
```
To customize the signing pipeline you can use the following options:
```yml
# .goreleaser.yml
signs:
-
# ID of the sign config, must be unique.
# Defaults to "default".
id: foo
# name of the signature file.
# '${artifact}' is the path to the artifact that should be signed.
#
# defaults to `${artifact}.sig`
signature: "${artifact}_sig"
# path to the signature command
#
# defaults to `gpg`
cmd: gpg2
# command line arguments for the command
#
# to sign with a specific key use
# args: ["-u", "<key id, fingerprint, email, ...>", "--output", "${signature}", "--detach-sign", "${artifact}"]
#
# defaults to `["--output", "${signature}", "--detach-sign", "${artifact}"]`
args: ["--output", "${signature}", "${artifact}"]
# which artifacts to sign
#
# checksum: only checksum file(s)
# all: all artifacts
# none: no signing
#
# defaults to `none`
artifacts: all
# IDs of the artifacts to sign.
# Defaults to all.
# If `artifacts` is checksum, this fields has no effect.
ids:
- foo
- bar
```
## Limitations
You can sign with any command that outputs a file.
If what you want to use does not do it, you can always hack by setting the
command to `sh -c`. For example:
```yaml
# goreleaser.yml
signs:
- cmd: sh
args:
- '-c'
- 'echo "${artifact} is signed and I can prove it" | tee ${signature}'
artifacts: all
```
And it will work just fine. Just make sure to always use the `${signature}`
template variable as the result file name and `${artifact}` as the origin file.
## Signing with gon
You can use [gon][] to create notarized macOS apps. Here's an example config:
```yaml
builds:
- binary: foo
id: foo
goos:
- linux
- windows
goarch:
- amd64
# notice that we need a separated build for the macos binary only:
- binary: foo
id: foo-macos
goos:
- darwin
goarch:
- amd64
signs:
- signature: "${artifact}.dmg"
ids:
- foo-macos # here we filter the macos only build id
# you'll need to have gon on PATH
cmd: gon
# you can follow the gon docs to properly create the gon.hcl config file:
# https://github.com/mitchellh/gon
args:
- gon.hcl
artifacts: all
```
Note that notarizing take some time, and will need to be run from a macOS machine.
You can also check [this issue](https://github.com/goreleaser/goreleaser/issues/1227) for more details.
[gon]: https://github.com/mitchellh/gon