aboutsummaryrefslogtreecommitdiffstats
path: root/commands/user/user_new.go
diff options
context:
space:
mode:
authorMichael Muré <batolettre@gmail.com>2022-11-22 14:53:15 +0100
committerGitHub <noreply@github.com>2022-11-22 14:53:15 +0100
commit70bd7377b6362127794f3a6198dd2c63863025fc (patch)
treee159372673104ade1f15ddc1a84aa9da93e93552 /commands/user/user_new.go
parenta3fa445a9c76631c4cd16f93e1c1c68a954adef7 (diff)
parentacc9a6f3a6df2961c3ae44352216d915cb9b5315 (diff)
downloadgit-bug-70bd7377b6362127794f3a6198dd2c63863025fc.tar.gz
Merge pull request #870 from MichaelMure/cli-reorg
commands: reorg into different packages
Diffstat (limited to 'commands/user/user_new.go')
-rw-r--r--commands/user/user_new.go98
1 files changed, 98 insertions, 0 deletions
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
+}