2022-05-03 09:45:54 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2023-02-08 09:14:25 +00:00
|
|
|
"errors"
|
2022-05-03 09:45:54 +00:00
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
|
|
|
|
"github.com/joho/godotenv"
|
2022-05-29 10:37:09 +00:00
|
|
|
"github.com/sirupsen/logrus"
|
2022-05-29 11:56:55 +00:00
|
|
|
"github.com/thegeeklab/drone-plugin-lib/v2/urfave"
|
2022-05-03 09:45:54 +00:00
|
|
|
"github.com/thegeeklab/drone-s3-sync/plugin"
|
|
|
|
"github.com/urfave/cli/v2"
|
|
|
|
)
|
|
|
|
|
2023-02-08 09:14:25 +00:00
|
|
|
//nolint:gochecknoglobals
|
2022-05-03 09:45:54 +00:00
|
|
|
var (
|
|
|
|
BuildVersion = "devel"
|
|
|
|
BuildDate = "00000000"
|
|
|
|
)
|
|
|
|
|
2023-02-08 09:14:25 +00:00
|
|
|
var ErrTypeAssertionFailed = errors.New("type assertion failed")
|
|
|
|
|
2022-05-03 09:45:54 +00:00
|
|
|
func main() {
|
|
|
|
settings := &plugin.Settings{}
|
|
|
|
|
|
|
|
if _, err := os.Stat("/run/drone/env"); err == nil {
|
|
|
|
_ = godotenv.Overload("/run/drone/env")
|
|
|
|
}
|
|
|
|
|
|
|
|
cli.VersionPrinter = func(c *cli.Context) {
|
|
|
|
fmt.Printf("%s version=%s date=%s\n", c.App.Name, c.App.Version, BuildDate)
|
|
|
|
}
|
|
|
|
|
|
|
|
app := &cli.App{
|
|
|
|
Name: "drone-s3-sync",
|
|
|
|
Usage: "synchronize a directory with an S3 bucket",
|
|
|
|
Version: BuildVersion,
|
2022-05-29 11:56:55 +00:00
|
|
|
Flags: append(settingsFlags(settings, urfave.FlagsPluginCategory), urfave.Flags()...),
|
2022-05-03 09:45:54 +00:00
|
|
|
Action: run(settings),
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := app.Run(os.Args); err != nil {
|
2022-05-29 10:37:09 +00:00
|
|
|
logrus.Fatal(err)
|
2022-05-03 09:45:54 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func run(settings *plugin.Settings) cli.ActionFunc {
|
|
|
|
return func(ctx *cli.Context) error {
|
|
|
|
urfave.LoggingFromContext(ctx)
|
|
|
|
|
2023-02-08 09:14:25 +00:00
|
|
|
acl, ok := ctx.Generic("acl").(*StringMapFlag)
|
|
|
|
if !ok {
|
|
|
|
return fmt.Errorf("%w: failed to read acl input", ErrTypeAssertionFailed)
|
|
|
|
}
|
|
|
|
|
|
|
|
cacheControl, ok := ctx.Generic("cache-control").(*StringMapFlag)
|
|
|
|
if !ok {
|
|
|
|
return fmt.Errorf("%w: failed to read cache-control input", ErrTypeAssertionFailed)
|
|
|
|
}
|
|
|
|
|
|
|
|
contentType, ok := ctx.Generic("content-type").(*StringMapFlag)
|
|
|
|
if !ok {
|
|
|
|
return fmt.Errorf("%w: failed to read content-type input", ErrTypeAssertionFailed)
|
|
|
|
}
|
|
|
|
|
|
|
|
contentEncoding, ok := ctx.Generic("content-encoding").(*StringMapFlag)
|
|
|
|
if !ok {
|
|
|
|
return fmt.Errorf("%w: failed to read content-encoding input", ErrTypeAssertionFailed)
|
|
|
|
}
|
|
|
|
|
|
|
|
metadata, ok := ctx.Generic("metadata").(*DeepStringMapFlag)
|
|
|
|
if !ok {
|
|
|
|
return fmt.Errorf("%w: failed to read metadata input", ErrTypeAssertionFailed)
|
|
|
|
}
|
|
|
|
|
|
|
|
redirects, ok := ctx.Generic("redirects").(*MapFlag)
|
|
|
|
if !ok {
|
|
|
|
return fmt.Errorf("%w: failed to read redirects input", ErrTypeAssertionFailed)
|
|
|
|
}
|
|
|
|
|
|
|
|
settings.ACL = acl.Get()
|
|
|
|
settings.CacheControl = cacheControl.Get()
|
|
|
|
settings.ContentType = contentType.Get()
|
|
|
|
settings.ContentEncoding = contentEncoding.Get()
|
|
|
|
settings.Metadata = metadata.Get()
|
|
|
|
settings.Redirects = redirects.Get()
|
2022-05-03 09:45:54 +00:00
|
|
|
|
|
|
|
plugin := plugin.New(
|
|
|
|
*settings,
|
|
|
|
urfave.PipelineFromContext(ctx),
|
|
|
|
urfave.NetworkFromContext(ctx),
|
|
|
|
)
|
|
|
|
|
|
|
|
if err := plugin.Validate(); err != nil {
|
2022-05-29 10:37:09 +00:00
|
|
|
return fmt.Errorf("validation failed: %w", err)
|
2022-05-03 09:45:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if err := plugin.Execute(); err != nil {
|
2022-05-29 10:37:09 +00:00
|
|
|
return fmt.Errorf("execution failed: %w", err)
|
2022-05-03 09:45:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|