2020-05-26 00:48:10 -03:00
|
|
|
// Package before provides the pipe implementation that runs before all other pipes.
|
2018-03-28 15:31:09 +02:00
|
|
|
package before
|
|
|
|
|
|
|
|
import (
|
2021-07-23 08:09:29 -03:00
|
|
|
"bytes"
|
2018-03-28 15:31:09 +02:00
|
|
|
"fmt"
|
2021-07-23 08:09:29 -03:00
|
|
|
"io"
|
2018-03-28 15:31:09 +02:00
|
|
|
"os/exec"
|
|
|
|
|
2021-03-22 08:45:18 -03:00
|
|
|
"github.com/caarlos0/go-shellwords"
|
2022-06-21 21:11:15 -03:00
|
|
|
"github.com/caarlos0/log"
|
2021-07-23 08:09:29 -03:00
|
|
|
"github.com/goreleaser/goreleaser/internal/gio"
|
|
|
|
"github.com/goreleaser/goreleaser/internal/logext"
|
2019-03-03 14:12:22 -03:00
|
|
|
"github.com/goreleaser/goreleaser/internal/tmpl"
|
2018-08-14 23:50:20 -03:00
|
|
|
"github.com/goreleaser/goreleaser/pkg/context"
|
2018-03-28 15:31:09 +02:00
|
|
|
)
|
|
|
|
|
2020-05-26 00:48:10 -03:00
|
|
|
// Pipe is a global hook pipe.
|
2018-03-28 15:31:09 +02:00
|
|
|
type Pipe struct{}
|
|
|
|
|
2022-06-22 21:56:53 -03:00
|
|
|
func (Pipe) String() string { return "running before hooks" }
|
|
|
|
func (Pipe) Skip(ctx *context.Context) bool {
|
|
|
|
return len(ctx.Config.Before.Hooks) == 0 || ctx.SkipBefore
|
|
|
|
}
|
2018-03-28 15:31:09 +02:00
|
|
|
|
2020-05-26 00:48:10 -03:00
|
|
|
// Run executes the hooks.
|
2018-03-28 15:31:09 +02:00
|
|
|
func (Pipe) Run(ctx *context.Context) error {
|
2021-03-22 08:45:18 -03:00
|
|
|
tmpl := tmpl.New(ctx)
|
2018-03-28 15:31:09 +02:00
|
|
|
/* #nosec */
|
|
|
|
for _, step := range ctx.Config.Before.Hooks {
|
2019-03-03 14:12:22 -03:00
|
|
|
s, err := tmpl.Apply(step)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2020-04-12 14:12:53 -03:00
|
|
|
args, err := shellwords.Parse(s)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2021-07-23 08:09:29 -03:00
|
|
|
|
2018-03-28 15:31:09 +02:00
|
|
|
cmd := exec.Command(args[0], args[1:]...)
|
2019-04-09 09:15:05 -03:00
|
|
|
cmd.Env = ctx.Env.Strings()
|
2021-07-23 08:09:29 -03:00
|
|
|
|
|
|
|
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())
|
2018-03-28 15:31:09 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|