2019-04-06 19:32:14 +00:00
|
|
|
package repo
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"time"
|
|
|
|
|
2021-05-25 12:08:27 +00:00
|
|
|
"github.com/woodpecker-ci/woodpecker/cli/drone/internal"
|
|
|
|
"github.com/woodpecker-ci/woodpecker/drone-go/drone"
|
2019-04-06 19:32:14 +00:00
|
|
|
|
|
|
|
"github.com/urfave/cli"
|
|
|
|
)
|
|
|
|
|
|
|
|
var repoUpdateCmd = cli.Command{
|
|
|
|
Name: "update",
|
|
|
|
Usage: "update a repository",
|
|
|
|
ArgsUsage: "<repo/name>",
|
|
|
|
Action: repoUpdate,
|
|
|
|
Flags: []cli.Flag{
|
|
|
|
cli.BoolFlag{
|
|
|
|
Name: "trusted",
|
|
|
|
Usage: "repository is trusted",
|
|
|
|
},
|
|
|
|
cli.BoolFlag{
|
|
|
|
Name: "gated",
|
|
|
|
Usage: "repository is gated",
|
|
|
|
},
|
|
|
|
cli.DurationFlag{
|
|
|
|
Name: "timeout",
|
|
|
|
Usage: "repository timeout",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
Name: "visibility",
|
|
|
|
Usage: "repository visibility",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
Name: "config",
|
|
|
|
Usage: "repository configuration path (e.g. .drone.yml)",
|
|
|
|
},
|
|
|
|
cli.IntFlag{
|
|
|
|
Name: "build-counter",
|
|
|
|
Usage: "repository starting build number",
|
|
|
|
},
|
|
|
|
cli.BoolFlag{
|
|
|
|
Name: "unsafe",
|
|
|
|
Usage: "validate updating the build-counter is unsafe",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
func repoUpdate(c *cli.Context) error {
|
|
|
|
repo := c.Args().First()
|
|
|
|
owner, name, err := internal.ParseRepo(repo)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
client, err := internal.NewClient(c)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
var (
|
|
|
|
visibility = c.String("visibility")
|
|
|
|
config = c.String("config")
|
|
|
|
timeout = c.Duration("timeout")
|
|
|
|
trusted = c.Bool("trusted")
|
|
|
|
gated = c.Bool("gated")
|
|
|
|
buildCounter = c.Int("build-counter")
|
|
|
|
unsafe = c.Bool("unsafe")
|
|
|
|
)
|
|
|
|
|
|
|
|
patch := new(drone.RepoPatch)
|
|
|
|
if c.IsSet("trusted") {
|
|
|
|
patch.IsTrusted = &trusted
|
|
|
|
}
|
|
|
|
if c.IsSet("gated") {
|
|
|
|
patch.IsGated = &gated
|
|
|
|
}
|
|
|
|
if c.IsSet("timeout") {
|
|
|
|
v := int64(timeout / time.Minute)
|
|
|
|
patch.Timeout = &v
|
|
|
|
}
|
|
|
|
if c.IsSet("config") {
|
|
|
|
patch.Config = &config
|
|
|
|
}
|
|
|
|
if c.IsSet("visibility") {
|
|
|
|
switch visibility {
|
|
|
|
case "public", "private", "internal":
|
|
|
|
patch.Visibility = &visibility
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if c.IsSet("build-counter") && !unsafe {
|
|
|
|
fmt.Printf("Setting the build counter is an unsafe operation that could put your repository in an inconsistent state. Please use --unsafe to proceed")
|
|
|
|
}
|
|
|
|
if c.IsSet("build-counter") && unsafe {
|
|
|
|
patch.BuildCounter = &buildCounter
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, err := client.RepoPatch(owner, name, patch); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
fmt.Printf("Successfully updated repository %s/%s\n", owner, name)
|
|
|
|
return nil
|
|
|
|
}
|