-
Notifications
You must be signed in to change notification settings - Fork 65
/
association.go
155 lines (136 loc) · 4.99 KB
/
association.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
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
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
package chef
// import "fmt"
import "errors"
type AssociationService struct {
client *Client
}
// Chef API docs: https://docs.chef.io/api_chef_server.html#association-requests
// https://github.com/chef/chef-server/blob/master/src/oc_erchef/apps/oc_chef_wm/src/oc_chef_wm_org_invites.erl Invitation implementation
// https://github.com/chef/chef-server/blob/master/src/oc_erchef/apps/oc_chef_wm/src/oc_chef_wm_org_associations.erl user org associations
// Association represents the response from creating an invitation to join an organization
// POST /organization/NAME/association_requests
type Association struct {
Uri string `json:"uri"` // the last part of the uri is the invitation id
OrganizationUser struct {
UserName string `json:"username,omitempty"`
} `json:"organization_user"`
Organization struct {
Name string `json:"name,omitempty"`
} `json:"organization"`
User struct {
Email string `json:"email,omitempty"`
FirstName string `json:"first_name,omitempty"`
} `json:"user"`
}
// RescindInvite respresents the response from deleting an invitation
// DELETE /organization/NAME/association_requests/ID
type RescindInvite struct {
Id string `json:"id,omitempty"`
Orgname string `json:"orgname,omitempty"`
Username string `json:"username,omitempty"`
}
// Invite represents an entry in the array of responses listing the outstanding invitations
// GET /organization/NAME/association_requests
type Invite struct {
Id string `json:"id,omitempty"`
UserName string `json:"username,omitempty"`
}
// Request represents the body of the request to invite a user to an organization
// POST /organization/NAME/association_requests
type Request struct {
User string `json:"user"`
}
// AddNow represents the body of the request to add a user to an organization
// POST /organization/NAME/users
type AddNow struct {
Username string `json:"username"`
}
// Invite represents an entry in the array of responses listing the users in an organization
// GET /organization/NAME/association_requests
type OrgUserListEntry struct {
User struct {
Username string `json:"username,omitempty"`
} `json:"user,omitempty"`
}
// OrgUser represents the detailed information about a user in an organization
// GET /organization/NAME/user/NAME
// DELETE /organization/NAME/user/NAME
type OrgUser struct {
Username string `json:"username,omitempty"`
Email string `json:"email,omitempty"`
DisplayName string `json:"display_name,omitempty"`
FirstName string `json:"first_name,omitempty"`
LastName string `json:"last_name,omitempty"`
PublicKey string `json:"public_key,omitempty"`
}
// ListInvites gets a list of the pending invitations for an organization.
func (e *AssociationService) ListInvites() (invitelist []Invite, err error) {
err = e.client.magicRequestDecoder("GET", "association_requests", nil, &invitelist)
return
}
// Invite creates an invitation for a user to join an organization on the chef server
func (e *AssociationService) Invite(invite Request) (data Association, err error) {
body, err := JSONReader(invite)
if err != nil {
return
}
err = e.client.magicRequestDecoder("POST", "association_requests/", body, &data)
return
}
// DeleteInvite removes a pending invitation to an organization
func (e *AssociationService) DeleteInvite(id string) (rescind RescindInvite, err error) {
err = e.client.magicRequestDecoder("DELETE", "association_requests/"+id, nil, &rescind)
return
}
// InviteID Finds an invitation id for a user
func (e *AssociationService) InviteId(user string) (id string, err error) {
var invitelist []Invite
err = e.client.magicRequestDecoder("GET", "association_requests", nil, &invitelist)
if err != nil {
return
}
// Find an invite for the user or return err
for _, in := range invitelist {
if in.UserName == user {
id = in.Id
}
}
if id == "" {
err = errors.New("User request not found")
}
return
}
// AcceptInvite Accepts an invitation
// TODO: Gets a 405, code is in knife is it part of erchef?
func (e *AssociationService) AcceptInvite(id string) (data string, err error) {
body, err := JSONReader("{ \"accept\" }")
if err != nil {
return
}
err = e.client.magicRequestDecoder("PUT", "association_requests/"+id, body, &data)
return
}
// List gets a list of the users in an organization
func (e *AssociationService) List() (data []OrgUserListEntry, err error) {
err = e.client.magicRequestDecoder("GET", "users", nil, &data)
return
}
// Add a user immediately
func (e *AssociationService) Add(addme AddNow) (err error) {
body, err := JSONReader(addme)
if err != nil {
return
}
err = e.client.magicRequestDecoder("POST", "users", body, nil)
return
}
// Get the details of a user in an organization
func (e *AssociationService) Get(name string) (data OrgUser, err error) {
err = e.client.magicRequestDecoder("GET", "users/"+name, nil, &data)
return
}
// Delete removes a user from an organization
func (e *AssociationService) Delete(name string) (data OrgUser, err error) {
err = e.client.magicRequestDecoder("DELETE", "users/"+name, nil, &data)
return
}