aboutsummaryrefslogtreecommitdiffstats
path: root/commands/user/user_adopt.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_adopt.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_adopt.go')
-rw-r--r--commands/user/user_adopt.go43
1 files changed, 43 insertions, 0 deletions
diff --git a/commands/user/user_adopt.go b/commands/user/user_adopt.go
new file mode 100644
index 00000000..f5944053
--- /dev/null
+++ b/commands/user/user_adopt.go
@@ -0,0 +1,43 @@
+package usercmd
+
+import (
+ "github.com/spf13/cobra"
+
+ "github.com/MichaelMure/git-bug/commands/completion"
+ "github.com/MichaelMure/git-bug/commands/execenv"
+)
+
+func newUserAdoptCommand() *cobra.Command {
+ env := execenv.NewEnv()
+
+ cmd := &cobra.Command{
+ Use: "adopt USER_ID",
+ Short: "Adopt an existing identity as your own",
+ Args: cobra.ExactArgs(1),
+ PreRunE: execenv.LoadBackend(env),
+ RunE: execenv.CloseBackend(env, func(cmd *cobra.Command, args []string) error {
+ return runUserAdopt(env, args)
+ }),
+ ValidArgsFunction: completion.User(env),
+ }
+
+ return cmd
+}
+
+func runUserAdopt(env *execenv.Env, args []string) error {
+ prefix := args[0]
+
+ i, err := env.Backend.ResolveIdentityPrefix(prefix)
+ if err != nil {
+ return err
+ }
+
+ err = env.Backend.SetUserIdentity(i)
+ if err != nil {
+ return err
+ }
+
+ env.Out.Printf("Your identity is now: %s\n", i.DisplayName())
+
+ return nil
+}