2017-12-13 17:14:01 +01:00
|
|
|
---
|
|
|
|
title: Signing
|
2018-04-24 22:20:12 -07:00
|
|
|
series: customization
|
|
|
|
hideFromIndex: true
|
|
|
|
weight: 60
|
2017-12-13 17:14:01 +01:00
|
|
|
---
|
|
|
|
|
|
|
|
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
|
2017-12-13 22:57:24 +01:00
|
|
|
to sign the checksum files only.
|
2017-12-13 17:14:01 +01:00
|
|
|
|
|
|
|
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
|
2017-12-13 17:14:01 +01:00
|
|
|
just add
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
# goreleaser.yml
|
2019-07-21 18:46:46 -03:00
|
|
|
signs:
|
|
|
|
- artifacts: checksum
|
2017-12-13 17:14:01 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
To customize the signing pipeline you can use the following options:
|
|
|
|
|
|
|
|
```yml
|
|
|
|
# .goreleaser.yml
|
2019-07-21 18:46:46 -03:00
|
|
|
signs:
|
|
|
|
-
|
|
|
|
# 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
|
2019-11-08 09:10:56 -03:00
|
|
|
|
|
|
|
# IDs of the artifacts to sign.
|
|
|
|
# Defaults to all.
|
|
|
|
# If `artifacts` is checksum, this fields has no effect.
|
|
|
|
ids:
|
|
|
|
- foo
|
|
|
|
- bar
|
2017-12-13 17:14:01 +01:00
|
|
|
```
|
2019-12-26 23:14:40 -03:00
|
|
|
|
|
|
|
## 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
|