package secret import ( "html/template" "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 secretListCmd = &cli.Command{ Name: "ls", Usage: "list secrets", ArgsUsage: "[repo-id|repo-full-name]", Action: secretList, Flags: append(common.GlobalFlags, &cli.BoolFlag{ Name: "global", Usage: "global secret", }, common.OrgFlag, common.RepoFlag, common.FormatFlag(tmplSecretList, true), ), } func secretList(c *cli.Context) error { format := c.String("format") + "\n" client, err := internal.NewClient(c) if err != nil { return err } global, orgID, repoID, err := parseTargetArgs(client, c) if err != nil { return err } var list []*woodpecker.Secret if global { list, err = client.GlobalSecretList() if err != nil { return err } } else if orgID != -1 { list, err = client.OrgSecretList(orgID) if err != nil { return err } } else { list, err = client.SecretList(repoID) if err != nil { return err } } tmpl, err := template.New("_").Funcs(secretFuncMap).Parse(format) if err != nil { return err } for _, registry := range list { if err := tmpl.Execute(os.Stdout, registry); err != nil { return err } } return nil } // template for secret list items var tmplSecretList = "\x1b[33m{{ .Name }} \x1b[0m" + ` Events: {{ list .Events }} {{- if .Images }} Images: {{ list .Images }} {{- else }} Images: {{- end }} ` var secretFuncMap = template.FuncMap{ "list": func(s []string) string { return strings.Join(s, ", ") }, }