Integrated org secret commands
This commit is contained in:
parent
86e4e53e77
commit
225d1c8288
7 changed files with 230 additions and 0 deletions
|
@ -42,6 +42,7 @@ func main() {
|
||||||
signCmd,
|
signCmd,
|
||||||
repoCmd,
|
repoCmd,
|
||||||
userCmd,
|
userCmd,
|
||||||
|
orgCmd,
|
||||||
}
|
}
|
||||||
|
|
||||||
app.Run(os.Args)
|
app.Run(os.Args)
|
||||||
|
|
11
drone/org.go
Normal file
11
drone/org.go
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
import "github.com/codegangsta/cli"
|
||||||
|
|
||||||
|
var orgCmd = cli.Command{
|
||||||
|
Name: "org",
|
||||||
|
Usage: "manage organizations",
|
||||||
|
Subcommands: []cli.Command{
|
||||||
|
orgSecretCmd,
|
||||||
|
},
|
||||||
|
}
|
13
drone/org_secret.go
Normal file
13
drone/org_secret.go
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
import "github.com/codegangsta/cli"
|
||||||
|
|
||||||
|
var orgSecretCmd = cli.Command{
|
||||||
|
Name: "secret",
|
||||||
|
Usage: "manage secrets",
|
||||||
|
Subcommands: []cli.Command{
|
||||||
|
orgSecretAddCmd,
|
||||||
|
orgSecretRemoveCmd,
|
||||||
|
orgSecretListCmd,
|
||||||
|
},
|
||||||
|
}
|
83
drone/org_secret_add.go
Normal file
83
drone/org_secret_add.go
Normal file
|
@ -0,0 +1,83 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
|
"log"
|
||||||
|
"strings"
|
||||||
|
|
||||||
|
"github.com/codegangsta/cli"
|
||||||
|
"github.com/drone/drone/model"
|
||||||
|
)
|
||||||
|
|
||||||
|
var orgSecretAddCmd = cli.Command{
|
||||||
|
Name: "add",
|
||||||
|
Usage: "adds a secret",
|
||||||
|
ArgsUsage: "[org] [key] [value]",
|
||||||
|
Action: func(c *cli.Context) {
|
||||||
|
if err := orgSecretAdd(c); err != nil {
|
||||||
|
log.Fatalln(err)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
Flags: []cli.Flag{
|
||||||
|
cli.StringSliceFlag{
|
||||||
|
Name: "event",
|
||||||
|
Usage: "inject the secret for these event types",
|
||||||
|
Value: &cli.StringSlice{
|
||||||
|
model.EventPush,
|
||||||
|
model.EventTag,
|
||||||
|
model.EventDeploy,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
cli.StringSliceFlag{
|
||||||
|
Name: "image",
|
||||||
|
Usage: "inject the secret for these image types",
|
||||||
|
Value: &cli.StringSlice{},
|
||||||
|
},
|
||||||
|
cli.StringFlag{
|
||||||
|
Name: "input",
|
||||||
|
Usage: "input secret value from a file",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
func orgSecretAdd(c *cli.Context) error {
|
||||||
|
if len(c.Args().Tail()) != 3 {
|
||||||
|
cli.ShowSubcommandHelp(c)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
team := c.Args().First()
|
||||||
|
name := c.Args().Get(1)
|
||||||
|
value := c.Args().Get(2)
|
||||||
|
|
||||||
|
secret := &model.Secret{}
|
||||||
|
secret.Name = name
|
||||||
|
secret.Value = value
|
||||||
|
secret.Images = c.StringSlice("image")
|
||||||
|
secret.Events = c.StringSlice("event")
|
||||||
|
|
||||||
|
if len(secret.Images) == 0 {
|
||||||
|
return fmt.Errorf("Please specify the --image parameter")
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO(bradrydzewski) below we use an @ sybmol to denote that the secret
|
||||||
|
// value should be loaded from a file (inspired by curl). I'd prefer to use
|
||||||
|
// a --input flag to explicitly specify a filepath instead.
|
||||||
|
|
||||||
|
if strings.HasPrefix(secret.Value, "@") {
|
||||||
|
path := secret.Value[1:]
|
||||||
|
out, ferr := ioutil.ReadFile(path)
|
||||||
|
if ferr != nil {
|
||||||
|
return ferr
|
||||||
|
}
|
||||||
|
secret.Value = string(out)
|
||||||
|
}
|
||||||
|
|
||||||
|
client, err := newClient(c)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return client.TeamSecretPost(team, secret)
|
||||||
|
}
|
1
drone/org_secret_info.go
Normal file
1
drone/org_secret_info.go
Normal file
|
@ -0,0 +1 @@
|
||||||
|
package main
|
87
drone/org_secret_list.go
Normal file
87
drone/org_secret_list.go
Normal file
|
@ -0,0 +1,87 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"log"
|
||||||
|
"os"
|
||||||
|
"strings"
|
||||||
|
"text/template"
|
||||||
|
|
||||||
|
"github.com/codegangsta/cli"
|
||||||
|
)
|
||||||
|
|
||||||
|
var orgSecretListCmd = cli.Command{
|
||||||
|
Name: "ls",
|
||||||
|
Usage: "list all secrets",
|
||||||
|
Action: func(c *cli.Context) {
|
||||||
|
if err := orgSecretList(c); err != nil {
|
||||||
|
log.Fatalln(err)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
Flags: []cli.Flag{
|
||||||
|
cli.StringFlag{
|
||||||
|
Name: "format",
|
||||||
|
Usage: "format output",
|
||||||
|
Value: tmplOrgSecretList,
|
||||||
|
},
|
||||||
|
cli.StringFlag{
|
||||||
|
Name: "image",
|
||||||
|
Usage: "filter by image",
|
||||||
|
},
|
||||||
|
cli.StringFlag{
|
||||||
|
Name: "event",
|
||||||
|
Usage: "filter by event",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
func orgSecretList(c *cli.Context) error {
|
||||||
|
if len(c.Args().Tail()) != 1 {
|
||||||
|
cli.ShowSubcommandHelp(c)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
team := c.Args().First()
|
||||||
|
|
||||||
|
client, err := newClient(c)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
secrets, err := client.TeamSecretList(team)
|
||||||
|
|
||||||
|
if err != nil || len(secrets) == 0 {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
tmpl, err := template.New("_").Funcs(orgSecretFuncMap).Parse(c.String("format") + "\n")
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, secret := range secrets {
|
||||||
|
if c.String("image") != "" && !stringInSlice(c.String("image"), secret.Images) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
if c.String("event") != "" && !stringInSlice(c.String("event"), secret.Events) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
tmpl.Execute(os.Stdout, secret)
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// template for secret list items
|
||||||
|
var tmplOrgSecretList = "\x1b[33m{{ .Name }} \x1b[0m" + `
|
||||||
|
Images: {{ list .Images }}
|
||||||
|
Events: {{ list .Events }}
|
||||||
|
`
|
||||||
|
|
||||||
|
var orgSecretFuncMap = template.FuncMap{
|
||||||
|
"list": func(s []string) string {
|
||||||
|
return strings.Join(s, ", ")
|
||||||
|
},
|
||||||
|
}
|
34
drone/org_secret_rm.go
Normal file
34
drone/org_secret_rm.go
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"log"
|
||||||
|
|
||||||
|
"github.com/codegangsta/cli"
|
||||||
|
)
|
||||||
|
|
||||||
|
var orgSecretRemoveCmd = cli.Command{
|
||||||
|
Name: "rm",
|
||||||
|
Usage: "remove a secret",
|
||||||
|
Action: func(c *cli.Context) {
|
||||||
|
if err := orgSecretRemove(c); err != nil {
|
||||||
|
log.Fatalln(err)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
func orgSecretRemove(c *cli.Context) error {
|
||||||
|
if len(c.Args().Tail()) != 2 {
|
||||||
|
cli.ShowSubcommandHelp(c)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
team := c.Args().First()
|
||||||
|
secret := c.Args().Get(1)
|
||||||
|
|
||||||
|
client, err := newClient(c)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return client.TeamSecretDel(team, secret)
|
||||||
|
}
|
Loading…
Reference in a new issue