/
team_helper.go
71 lines (61 loc) · 1.69 KB
/
team_helper.go
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
package client
import (
"errors"
"strings"
"github.com/keybase/cli"
"github.com/keybase/client/go/protocol/keybase1"
)
func ParseOneTeamName(ctx *cli.Context) (string, error) {
if len(ctx.Args()) == 0 {
return "", errors.New("team name argument required")
}
if len(ctx.Args()) > 1 {
return "", errors.New("one team name argument required, multiple found")
}
return ctx.Args()[0], nil
}
func ParseOneTeamNameK1(ctx *cli.Context) (res keybase1.TeamName, err error) {
teamNameStr, err := ParseOneTeamName(ctx)
if err != nil {
return res, err
}
return keybase1.TeamNameFromString(teamNameStr)
}
func ParseOneTeamID(ctx *cli.Context) (res keybase1.TeamID, err error) {
if len(ctx.Args()) == 0 {
return "", errors.New("team ID argument required")
}
if len(ctx.Args()) > 1 {
return "", errors.New("one team ID argument required, multiple found")
}
return keybase1.TeamIDFromString(ctx.Args()[0])
}
func ParseUser(ctx *cli.Context) (string, error) {
username := ctx.String("user")
if len(username) == 0 {
return "", errors.New("username required via --user flag")
}
return username, nil
}
func ParseRole(ctx *cli.Context) (keybase1.TeamRole, error) {
srole := ctx.String("role")
if srole == "" {
return 0, errors.New("team role required via --role flag")
}
role, ok := keybase1.TeamRoleMap[strings.ToUpper(srole)]
if !ok {
return 0, errors.New("invalid team role, please use owner, admin, writer, or reader")
}
return role, nil
}
func ParseUserAndRole(ctx *cli.Context) (string, keybase1.TeamRole, error) {
username, err := ParseUser(ctx)
if err != nil {
return "", 0, err
}
role, err := ParseRole(ctx)
if err != nil {
return "", 0, err
}
return username, role, nil
}