bridge_token_add.go

 1package commands
 2
 3import (
 4	"github.com/pkg/errors"
 5	"github.com/spf13/cobra"
 6
 7	"github.com/MichaelMure/git-bug/bridge/core"
 8)
 9
10var (
11	bridgeToken core.Token
12)
13
14func runBridgeTokenAdd(cmd *cobra.Command, args []string) error {
15	_ = bridgeToken.Id() // TODO: a better design to avoid doing this
16
17	if err := bridgeToken.Validate(); err != nil {
18		return errors.Wrap(err, "invalid token")
19	}
20
21	return core.StoreToken(repo, &bridgeToken)
22}
23
24var bridgeTokenAddCmd = &cobra.Command{
25	Use:     "add",
26	Short:   "Create and store a new token",
27	PreRunE: loadRepo,
28	RunE:    runBridgeTokenAdd,
29	Args:    cobra.NoArgs,
30}
31
32func init() {
33	bridgeTokenCmd.AddCommand(bridgeTokenAddCmd)
34	bridgeTokenAddCmd.Flags().BoolVarP(&bridgeToken.Global, "global", "g", false, "")
35	bridgeTokenAddCmd.Flags().StringVarP(&bridgeToken.Value, "value", "v", "", "")
36	bridgeTokenAddCmd.Flags().StringVarP(&bridgeToken.Target, "target", "t", "", "")
37	bridgeTokenAddCmd.Flags().StringArrayVarP(&bridgeToken.Scopes, "scopes", "s", []string{}, "")
38	bridgeTokenAddCmd.Flags().SortFlags = false
39}