mirror of
https://github.com/goreleaser/goreleaser.git
synced 2025-01-22 04:08:49 +02:00
15fd80eded
* Revert "feat: split brew tap in 2 steps (#1425)" This reverts commit 5e8882fbb6b8a841b0f21a8f63d3308b0e50118e. Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: brew generation Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * feat: improve bucket write Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: tests Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: tests Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: minio test Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: lint issues Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: lint issues Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: err handling Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com>
64 lines
1.3 KiB
Go
64 lines
1.3 KiB
Go
package blob
|
|
|
|
import (
|
|
"fmt"
|
|
"strings"
|
|
|
|
"github.com/goreleaser/goreleaser/internal/pipe"
|
|
"github.com/goreleaser/goreleaser/internal/semerrgroup"
|
|
"github.com/goreleaser/goreleaser/pkg/context"
|
|
)
|
|
|
|
// Pipe for Artifactory
|
|
type Pipe struct{}
|
|
|
|
// String returns the description of the pipe
|
|
func (Pipe) String() string {
|
|
return "blobs"
|
|
}
|
|
|
|
// Default sets the pipe defaults
|
|
func (Pipe) Default(ctx *context.Context) error {
|
|
for i := range ctx.Config.Blobs {
|
|
blob := &ctx.Config.Blobs[i]
|
|
|
|
if blob.Bucket == "" || blob.Provider == "" {
|
|
return fmt.Errorf("bucket or provider cannot be empty")
|
|
}
|
|
if blob.Folder == "" {
|
|
blob.Folder = "{{ .ProjectName }}/{{ .Tag }}"
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// Publish to specified blob bucket url
|
|
func (Pipe) Publish(ctx *context.Context) error {
|
|
if len(ctx.Config.Blobs) == 0 {
|
|
return pipe.Skip("Blob section is not configured")
|
|
}
|
|
var up uploader = productionUploader{}
|
|
if ctx.SkipPublish {
|
|
up = skipUploader{}
|
|
}
|
|
|
|
var g = semerrgroup.New(ctx.Parallelism)
|
|
for _, conf := range ctx.Config.Blobs {
|
|
conf := conf
|
|
g.Go(func() error {
|
|
return doUpload(ctx, conf, up)
|
|
})
|
|
}
|
|
return g.Wait()
|
|
}
|
|
|
|
// errorContains check if error contains specific string
|
|
func errorContains(err error, subs ...string) bool {
|
|
for _, sub := range subs {
|
|
if strings.Contains(err.Error(), sub) {
|
|
return true
|
|
}
|
|
}
|
|
return false
|
|
}
|