aboutsummaryrefslogtreecommitdiffstats
path: root/commands/user.go
diff options
context:
space:
mode:
Diffstat (limited to 'commands/user.go')
-rw-r--r--commands/user.go110
1 files changed, 0 insertions, 110 deletions
diff --git a/commands/user.go b/commands/user.go
deleted file mode 100644
index 0fe3be4d..00000000
--- a/commands/user.go
+++ /dev/null
@@ -1,110 +0,0 @@
-package commands
-
-import (
- "errors"
- "fmt"
- "strings"
-
- "github.com/spf13/cobra"
-
- "github.com/MichaelMure/git-bug/cache"
-)
-
-type userOptions struct {
- fields string
-}
-
-func newUserCommand() *cobra.Command {
- env := newEnv()
- options := userOptions{}
-
- cmd := &cobra.Command{
- Use: "user [USER-ID]",
- Short: "Display or change the user identity.",
- PreRunE: loadBackendEnsureUser(env),
- RunE: closeBackend(env, func(cmd *cobra.Command, args []string) error {
- return runUser(env, options, args)
- }),
- ValidArgsFunction: completeUser(env),
- }
-
- cmd.AddCommand(newUserAdoptCommand())
- cmd.AddCommand(newUserCreateCommand())
- cmd.AddCommand(newUserLsCommand())
-
- flags := cmd.Flags()
- flags.SortFlags = false
-
- fields := []string{"email", "humanId", "id", "lastModification", "lastModificationLamports", "login", "metadata", "name"}
- flags.StringVarP(&options.fields, "field", "f", "",
- "Select field to display. Valid values are ["+strings.Join(fields, ",")+"]")
- cmd.RegisterFlagCompletionFunc("field", completeFrom(fields))
-
- return cmd
-}
-
-func runUser(env *Env, opts userOptions, args []string) error {
- if len(args) > 1 {
- return errors.New("only one identity can be displayed at a time")
- }
-
- var id *cache.IdentityCache
- var err error
- if len(args) == 1 {
- id, err = env.backend.ResolveIdentityPrefix(args[0])
- } else {
- id, err = env.backend.GetUserIdentity()
- }
-
- if err != nil {
- return err
- }
-
- if opts.fields != "" {
- switch opts.fields {
- case "email":
- env.out.Printf("%s\n", id.Email())
- case "login":
- env.out.Printf("%s\n", id.Login())
- case "humanId":
- env.out.Printf("%s\n", id.Id().Human())
- case "id":
- env.out.Printf("%s\n", id.Id())
- case "lastModification":
- env.out.Printf("%s\n", id.LastModification().
- Time().Format("Mon Jan 2 15:04:05 2006 +0200"))
- case "lastModificationLamport":
- for name, t := range id.LastModificationLamports() {
- env.out.Printf("%s\n%d\n", name, t)
- }
- case "metadata":
- for key, value := range id.ImmutableMetadata() {
- env.out.Printf("%s\n%s\n", key, value)
- }
- case "name":
- env.out.Printf("%s\n", id.Name())
-
- default:
- return fmt.Errorf("\nUnsupported field: %s\n", opts.fields)
- }
-
- return nil
- }
-
- env.out.Printf("Id: %s\n", id.Id())
- env.out.Printf("Name: %s\n", id.Name())
- env.out.Printf("Email: %s\n", id.Email())
- env.out.Printf("Login: %s\n", id.Login())
- env.out.Printf("Last modification: %s\n", id.LastModification().Time().Format("Mon Jan 2 15:04:05 2006 +0200"))
- env.out.Printf("Last moditication (lamport):\n")
- for name, t := range id.LastModificationLamports() {
- env.out.Printf("\t%s: %d", name, t)
- }
- env.out.Println("Metadata:")
- for key, value := range id.ImmutableMetadata() {
- env.out.Printf(" %s --> %s\n", key, value)
- }
- // env.out.Printf("Protected: %v\n", id.IsProtected())
-
- return nil
-}