1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-02-03 13:11:48 +02:00

48 lines
1.2 KiB
Go
Raw Normal View History

// Package upload provides a Pipe that push using HTTP.
package upload
2018-06-14 00:37:48 -03:00
import (
"fmt"
2018-06-14 00:37:48 -03:00
h "net/http"
"github.com/goreleaser/goreleaser/internal/http"
2018-09-12 14:18:01 -03:00
"github.com/goreleaser/goreleaser/internal/pipe"
"github.com/goreleaser/goreleaser/pkg/context"
2018-06-14 00:37:48 -03:00
)
// Pipe for http publishing.
2018-06-14 00:37:48 -03:00
type Pipe struct{}
// String returns the description of the pipe.
2018-06-14 00:37:48 -03:00
func (Pipe) String() string {
return "http upload"
2018-06-14 00:37:48 -03:00
}
// Default sets the pipe defaults.
2018-06-14 00:37:48 -03:00
func (Pipe) Default(ctx *context.Context) error {
return http.Defaults(ctx.Config.Uploads)
2018-06-14 00:37:48 -03:00
}
// Publish artifacts.
2018-10-16 20:50:49 -03:00
func (Pipe) Publish(ctx *context.Context) error {
if len(ctx.Config.Uploads) == 0 {
return pipe.Skip("uploads section is not configured")
2018-06-14 00:37:48 -03:00
}
// Check requirements for every instance we have configured.
// If not fulfilled, we can skip this pipeline
for _, instance := range ctx.Config.Uploads {
2018-11-07 22:04:49 -02:00
instance := instance
if skip := http.CheckConfig(ctx, &instance, "upload"); skip != nil {
2018-09-12 14:18:01 -03:00
return pipe.Skip(skip.Error())
2018-06-14 00:37:48 -03:00
}
}
return http.Upload(ctx, ctx.Config.Uploads, "upload", func(res *h.Response) error {
2018-06-14 00:37:48 -03:00
if c := res.StatusCode; c < 200 || 299 < c {
return fmt.Errorf("unexpected http response status: %s", res.Status)
2018-06-14 00:37:48 -03:00
}
return nil
2018-06-14 00:37:48 -03:00
})
}