-
Notifications
You must be signed in to change notification settings - Fork 11
/
account.go
68 lines (57 loc) · 1.7 KB
/
account.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
package udnssdk
import (
"fmt"
"net/http"
)
// AccountsService provides access to account resources
type AccountsService struct {
client *Client
}
// Account represents responses from the service
type Account struct {
AccountName string `json:"accountName"`
AccountHolderUserName string `json:"accountHolderUserName"`
OwnerUserName string `json:"ownerUserName"`
NumberOfUsers int `json:"numberOfUsers"`
NumberOfGroups int `json:"numberOfGroups"`
AccountType string `json:"accountType"`
}
// AccountListDTO represents a account index response
type AccountListDTO struct {
Accounts []Account `json:"accounts"`
Resultinfo ResultInfo `json:"resultInfo"`
}
// AccountKey represents the string identifier of an Account
type AccountKey string
// URI generates the URI for an Account
func (k AccountKey) URI() string {
uri := "accounts"
if k != "" {
uri = fmt.Sprintf("accounts/%s", k)
}
return uri
}
// AccountsURI generates the URI for Accounts collection
func AccountsURI() string {
return "accounts"
}
// Select requests all Accounts of user
func (s *AccountsService) Select() ([]Account, *http.Response, error) {
var ald AccountListDTO
res, err := s.client.get(AccountsURI(), &ald)
accts := []Account{}
for _, t := range ald.Accounts {
accts = append(accts, t)
}
return accts, res, err
}
// Find requests an Account by AccountKey
func (s *AccountsService) Find(k AccountKey) (Account, *http.Response, error) {
var t Account
res, err := s.client.get(k.URI(), &t)
return t, res, err
}
// Delete requests deletion of an Account by AccountKey
func (s *AccountsService) Delete(k AccountKey) (*http.Response, error) {
return s.client.delete(k.URI(), nil)
}