1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
|
package commands
import (
"errors"
"fmt"
"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),
PostRunE: closeBackend(env),
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", "",
"Select field to display. Valid values are [email,humanId,id,lastModification,lastModificationLamports,login,metadata,name]")
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
}
|