Source code for

from oauth2client.service_account import ServiceAccountCredentials
from parsons.etl.table import Table
from import setup_google_application_credentials
import httplib2
import json
import os

[docs]class GoogleAdmin(object): """ A connector for Google Admin. `Args:` app_creds: str A credentials json string or a path to a json file. Not required if ``GOOGLE_APPLICATION_CREDENTIALS`` env variable set. sub: str An email address that this service account will act on behalf of (via domain-wide delegation) `Returns:` GoogleAdmin Class """ def __init__(self, app_creds=None, sub=None): setup_google_application_credentials(app_creds) self.client = ServiceAccountCredentials.from_json_keyfile_name( os.environ['GOOGLE_APPLICATION_CREDENTIALS'], [''] ).create_delegated(sub).authorize(httplib2.Http()) def _paginate_request(self, endpoint, collection, params=None): # Build query params param_arr = [] param_str = '' if params: for key, value in params.items(): param_arr.append(key + '=' + value) param_str = '?' + '&'.join(param_arr) # Make API call req_url = '' + endpoint # Return type from Google Admin is a tuple of length 2. Extract desired result from 2nd item # in tuple and convert to json res = json.loads(self.client.request(req_url + param_str, 'GET')[1].decode('utf-8')) # Paginate ret = [] if collection in res: ret = res[collection] while('nextPageToken' in res): if param_arr[-1][0:10] != 'pageToken=': param_arr.append('pageToken=' + res['nextPageToken']) else: param_arr[-1] = 'pageToken=' + res['nextPageToken'] res = json.loads(self.client.request( req_url + '?' + '&'.join(param_arr), 'GET' )[1].decode('utf-8')) ret += res[collection] return Table(ret)
[docs] def get_all_group_members(self, group_key, params=None): """ Get all members in a group. `Google Admin API Documentation <\ admin-sdk/directory/v1/guides/manage-group-members#get_all_members>`_ `Args:` group_key: str The Google group id params: dict A dictionary of fields for the GET request `Returns:` Table Class """ return self._paginate_request('groups/' + group_key + '/members', 'members', params)
[docs] def get_all_groups(self, params=None): """ Get all groups in a domain or account. `Google Admin API Documentation <https://developers.\>`_ `Args:` params: dict A dictionary of fields for the GET request. `Returns:` Table Class """ return self._paginate_request('groups', 'groups', params)