mirror of
https://github.com/goreleaser/goreleaser.git
synced 2025-01-24 04:16:27 +02:00
77 lines
1.9 KiB
Go
77 lines
1.9 KiB
Go
// Package publish contains the publishing pipe.
|
|
package publish
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/apex/log"
|
|
"github.com/fatih/color"
|
|
"github.com/goreleaser/goreleaser/internal/pipe"
|
|
"github.com/goreleaser/goreleaser/internal/pipe/artifactory"
|
|
"github.com/goreleaser/goreleaser/internal/pipe/brew"
|
|
"github.com/goreleaser/goreleaser/internal/pipe/docker"
|
|
"github.com/goreleaser/goreleaser/internal/pipe/put"
|
|
"github.com/goreleaser/goreleaser/internal/pipe/release"
|
|
"github.com/goreleaser/goreleaser/internal/pipe/s3"
|
|
"github.com/goreleaser/goreleaser/internal/pipe/scoop"
|
|
"github.com/goreleaser/goreleaser/internal/pipe/snapcraft"
|
|
"github.com/goreleaser/goreleaser/pkg/context"
|
|
"github.com/pkg/errors"
|
|
)
|
|
|
|
// Pipe that publishes artifacts
|
|
type Pipe struct{}
|
|
|
|
func (Pipe) String() string {
|
|
return "publishing"
|
|
}
|
|
|
|
// Publisher should be implemented by pipes that want to publish artifacts
|
|
type Publisher interface {
|
|
fmt.Stringer
|
|
|
|
// Default sets the configuration defaults
|
|
Publish(ctx *context.Context) error
|
|
}
|
|
|
|
// nolint: gochecknoglobals
|
|
var publishers = []Publisher{
|
|
s3.Pipe{},
|
|
put.Pipe{},
|
|
artifactory.Pipe{},
|
|
docker.Pipe{},
|
|
snapcraft.Pipe{},
|
|
// This should be one of the last steps
|
|
release.Pipe{},
|
|
// brew and scoop use the release URL, so, they should be last
|
|
brew.Pipe{},
|
|
scoop.Pipe{},
|
|
}
|
|
|
|
// Run the pipe
|
|
func (Pipe) Run(ctx *context.Context) error {
|
|
if ctx.SkipPublish {
|
|
return pipe.ErrSkipPublishEnabled
|
|
}
|
|
for _, publisher := range publishers {
|
|
log.Infof(color.New(color.Bold).Sprint(publisher.String()))
|
|
if err := handle(publisher.Publish(ctx)); err != nil {
|
|
return errors.Wrapf(err, "%s: failed to publish artifacts", publisher.String())
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// TODO: for now this is duplicated, we should have better error handling
|
|
// eventually.
|
|
func handle(err error) error {
|
|
if err == nil {
|
|
return nil
|
|
}
|
|
if pipe.IsSkip(err) {
|
|
log.WithField("reason", err.Error()).Warn("skipped")
|
|
return nil
|
|
}
|
|
return err
|
|
}
|