package secret import ( "os" "strings" "github.com/urfave/cli/v2" "github.com/woodpecker-ci/woodpecker/cli/common" "github.com/woodpecker-ci/woodpecker/cli/internal" "github.com/woodpecker-ci/woodpecker/woodpecker-go/woodpecker" ) var secretCreateCmd = &cli.Command{ Name: "add", Usage: "adds a secret", ArgsUsage: "[org/repo|org]", Action: secretCreate, Flags: append(common.GlobalFlags, &cli.BoolFlag{ Name: "global", Usage: "global secret", }, &cli.StringFlag{ Name: "organization", Usage: "organization name (e.g. octocat)", }, common.RepoFlag, &cli.StringFlag{ Name: "name", Usage: "secret name", }, &cli.StringFlag{ Name: "value", Usage: "secret value", }, &cli.StringSliceFlag{ Name: "event", Usage: "secret limited to these events", }, &cli.StringSliceFlag{ Name: "image", Usage: "secret limited to these images", }, ), } func secretCreate(c *cli.Context) error { client, err := internal.NewClient(c) if err != nil { return err } secret := &woodpecker.Secret{ Name: strings.ToLower(c.String("name")), Value: c.String("value"), Images: c.StringSlice("image"), Events: c.StringSlice("event"), } if len(secret.Events) == 0 { secret.Events = defaultSecretEvents } if strings.HasPrefix(secret.Value, "@") { path := strings.TrimPrefix(secret.Value, "@") out, err := os.ReadFile(path) if err != nil { return err } secret.Value = string(out) } global, owner, repo, err := parseTargetArgs(c) if err != nil { return err } if global { _, err = client.GlobalSecretCreate(secret) return err } if repo == "" { _, err = client.OrgSecretCreate(owner, secret) return err } _, err = client.SecretCreate(owner, repo, secret) return err } var defaultSecretEvents = []string{ woodpecker.EventPush, woodpecker.EventTag, woodpecker.EventDeploy, }