1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-01-16 03:52:12 +02:00

fix: ensure certificate is always within dist (#2680)

* fix: ensure certificate is always within dist

* fix: improve impl

* fix: uneeded err check
This commit is contained in:
Carlos Alexandro Becker 2021-11-22 14:52:30 -03:00 committed by GitHub
parent 6e34a279a3
commit 72434a036e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 9 additions and 30 deletions

View File

@ -6,7 +6,6 @@ import (
"io" "io"
"os" "os"
"os/exec" "os/exec"
"path/filepath"
"strings" "strings"
"github.com/apex/log" "github.com/apex/log"
@ -114,7 +113,7 @@ func sign(ctx *context.Context, cfg config.Sign, artifacts []*artifact.Artifact)
func signone(ctx *context.Context, cfg config.Sign, art *artifact.Artifact) ([]*artifact.Artifact, error) { func signone(ctx *context.Context, cfg config.Sign, art *artifact.Artifact) ([]*artifact.Artifact, error) {
env := ctx.Env.Copy() env := ctx.Env.Copy()
env["artifactName"] = art.Name env["artifactName"] = art.Name // shouldn't be used
env["artifact"] = art.Path env["artifact"] = art.Path
env["artifactID"] = art.ID() env["artifactID"] = art.ID()
@ -190,19 +189,16 @@ func signone(ctx *context.Context, cfg config.Sign, art *artifact.Artifact) ([]*
return nil, nil return nil, nil
} }
// re-execute template results, using artifact name as artifact so they eval to the actual needed file name.
env["artifact"] = art.Name env["artifact"] = art.Name
name, err = tmpl.New(ctx).WithEnv(env).Apply(expand(cfg.Signature, env)) name, _ = tmpl.New(ctx).WithEnv(env).Apply(expand(cfg.Signature, env)) // could never error as it passed the previous check
if err != nil { cert, _ = tmpl.New(ctx).WithEnv(env).Apply(expand(cfg.Certificate, env)) // could never error as it passed the previous check
return nil, fmt.Errorf("sign failed: %s: invalid template: %w", art.Name, err)
}
artifactPathBase, _ := filepath.Split(art.Path)
sigFilename := filepath.Base(env["signature"])
result := []*artifact.Artifact{ result := []*artifact.Artifact{
{ {
Type: artifact.Signature, Type: artifact.Signature,
Name: name, Name: name,
Path: filepath.Join(artifactPathBase, sigFilename), Path: env["signature"],
Extra: map[string]interface{}{ Extra: map[string]interface{}{
artifact.ExtraID: cfg.ID, artifact.ExtraID: cfg.ID,
}, },
@ -213,7 +209,7 @@ func signone(ctx *context.Context, cfg config.Sign, art *artifact.Artifact) ([]*
result = append(result, &artifact.Artifact{ result = append(result, &artifact.Artifact{
Type: artifact.Certificate, Type: artifact.Certificate,
Name: cert, Name: cert,
Path: filepath.Join(artifactPathBase, cert), Path: env["certificate"],
Extra: map[string]interface{}{ Extra: map[string]interface{}{
artifact.ExtraID: cfg.ID, artifact.ExtraID: cfg.ID,
}, },

View File

@ -522,7 +522,7 @@ func TestSignArtifacts(t *testing.T) {
config.Project{ config.Project{
Signs: []config.Sign{ Signs: []config.Sign{
{ {
Certificate: "${artifactName}.pem", Certificate: "${artifact}.pem",
Artifacts: "checksum", Artifacts: "checksum",
}, },
}, },
@ -539,7 +539,7 @@ func TestSignArtifacts(t *testing.T) {
Signs: []config.Sign{ Signs: []config.Sign{
{ {
Env: []string{"NOT_HONK=honk", "HONK={{ .Env.NOT_HONK }}"}, Env: []string{"NOT_HONK=honk", "HONK={{ .Env.NOT_HONK }}"},
Certificate: `{{ trimsuffix (trimsuffix .Env.artifactName ".tar.gz") ".deb" }}_${HONK}.pem`, Certificate: `{{ trimsuffix (trimsuffix .Env.artifact ".tar.gz") ".deb" }}_${HONK}.pem`,
Artifacts: "all", Artifacts: "all",
}, },
}, },
@ -669,6 +669,7 @@ func testSign(tb testing.TB, ctx *context.Context, certificateNames, signaturePa
certNames := []string{} certNames := []string{}
for _, cert := range certificates { for _, cert := range certificates {
certNames = append(certNames, cert.Name) certNames = append(certNames, cert.Name)
require.True(tb, strings.HasPrefix(cert.Path, ctx.Config.Dist))
} }
sort.Strings(certificateNames) sort.Strings(certificateNames)
sort.Strings(certNames) sort.Strings(certNames)

View File

@ -19,12 +19,6 @@ docker_signs:
# Defaults to "default". # Defaults to "default".
id: foo id: foo
# Name/template of the signature file.
# Note that with cosign you don't need to use this.
#
# Defaults to empty.
signature: "${artifact}_sig"
# Path to the signature command # Path to the signature command
# #
# Defaults to `cosign` # Defaults to `cosign`
@ -61,14 +55,6 @@ docker_signs:
# Defaults to empty # Defaults to empty
stdin_file: ./.password stdin_file: ./.password
# Sets a certificate name that your signing command should write to.
# You can later use `${certificate}` or `.Env.certificate` in the `args` section.
# This is particularly useful for keyless signing (for instance, with cosign).
# Note that this should be a name, not a path.
#
# Defaults to empty.
certificate: '{{ trimsuffix .Env.artifactName ".tar.gz" }}.pem'
# List of environment variables that will be passed to the signing command as well as the templates. # List of environment variables that will be passed to the signing command as well as the templates.
# #
# Defaults to empty # Defaults to empty
@ -84,7 +70,6 @@ These environment variables might be available in the fields that are templateab
- `${artifact}`: the path to the artifact that will be signed [^1] - `${artifact}`: the path to the artifact that will be signed [^1]
- `${artifactID}`: the ID of the artifact that will be signed - `${artifactID}`: the ID of the artifact that will be signed
- `${certificate}`: the certificate filename, if provided - `${certificate}`: the certificate filename, if provided
- `${artifactName}`: the name of the artifact [^1]
[^1]: notice that the this might contain `/` characters, which depending on how you use it migth evaluate to actual paths within the filesystem. Use with care. [^1]: notice that the this might contain `/` characters, which depending on how you use it migth evaluate to actual paths within the filesystem. Use with care.

View File

@ -107,9 +107,6 @@ These environment variables might be available in the fields that are templateab
- `${artifactID}`: the ID of the artifact that will be signed - `${artifactID}`: the ID of the artifact that will be signed
- `${certificate}`: the certificate filename, if provided - `${certificate}`: the certificate filename, if provided
- `${signature}`: the signature filename - `${signature}`: the signature filename
- `${artifactName}`: the name of the artifact [^1]
[^1]: notice that the name won't have the `dist` prefix, so if you are using it to build filepaths, be sure to prefix them properly. Prefer using `${artifact}` instead.
## Signing with cosign ## Signing with cosign