* Document member restrictions
* Fix gam print users allfields custom all to include primaryEmail
If you really want everything say: gam print users full
* agreedToTerms is now read-only
* Fix sync devices
* assetTag if specified is part of sync device key
* Handle missing assetTags
* Leave agreedtoterms as an undocumented option
* More assetTag processing, the field is not returned from the API if it's empty
* Fix DriveFileAttribute formatting
* memberKey has been replaced by preferredMemberKey
* Correct license name
* If notdemail.txt is present, write_csv_file will not send an email
* Initialize pageToken for each namespace
* Update group sync to do removes before adds
This gets around problem when a group contains a primary address and a sync is performed with an alias. With adds first you get a duplicate error; with removes first the primary address in the group is replaced with the alias.
* Add defaultsender to group settings
* Update requirements.txt
Adding `pathvalidate` to requrements
* Update __init__.py
Adding `pathvalidate` to make correct filename on other then ascii encodings.
* Updating with sanitize_filename
* Removing unused variable.
When page_args_in_body is true you have to add body to kwargs to ensure a place for pageToken
Allow setting a list of namespaces that override the defaults for printerid (not likely) and appid.
* Code cleanup; display role for group members
* Standardize member and membertree output
Should dates be added to membergtree output?
* Use member_id to get subgroup, avoid call to convert email to id
* Only show role on top-level members
* Use v1beta1 for info user grouptree
* Update groups.py
* Cloud Identity v1 only uses preferredMemberKey
* Document print labels
* Cleanup/bug fix info user grouptree; fix todrive for print labels
* Standardize write_csv_file call in print labels
* Use cloudidentity_beta for calls that process memberKey
* Code cleanup