variable create: read values from yaml file/stdin

This commit is contained in:
Simone Gotti 2019-07-05 18:34:40 +02:00
parent ee5c829653
commit c7aca42f1f
3 changed files with 98 additions and 16 deletions

View File

@ -20,7 +20,14 @@ import (
var cmdProjectGroupSecretCreate = &cobra.Command{ var cmdProjectGroupSecretCreate = &cobra.Command{
Use: "create", Use: "create",
Short: "create a project group secret", Short: "create a project local secret",
Long: `create a project local secret
The secret data should be provided by a yaml document. Examples:
data01: secretvalue01
data02: secretvalue02
`,
Run: func(cmd *cobra.Command, args []string) { Run: func(cmd *cobra.Command, args []string) {
if err := secretCreate(cmd, "projectgroup", args); err != nil { if err := secretCreate(cmd, "projectgroup", args); err != nil {
log.Fatalf("err: %v", err) log.Fatalf("err: %v", err)
@ -33,7 +40,7 @@ func init() {
flags.StringVar(&secretCreateOpts.parentRef, "projectgroup", "", "project group id or full path") flags.StringVar(&secretCreateOpts.parentRef, "projectgroup", "", "project group id or full path")
flags.StringVarP(&secretCreateOpts.name, "name", "n", "", "secret name") flags.StringVarP(&secretCreateOpts.name, "name", "n", "", "secret name")
flags.StringVar(&secretCreateOpts.data, "data", "", "json map of secret data") flags.StringVarP(&secretCreateOpts.file, "file", "f", "", `yaml file containing the secret data (use "-" to read from stdin`)
if err := cmdProjectGroupSecretCreate.MarkFlagRequired("projectgroup"); err != nil { if err := cmdProjectGroupSecretCreate.MarkFlagRequired("projectgroup"); err != nil {
log.Fatal(err) log.Fatal(err)
@ -41,7 +48,7 @@ func init() {
if err := cmdProjectGroupSecretCreate.MarkFlagRequired("name"); err != nil { if err := cmdProjectGroupSecretCreate.MarkFlagRequired("name"); err != nil {
log.Fatal(err) log.Fatal(err)
} }
if err := cmdProjectGroupSecretCreate.MarkFlagRequired("data"); err != nil { if err := cmdProjectGroupSecretCreate.MarkFlagRequired("file"); err != nil {
log.Fatal(err) log.Fatal(err)
} }

View File

@ -20,7 +20,29 @@ import (
var cmdProjectGroupVariableCreate = &cobra.Command{ var cmdProjectGroupVariableCreate = &cobra.Command{
Use: "create", Use: "create",
Short: "create a project variable", Short: "create a project group variable",
Long: `create a project group variable
The variable values should be provided by a yaml document. Examples:
- secret_name: secret01
secret_var: var01
when:
branch: master
tag:
- v1.x
- v2.x
- secret_name: secret02
secret_var: data02
when:
ref:
include:
- '#/refs/pull/.*#'
- '#/refs/heads/devel.*#'
exclude: /refs/heads/develop
The above yaml document defines a variable that can have two different values depending on the first matching condition.
`,
Run: func(cmd *cobra.Command, args []string) { Run: func(cmd *cobra.Command, args []string) {
if err := variableCreate(cmd, "projectgroup", args); err != nil { if err := variableCreate(cmd, "projectgroup", args); err != nil {
log.Fatalf("err: %v", err) log.Fatalf("err: %v", err)
@ -33,7 +55,7 @@ func init() {
flags.StringVar(&variableCreateOpts.parentRef, "projectgroup", "", "project group id or full path") flags.StringVar(&variableCreateOpts.parentRef, "projectgroup", "", "project group id or full path")
flags.StringVarP(&variableCreateOpts.name, "name", "n", "", "variable name") flags.StringVarP(&variableCreateOpts.name, "name", "n", "", "variable name")
flags.StringVar(&variableCreateOpts.values, "values", "", "json list of values and conditions") flags.StringVarP(&variableCreateOpts.file, "file", "f", "", `yaml file containing the variable definition (use "-" to read from stdin`)
if err := cmdProjectGroupVariableCreate.MarkFlagRequired("projectgroup"); err != nil { if err := cmdProjectGroupVariableCreate.MarkFlagRequired("projectgroup"); err != nil {
log.Fatal(err) log.Fatal(err)
@ -41,7 +63,7 @@ func init() {
if err := cmdProjectGroupVariableCreate.MarkFlagRequired("name"); err != nil { if err := cmdProjectGroupVariableCreate.MarkFlagRequired("name"); err != nil {
log.Fatal(err) log.Fatal(err)
} }
if err := cmdProjectGroupVariableCreate.MarkFlagRequired("values"); err != nil { if err := cmdProjectGroupVariableCreate.MarkFlagRequired("file"); err != nil {
log.Fatal(err) log.Fatal(err)
} }

View File

@ -16,18 +16,41 @@ package cmd
import ( import (
"context" "context"
"encoding/json" "io/ioutil"
"os"
"agola.io/agola/internal/config"
"agola.io/agola/internal/services/gateway/api" "agola.io/agola/internal/services/gateway/api"
"agola.io/agola/internal/services/types" "agola.io/agola/internal/services/types"
"github.com/ghodss/yaml"
"github.com/spf13/cobra" "github.com/spf13/cobra"
errors "golang.org/x/xerrors" errors "golang.org/x/xerrors"
) )
var cmdProjectVariableCreate = &cobra.Command{ var cmdProjectVariableCreate = &cobra.Command{
Use: "create", Use: "create",
Short: "create a project variable", Short: `create a project variable
The variable values should be provided by a yaml document. Examples:
- secret_name: secret01
secret_var: var01
when:
branch: master
tag:
- v1.x
- v2.x
- secret_name: secret02
secret_var: data02
when:
ref:
include:
- '#/refs/pull/.*#'
- '#/refs/heads/devel.*#'
exclude: /refs/heads/develop
The above yaml document defines a variable that can have two different values depending on the first matching condition.
`,
Run: func(cmd *cobra.Command, args []string) { Run: func(cmd *cobra.Command, args []string) {
if err := variableCreate(cmd, "project", args); err != nil { if err := variableCreate(cmd, "project", args); err != nil {
log.Fatalf("err: %v", err) log.Fatalf("err: %v", err)
@ -38,7 +61,7 @@ var cmdProjectVariableCreate = &cobra.Command{
type variableCreateOptions struct { type variableCreateOptions struct {
parentRef string parentRef string
name string name string
values string file string
} }
var variableCreateOpts variableCreateOptions var variableCreateOpts variableCreateOptions
@ -48,7 +71,7 @@ func init() {
flags.StringVar(&variableCreateOpts.parentRef, "project", "", "project id or full path") flags.StringVar(&variableCreateOpts.parentRef, "project", "", "project id or full path")
flags.StringVarP(&variableCreateOpts.name, "name", "n", "", "variable name") flags.StringVarP(&variableCreateOpts.name, "name", "n", "", "variable name")
flags.StringVar(&variableCreateOpts.values, "values", "", "json list of values and conditions") flags.StringVarP(&variableCreateOpts.file, "file", "f", "", `yaml file containing the variable definition (use "-" to read from stdin`)
if err := cmdProjectVariableCreate.MarkFlagRequired("project"); err != nil { if err := cmdProjectVariableCreate.MarkFlagRequired("project"); err != nil {
log.Fatal(err) log.Fatal(err)
@ -56,23 +79,53 @@ func init() {
if err := cmdProjectVariableCreate.MarkFlagRequired("name"); err != nil { if err := cmdProjectVariableCreate.MarkFlagRequired("name"); err != nil {
log.Fatal(err) log.Fatal(err)
} }
if err := cmdProjectVariableCreate.MarkFlagRequired("values"); err != nil { if err := cmdProjectVariableCreate.MarkFlagRequired("file"); err != nil {
log.Fatal(err) log.Fatal(err)
} }
cmdProjectVariable.AddCommand(cmdProjectVariableCreate) cmdProjectVariable.AddCommand(cmdProjectVariableCreate)
} }
type VariableValue struct {
SecretName string `json:"secret_name,omitempty"`
SecretVar string `json:"secret_var,omitempty"`
When *config.When `json:"when,omitempty"`
}
func variableCreate(cmd *cobra.Command, ownertype string, args []string) error { func variableCreate(cmd *cobra.Command, ownertype string, args []string) error {
gwclient := api.NewClient(gatewayURL, token) gwclient := api.NewClient(gatewayURL, token)
var values []types.VariableValue // "github.com/ghodss/yaml" doesn't provide a streaming decoder
if err := json.Unmarshal([]byte(variableCreateOpts.values), &values); err != nil { var data []byte
log.Fatalf("failed to unmarshall values: %v", err) var err error
if variableCreateOpts.file == "-" {
data, err = ioutil.ReadAll(os.Stdin)
if err != nil {
return err
}
} else {
data, err = ioutil.ReadFile(variableCreateOpts.file)
if err != nil {
return err
}
}
var values []VariableValue
if err := yaml.Unmarshal(data, &values); err != nil {
log.Fatalf("failed to unmarshal values: %v", err)
}
rvalues := []types.VariableValue{}
for _, value := range values {
rvalues = append(rvalues, types.VariableValue{
SecretName: value.SecretName,
SecretVar: value.SecretVar,
When: (*types.When)(value.When),
})
} }
req := &api.CreateVariableRequest{ req := &api.CreateVariableRequest{
Name: variableCreateOpts.name, Name: variableCreateOpts.name,
Values: values, Values: rvalues,
} }
switch ownertype { switch ownertype {