-
Notifications
You must be signed in to change notification settings - Fork 31
/
Copy pathlistgroupsandmembers.py
executable file
·146 lines (118 loc) · 5.09 KB
/
listgroupsandmembers.py
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
#!/usr/bin/python
# -*- coding: utf-8 -*-
#
# listgroupsandmembers.py
# January 2019
#
# Usage:
# listgroupsandmembers.py [--noheader] [-e] [-d]
#
# Examples:
#
# 1. Return list of all groups and all their members
# ./listgroupsandmembers.py
#
# 2. Return list of all groups and all their members, including email
# address for members
# ./listgroupsandmembers.py -e
#
# Copyright © 2020, SAS Institute Inc., Cary, NC, USA. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the License);
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
# Import Python modules
from __future__ import unicode_literals
import argparse
import sys
from sharedfunctions import callrestapi
# Define exception handler so that we only output trace info from errors when in debug mode
def exception_handler(exception_type, exception, traceback, debug_hook=sys.excepthook):
if debug:
debug_hook(exception_type, exception, traceback)
else:
print (exception_type.__name__, exception)
sys.excepthook = exception_handler
parser = argparse.ArgumentParser()
parser.add_argument("--id", help="Subset based on group id containing a string",default=None )
parser.add_argument("--name", help="Subset based on name containing a string",default=None )
parser.add_argument("--noheader", action='store_true', help="Do not print the header row")
parser.add_argument("-e","--email", action='store_true', help="Show email addresses for users")
parser.add_argument("-d","--debug", action='store_true', help="Debug")
args = parser.parse_args()
noheader=args.noheader
debug=args.debug
show_email=args.email
idval=args.id
nameval=args.name
# create filter
filtercond=[]
if idval!=None: filtercond.append('contains(id,"'+idval+'")')
if nameval!=None: filtercond.append('contains(name,"'+nameval+'")')
delimiter = ','
completefilter = 'and('+delimiter.join(filtercond)+')'
# Print header row unless noheader argument was specified
if not noheader:
if show_email:
print('groupid,groupname,grouptype,groupproviderid,memberid,membername,membertype,memberproviderid,email')
else:
print('groupid,groupname,grouptype,groupproviderid,memberid,membername,membertype,memberproviderid')
endpoint='/identities/groups?limit=10000&filter='+completefilter
method='get'
if debug: print(endpoint)
#make the rest call
groupslist_result_json=callrestapi(endpoint,method)
if debug:
print(groupslist_result_json)
print('groupslist_result_json is a '+type(groupslist_result_json).__name__+' object') #groupslist_result_json is a dict object
groups = groupslist_result_json['items']
for group in groups:
groupid=group['id']
groupname=group['name']
grouptype=group['type']
groupproviderid=group['providerId']
if groupid!="": # Skip groups with empty id (this has been seen at least once at a customer site), because we cannot fetch their members.
# List the members of this group
endpoint='/identities/groups/'+groupid+'/members?limit=10000'
method='get'
members_result_json=callrestapi(endpoint,method)
if debug:
print(members_result_json)
print('members_result_json is a '+type(members_result_json).__name__+' object') #members_result_json is a dict object
members=members_result_json['items']
for member in members:
memberid=member['id']
membername=member['name']
membertype=member['type']
memberproviderid=member['providerId']
user_email_string=''
output=groupid+','+groupname+','+grouptype+','+groupproviderid+','+memberid+',"'+membername+'",'+membertype+','+memberproviderid
if show_email:
output=output+','
if membertype=='user' and show_email:
# List the members of this group
endpoint='/identities/users/'+memberid+'?limit=10000'
method='get'
user_details_json=callrestapi(endpoint,method)
if debug:
print(user_details_json)
print('user_details_json is a '+type(user_details_json).__name__+' object') #user_details_json is a dict object
if 'emailAddresses' in user_details_json:
user_emails=user_details_json['emailAddresses']
user_email_string=''
for email in user_emails:
email_address=email['value']
if user_email_string!='':
user_email_string=user_email_string+';'
user_email_string=user_email_string+email_address
output=output+user_email_string
print(output)