-
Notifications
You must be signed in to change notification settings - Fork 0
/
Group.go
125 lines (111 loc) · 5.29 KB
/
Group.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
package msgraph
import (
"encoding/json"
"fmt"
"time"
)
// Group represents one group of ms graph
//
// See: https://developer.microsoft.com/en-us/graph/docs/api-reference/v1.0/api/group_get
type Group struct {
ID string
Description string
DisplayName string
CreatedDateTime time.Time
GroupTypes []string
Mail string
MailEnabled bool
MailNickname string
OnPremisesLastSyncDateTime time.Time // defaults to 0001-01-01 00:00:00 +0000 UTC if there's none
OnPremisesSecurityIdentifier string
OnPremisesSyncEnabled bool
ProxyAddresses []string
SecurityEnabled bool
Visibility string
graphClient *GraphClient // the graphClient that called the group
}
func (g Group) String() string {
return fmt.Sprintf("Group(ID: \"%v\", Description: \"%v\" DisplayName: \"%v\", CreatedDateTime: \"%v\", GroupTypes: \"%v\", Mail: \"%v\", MailEnabled: \"%v\", MailNickname: \"%v\", OnPremisesLastSyncDateTime: \"%v\", OnPremisesSecurityIdentifier: \"%v\", OnPremisesSyncEnabled: \"%v\", ProxyAddresses: \"%v\", SecurityEnabled \"%v\", Visibility: \"%v\", DirectAPIConnection: %v)",
g.ID, g.Description, g.DisplayName, g.CreatedDateTime, g.GroupTypes, g.Mail, g.MailEnabled, g.MailNickname, g.OnPremisesLastSyncDateTime, g.OnPremisesSecurityIdentifier, g.OnPremisesSyncEnabled, g.ProxyAddresses, g.SecurityEnabled, g.Visibility, g.graphClient != nil)
}
// setGraphClient sets the graphClient instance in this instance and all child-instances (if any)
func (g *Group) setGraphClient(gC *GraphClient) {
g.graphClient = gC
}
// ListMembers - Get a list of the group's direct members. A group can have users,
// contacts, and other groups as members. This operation is not transitive. This
// method will currently ONLY return User-instances of members
// Supports optional OData query parameters https://docs.microsoft.com/en-us/graph/query-parameters
//
// See https://developer.microsoft.com/en-us/graph/docs/api-reference/v1.0/api/group_list_members
func (g Group) ListMembers(opts ...ListQueryOption) (Users, error) {
if g.graphClient == nil {
return nil, ErrNotGraphClientSourced
}
resource := fmt.Sprintf("/groups/%v/members", g.ID)
var marsh struct {
Users Users `json:"value"`
}
marsh.Users.setGraphClient(g.graphClient)
return marsh.Users, g.graphClient.makeGETAPICall(resource, compileListQueryOptions(opts), &marsh)
}
// Get a list of the group's members. A group can have users, devices, organizational contacts, and other groups as members.
// This operation is transitive and returns a flat list of all nested members.
// Supports optional OData query parameters https://docs.microsoft.com/en-us/graph/query-parameters
//
// See https://docs.microsoft.com/en-us/graph/api/group-list-transitivemembers?view=graph-rest-1.0&tabs=http
func (g Group) ListTransitiveMembers(opts ...ListQueryOption) (Users, error) {
if g.graphClient == nil {
return nil, ErrNotGraphClientSourced
}
resource := fmt.Sprintf("/groups/%v/transitiveMembers", g.ID)
var marsh struct {
Users Users `json:"value"`
}
marsh.Users.setGraphClient(g.graphClient)
return marsh.Users, g.graphClient.makeGETAPICall(resource, compileListQueryOptions(opts), &marsh)
}
// UnmarshalJSON implements the json unmarshal to be used by the json-library
func (g *Group) UnmarshalJSON(data []byte) error {
tmp := struct {
ID string `json:"id"`
Description string `json:"description"`
DisplayName string `json:"displayName"`
CreatedDateTime string `json:"createdDateTime"`
GroupTypes []string `json:"groupTypes"`
Mail string `json:"mail"`
MailEnabled bool `json:"mailEnabled"`
MailNickname string `json:"mailNickname"`
OnPremisesLastSyncDateTime string `json:"onPremisesLastSyncDateTime"`
OnPremisesSecurityIdentifier string `json:"onPremisesSecurityIdentifier"`
OnPremisesSyncEnabled bool `json:"onPremisesSyncEnabled"`
ProxyAddresses []string `json:"proxyAddresses"`
SecurityEnabled bool `json:"securityEnabled"`
Visibility string `json:"visibility"`
}{}
err := json.Unmarshal(data, &tmp)
if err != nil {
return err
}
g.ID = tmp.ID
g.Description = tmp.Description
g.DisplayName = tmp.DisplayName
g.CreatedDateTime, err = time.Parse(time.RFC3339, tmp.CreatedDateTime)
if err != nil && tmp.CreatedDateTime != "" {
return fmt.Errorf("cannot parse CreatedDateTime %v with RFC3339: %v", tmp.CreatedDateTime, err)
}
g.GroupTypes = tmp.GroupTypes
g.Mail = tmp.Mail
g.MailEnabled = tmp.MailEnabled
g.MailNickname = tmp.MailNickname
g.OnPremisesLastSyncDateTime, err = time.Parse(time.RFC3339, tmp.OnPremisesLastSyncDateTime)
if err != nil && tmp.OnPremisesLastSyncDateTime != "" {
return fmt.Errorf("cannot parse OnPremisesLastSyncDateTime %v with RFC3339: %v", tmp.OnPremisesLastSyncDateTime, err)
}
g.OnPremisesSecurityIdentifier = tmp.OnPremisesSecurityIdentifier
g.OnPremisesSyncEnabled = tmp.OnPremisesSyncEnabled
g.ProxyAddresses = tmp.ProxyAddresses
g.SecurityEnabled = tmp.SecurityEnabled
g.Visibility = tmp.Visibility
return nil
}