summaryrefslogtreecommitdiffstats
path: root/vendor/github.com/keybase/go-keybase-chat-bot/kbchat/team.go
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/github.com/keybase/go-keybase-chat-bot/kbchat/team.go')
-rw-r--r--vendor/github.com/keybase/go-keybase-chat-bot/kbchat/team.go53
1 files changed, 14 insertions, 39 deletions
diff --git a/vendor/github.com/keybase/go-keybase-chat-bot/kbchat/team.go b/vendor/github.com/keybase/go-keybase-chat-bot/kbchat/team.go
index 89c55c4f..0f9d9524 100644
--- a/vendor/github.com/keybase/go-keybase-chat-bot/kbchat/team.go
+++ b/vendor/github.com/keybase/go-keybase-chat-bot/kbchat/team.go
@@ -4,22 +4,13 @@ import (
"encoding/json"
"fmt"
"strings"
+
+ "github.com/keybase/go-keybase-chat-bot/kbchat/types/keybase1"
)
type ListTeamMembers struct {
- Result ListTeamMembersResult `json:"result"`
- Error Error `json:"error"`
-}
-
-type ListTeamMembersResult struct {
- Members ListTeamMembersResultMembers `json:"members"`
-}
-
-type ListTeamMembersResultMembers struct {
- Owners []ListMembersOutputMembersCategory `json:"owners"`
- Admins []ListMembersOutputMembersCategory `json:"admins"`
- Writers []ListMembersOutputMembersCategory `json:"writers"`
- Readers []ListMembersOutputMembersCategory `json:"readers"`
+ Result keybase1.TeamDetails `json:"result"`
+ Error Error `json:"error"`
}
type ListMembersOutputMembersCategory struct {
@@ -28,62 +19,46 @@ type ListMembersOutputMembersCategory struct {
}
type ListUserMemberships struct {
- Result ListUserMembershipsResult `json:"result"`
- Error Error `json:"error"`
+ Result keybase1.AnnotatedTeamList `json:"result"`
+ Error Error `json:"error"`
}
-type ListUserMembershipsResult struct {
- Teams []ListUserMembershipsResultTeam `json:"teams"`
-}
-
-type ListUserMembershipsResultTeam struct {
- TeamName string `json:"fq_name"`
- IsImplicitTeam bool `json:"is_implicit_team"`
- IsOpenTeam bool `json:"is_open_team"`
- Role int `json:"role"`
- MemberCount int `json:"member_count"`
-}
-
-func (a *API) ListMembersOfTeam(teamName string) (ListTeamMembersResultMembers, error) {
- empty := ListTeamMembersResultMembers{}
-
+func (a *API) ListMembersOfTeam(teamName string) (res keybase1.TeamMembersDetails, err error) {
apiInput := fmt.Sprintf(`{"method": "list-team-memberships", "params": {"options": {"team": "%s"}}}`, teamName)
cmd := a.runOpts.Command("team", "api")
cmd.Stdin = strings.NewReader(apiInput)
bytes, err := cmd.CombinedOutput()
if err != nil {
- return empty, fmt.Errorf("failed to call keybase team api: %v", err)
+ return res, APIError{err}
}
members := ListTeamMembers{}
err = json.Unmarshal(bytes, &members)
if err != nil {
- return empty, fmt.Errorf("failed to parse output from keybase team api: %v", err)
+ return res, UnmarshalError{err}
}
if members.Error.Message != "" {
- return empty, fmt.Errorf("received error from keybase team api: %s", members.Error.Message)
+ return res, members.Error
}
return members.Result.Members, nil
}
-func (a *API) ListUserMemberships(username string) ([]ListUserMembershipsResultTeam, error) {
- empty := []ListUserMembershipsResultTeam{}
-
+func (a *API) ListUserMemberships(username string) ([]keybase1.AnnotatedMemberInfo, error) {
apiInput := fmt.Sprintf(`{"method": "list-user-memberships", "params": {"options": {"username": "%s"}}}`, username)
cmd := a.runOpts.Command("team", "api")
cmd.Stdin = strings.NewReader(apiInput)
bytes, err := cmd.CombinedOutput()
if err != nil {
- return empty, fmt.Errorf("failed to call keybase team api: %v", err)
+ return nil, APIError{err}
}
members := ListUserMemberships{}
err = json.Unmarshal(bytes, &members)
if err != nil {
- return empty, fmt.Errorf("failed to parse output from keybase team api: %v", err)
+ return nil, UnmarshalError{err}
}
if members.Error.Message != "" {
- return empty, fmt.Errorf("received error from keybase team api: %s", members.Error.Message)
+ return nil, members.Error
}
return members.Result.Teams, nil
}