git-bug/commands/user.go

104 lines
2.5 KiB
Go
Raw Normal View History

package commands
import (
"errors"
"fmt"
"github.com/spf13/cobra"
"github.com/MichaelMure/git-bug/cache"
)
2020-06-28 19:26:29 +03:00
type userOptions struct {
fields string
2020-06-28 19:26:29 +03:00
}
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),
PostRunE: closeBackend(env),
2020-06-28 19:26:29 +03:00
RunE: func(cmd *cobra.Command, args []string) error {
return runUser(env, options, args)
},
}
cmd.AddCommand(newUserAdoptCommand())
cmd.AddCommand(newUserCreateCommand())
cmd.AddCommand(newUserLsCommand())
flags := cmd.Flags()
flags.SortFlags = false
flags.StringVarP(&options.fields, "field", "f", "",
2020-06-28 19:26:29 +03:00
"Select field to display. Valid values are [email,humanId,id,lastModification,lastModificationLamport,login,metadata,name]")
2020-06-28 19:26:29 +03:00
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":
2020-06-28 19:26:29 +03:00
env.out.Printf("%s\n", id.Email())
case "login":
2020-06-28 19:26:29 +03:00
env.out.Printf("%s\n", id.Login())
case "humanId":
2020-06-28 19:26:29 +03:00
env.out.Printf("%s\n", id.Id().Human())
case "id":
2020-06-28 19:26:29 +03:00
env.out.Printf("%s\n", id.Id())
case "lastModification":
2020-06-28 19:26:29 +03:00
env.out.Printf("%s\n", id.LastModification().
Time().Format("Mon Jan 2 15:04:05 2006 +0200"))
case "lastModificationLamport":
2020-06-28 19:26:29 +03:00
env.out.Printf("%d\n", id.LastModificationLamport())
case "metadata":
for key, value := range id.ImmutableMetadata() {
2020-06-28 19:26:29 +03:00
env.out.Printf("%s\n%s\n", key, value)
}
case "name":
2020-06-28 19:26:29 +03:00
env.out.Printf("%s\n", id.Name())
default:
return fmt.Errorf("\nUnsupported field: %s\n", opts.fields)
}
return nil
}
2020-06-28 19:26:29 +03:00
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 (lamport %d)\n",
id.LastModification().Time().Format("Mon Jan 2 15:04:05 2006 +0200"),
id.LastModificationLamport())
2020-06-28 19:26:29 +03:00
env.out.Println("Metadata:")
2019-02-27 00:27:30 +03:00
for key, value := range id.ImmutableMetadata() {
2020-06-28 19:26:29 +03:00
env.out.Printf(" %s --> %s\n", key, value)
2019-02-27 00:27:30 +03:00
}
2020-06-28 19:26:29 +03:00
// env.out.Printf("Protected: %v\n", id.IsProtected())
return nil
}