From acc9a6f3a6df2961c3ae44352216d915cb9b5315 Mon Sep 17 00:00:00 2001 From: Michael Muré Date: Sat, 10 Sep 2022 11:09:19 +0200 Subject: commands: reorg into different packages --- commands/user/user_new.go | 98 +++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 98 insertions(+) create mode 100644 commands/user/user_new.go (limited to 'commands/user/user_new.go') diff --git a/commands/user/user_new.go b/commands/user/user_new.go new file mode 100644 index 00000000..d7224512 --- /dev/null +++ b/commands/user/user_new.go @@ -0,0 +1,98 @@ +package usercmd + +import ( + "github.com/spf13/cobra" + + "github.com/MichaelMure/git-bug/commands/execenv" + "github.com/MichaelMure/git-bug/commands/input" +) + +type userNewOptions struct { + name string + email string + avatarURL string + nonInteractive bool +} + +func newUserNewCommand() *cobra.Command { + env := execenv.NewEnv() + + options := userNewOptions{} + cmd := &cobra.Command{ + Use: "new", + Short: "Create a new identity", + PreRunE: execenv.LoadBackend(env), + RunE: execenv.CloseBackend(env, func(cmd *cobra.Command, args []string) error { + return runUserNew(env, options) + }), + } + + flags := cmd.Flags() + flags.StringVarP(&options.name, "name", "n", "", "Name to identify the user") + flags.StringVarP(&options.email, "email", "e", "", "Email of the user") + flags.StringVarP(&options.avatarURL, "avatar", "a", "", "Avatar URL") + flags.BoolVar(&options.nonInteractive, "non-interactive", false, "Do not ask for user input") + + return cmd +} + +func runUserNew(env *execenv.Env, opts userNewOptions) error { + + if !opts.nonInteractive && opts.name == "" { + preName, err := env.Backend.GetUserName() + if err != nil { + return err + } + opts.name, err = input.PromptDefault("Name", "name", preName, input.Required) + if err != nil { + return err + } + } + + if !opts.nonInteractive && opts.email == "" { + preEmail, err := env.Backend.GetUserEmail() + if err != nil { + return err + } + + opts.email, err = input.PromptDefault("Email", "email", preEmail, input.Required) + if err != nil { + return err + } + } + + if !opts.nonInteractive && opts.avatarURL == "" { + var err error + opts.avatarURL, err = input.Prompt("Avatar URL", "avatar") + if err != nil { + return err + } + } + + id, err := env.Backend.NewIdentityRaw(opts.name, opts.email, "", opts.avatarURL, nil, nil) + if err != nil { + return err + } + + err = id.CommitAsNeeded() + if err != nil { + return err + } + + set, err := env.Backend.IsUserIdentitySet() + if err != nil { + return err + } + + if !set { + err = env.Backend.SetUserIdentity(id) + if err != nil { + return err + } + } + + env.Err.Println() + env.Out.Println(id.Id()) + + return nil +} -- cgit