mirror of
https://github.com/goreleaser/goreleaser.git
synced 2025-01-08 03:31:59 +02:00
bf19dc1079
* feat: moving some cmd logs to debug Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * feat: moving some cmd logs to debug Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com>
56 lines
1.3 KiB
Go
56 lines
1.3 KiB
Go
// Package before provides the pipe implementation that runs before all other pipes.
|
|
package before
|
|
|
|
import (
|
|
"bytes"
|
|
"fmt"
|
|
"io"
|
|
"os/exec"
|
|
|
|
"github.com/apex/log"
|
|
"github.com/caarlos0/go-shellwords"
|
|
"github.com/goreleaser/goreleaser/internal/gio"
|
|
"github.com/goreleaser/goreleaser/internal/logext"
|
|
"github.com/goreleaser/goreleaser/internal/tmpl"
|
|
"github.com/goreleaser/goreleaser/pkg/context"
|
|
)
|
|
|
|
// Pipe is a global hook pipe.
|
|
type Pipe struct{}
|
|
|
|
// String is the name of this pipe.
|
|
func (Pipe) String() string {
|
|
return "running before hooks"
|
|
}
|
|
|
|
// Run executes the hooks.
|
|
func (Pipe) Run(ctx *context.Context) error {
|
|
tmpl := tmpl.New(ctx)
|
|
/* #nosec */
|
|
for _, step := range ctx.Config.Before.Hooks {
|
|
s, err := tmpl.Apply(step)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
args, err := shellwords.Parse(s)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
cmd := exec.Command(args[0], args[1:]...)
|
|
cmd.Env = ctx.Env.Strings()
|
|
|
|
var b bytes.Buffer
|
|
w := gio.Safe(&b)
|
|
fields := log.Fields{"hook": step}
|
|
cmd.Stderr = io.MultiWriter(logext.NewWriter(fields, logext.Error), w)
|
|
cmd.Stdout = io.MultiWriter(logext.NewWriter(fields, logext.Info), w)
|
|
|
|
log.WithFields(fields).Info("running")
|
|
if err := cmd.Run(); err != nil {
|
|
return fmt.Errorf("hook failed: %s: %w; output: %s", step, err, b.String())
|
|
}
|
|
}
|
|
return nil
|
|
}
|