2021-06-26 16:36:31 -03:00
|
|
|
package docker
|
|
|
|
|
|
|
|
import (
|
2021-07-23 08:09:29 -03:00
|
|
|
"bytes"
|
2021-07-24 21:32:04 -03:00
|
|
|
"fmt"
|
2021-07-23 08:09:29 -03:00
|
|
|
"io"
|
2021-06-26 16:36:31 -03:00
|
|
|
"os/exec"
|
2021-06-27 17:55:00 -03:00
|
|
|
"sync"
|
2021-06-26 16:36:31 -03:00
|
|
|
|
|
|
|
"github.com/apex/log"
|
2021-07-23 08:09:29 -03:00
|
|
|
"github.com/goreleaser/goreleaser/internal/gio"
|
|
|
|
"github.com/goreleaser/goreleaser/internal/logext"
|
2021-11-24 14:42:12 +01:00
|
|
|
"github.com/goreleaser/goreleaser/pkg/context"
|
2021-06-26 16:36:31 -03:00
|
|
|
)
|
|
|
|
|
2021-06-27 17:55:00 -03:00
|
|
|
var (
|
|
|
|
manifesters = map[string]manifester{}
|
|
|
|
imagers = map[string]imager{}
|
|
|
|
lock sync.Mutex
|
|
|
|
)
|
|
|
|
|
|
|
|
func registerManifester(use string, impl manifester) {
|
|
|
|
lock.Lock()
|
|
|
|
defer lock.Unlock()
|
|
|
|
manifesters[use] = impl
|
|
|
|
}
|
|
|
|
|
|
|
|
func registerImager(use string, impl imager) {
|
|
|
|
lock.Lock()
|
|
|
|
defer lock.Unlock()
|
|
|
|
imagers[use] = impl
|
|
|
|
}
|
|
|
|
|
2021-06-26 16:36:31 -03:00
|
|
|
// imager is something that can build and push docker images.
|
|
|
|
type imager interface {
|
2021-11-24 14:42:12 +01:00
|
|
|
Build(ctx *context.Context, root string, images, flags []string) error
|
|
|
|
Push(ctx *context.Context, image string, flags []string) error
|
2021-06-26 16:36:31 -03:00
|
|
|
}
|
|
|
|
|
|
|
|
// manifester is something that can create and push docker manifests.
|
|
|
|
type manifester interface {
|
2021-11-24 14:42:12 +01:00
|
|
|
Create(ctx *context.Context, manifest string, images, flags []string) error
|
|
|
|
Push(ctx *context.Context, manifest string, flags []string) error
|
2021-06-26 16:36:31 -03:00
|
|
|
}
|
|
|
|
|
|
|
|
// nolint: unparam
|
2021-11-24 14:42:12 +01:00
|
|
|
func runCommand(ctx *context.Context, dir, binary string, args ...string) error {
|
2021-07-23 08:09:29 -03:00
|
|
|
fields := log.Fields{
|
|
|
|
"cmd": append([]string{binary}, args[0]),
|
|
|
|
"cwd": dir,
|
|
|
|
}
|
|
|
|
|
2021-06-26 16:36:31 -03:00
|
|
|
/* #nosec */
|
|
|
|
cmd := exec.CommandContext(ctx, binary, args...)
|
|
|
|
cmd.Dir = dir
|
2021-11-24 14:42:12 +01:00
|
|
|
cmd.Env = ctx.Env.Strings()
|
2021-07-23 08:09:29 -03:00
|
|
|
|
|
|
|
var b bytes.Buffer
|
|
|
|
w := gio.Safe(&b)
|
|
|
|
cmd.Stderr = io.MultiWriter(logext.NewWriter(fields, logext.Error), w)
|
|
|
|
cmd.Stdout = io.MultiWriter(logext.NewWriter(fields, logext.Info), w)
|
|
|
|
|
2021-08-31 23:34:21 -03:00
|
|
|
log.WithFields(fields).WithField("args", args[1:]).Debug("running")
|
2021-07-24 21:32:04 -03:00
|
|
|
if err := cmd.Run(); err != nil {
|
|
|
|
return fmt.Errorf("%w: %s", err, b.String())
|
|
|
|
}
|
|
|
|
return nil
|
2021-06-26 16:36:31 -03:00
|
|
|
}
|