gam7 7.10.7__tar.gz → 7.10.9__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of gam7 might be problematic. Click here for more details.
- {gam7-7.10.7 → gam7-7.10.9}/.github/workflows/pushwiki.yml +2 -0
- {gam7-7.10.7 → gam7-7.10.9}/PKG-INFO +1 -1
- {gam7-7.10.7 → gam7-7.10.9}/src/GamCommands.txt +4 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/GamUpdate.txt +11 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/__init__.py +74 -19
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gamlib/glapi.py +41 -17
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gamlib/glmsgs.py +3 -3
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Authorization.md +10 -15
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Cloud-Identity-Groups.md +2 -1
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Cloud-Identity-Policies.md +16 -2
- {gam7-7.10.7 → gam7-7.10.9}/wiki/GamUpdates.md +21 -1
- {gam7-7.10.7 → gam7-7.10.9}/wiki/How-to-Upgrade-Legacy-GAM-to-GAM7.md +2 -2
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Licenses.md +1 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Shared-Drives.md +6 -2
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Shared-Drives.md +4 -1
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Version-and-Help.md +6 -6
- {gam7-7.10.7 → gam7-7.10.9}/.github/ISSUE_TEMPLATE/aa-question.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/.github/ISSUE_TEMPLATE/za-bug-report.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/.github/ISSUE_TEMPLATE/zz-feature-request.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/.github/ISSUE_TEMPLATE.txt +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/.github/actions/decrypt.sh +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/.github/actions/entitlements.plist +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/.github/actions/package_exclusions.txt +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/.github/stale.yml +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/.github/workflows/build.yml +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/.github/workflows/codeql-analysis.yml +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/.github/workflows/get-cacerts.yml +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/.github/workflows/pypi.yml +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/.pre-commit-config.yaml +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/LICENSE +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/README.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/pyproject.toml +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/.gitignore +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/LICENSE +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/cacerts.pem +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/callgam.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/__main__.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/atom/__init__.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/atom/auth.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/atom/client.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/atom/core.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/atom/data.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/atom/http.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/atom/http_core.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/atom/http_interface.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/atom/mock_http.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/atom/mock_http_core.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/atom/mock_service.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/atom/service.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/atom/token_store.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/atom/url.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/cacerts.pem +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/cbcm-v1.1beta1.json +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/contactdelegation-v1.json +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/datastudio-v1.json +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gamlib/__init__.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gamlib/glaction.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gamlib/glcfg.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gamlib/glclargs.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gamlib/glentity.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gamlib/glgapi.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gamlib/glgdata.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gamlib/glglobals.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gamlib/glindent.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gamlib/glskus.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gamlib/gluprop.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gamlib/glverlibs.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gamlib/yubikey.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gdata/__init__.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gdata/alt/__init__.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gdata/alt/app_engine.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gdata/alt/appengine.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gdata/apps/__init__.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gdata/apps/audit/__init__.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gdata/apps/audit/service.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gdata/apps/contacts/__init__.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gdata/apps/contacts/service.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gdata/apps/service.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gdata/service.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/gdata/urlfetch.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/googleapiclient/__init__.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/googleapiclient/_auth.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/googleapiclient/_helpers.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/googleapiclient/channel.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/googleapiclient/discovery.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/googleapiclient/discovery_cache/__init__.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/googleapiclient/discovery_cache/appengine_memcache.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/googleapiclient/discovery_cache/base.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/googleapiclient/discovery_cache/file_cache.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/googleapiclient/errors.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/googleapiclient/http.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/googleapiclient/mimeparse.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/googleapiclient/model.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/googleapiclient/schema.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/googleapiclient/version.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/iso8601/__init__.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/iso8601/iso8601.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/meet-v2beta.json +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/serviceaccountlookup-v1.json +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam/six.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam-install.sh +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam-setup.bat +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam.exe.manifest +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam.spec +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/gam.wxs +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/license.rtf +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/requirements-dev.txt +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/requirements.txt +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/setup.cfg +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/setup.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/tools/a_atleast_b.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/tools/gen-wix-xml-filelist.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/tools/mkGamRef.py +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/tools/openssl.props +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/src/version_info.txt.in +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/00scratch.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Addresses.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Administrators.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Alert-Center.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Aliases.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/BNF-Syntax.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Basic-Items.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Bulk-Processing.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/CSV-Input-Filtering.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/CSV-Output-Filtering.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/CSV-Special-Characters.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Calendars-Access.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Calendars-Events.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Calendars.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Chat-Bot.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Chrome-AUE-Counts.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Chrome-Browser-Cloud-Management.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Chrome-Installed-Apps.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Chrome-Needs-Attention-Counts.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Chrome-Policies.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Chrome-Printers.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Chrome-Profile-Management.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Chrome-Version-Counts.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Chrome-Version-History.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/ChromeOS-Devices.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Classroom-Courses.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Classroom-Guardians.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Classroom-Invitations.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Classroom-Membership.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Cloud-Channel.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Cloud-Identity-Devices.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Cloud-Identity-Groups-Membership.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Cloud-Storage.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Collections-of-ChromeOS-Devices.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Collections-of-Items.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Collections-of-Users.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Command-Data-From-Google-Docs-Sheets-Storage.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Command-Line-Parsing.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Command-Logging-Progress.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Context-Aware-Access-Levels.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Customer.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Domain-People-Contacts-Profiles.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Domain-SharedContacts.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Domains-Verification.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Domains.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Downloads-Installs.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Drive-File-Selection.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Drive-Items.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Drive-REST-API-v3.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Email-Audit-Monitor.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Find-File-Owner.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/GAM-Public-Chat-Room.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/GAM-Return-Codes.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/GAM-with-minimal-GCP-rights.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/GAM7-on-Android-Devices.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/GAM7-on-Chrome-OS-Devices.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Google-Data-Transfers.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Google-Network-Addresses.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Groups-Membership.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Groups.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/HTTPS-Proxy.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Home.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/How-to-Install-GAM7.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/How-to-Uninstall-GAM7.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/How-to-Update-GAM7.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/How-to-Upgrade-GAMADV-XTD3-to-GAM7.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Inbound-SSO.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Install-GAM-as-Python-Library.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/List-Items.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/List.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Meta-Commands-and-File-Redirection.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Mobile-Devices.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Organizational-Units.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Other-Resources.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Permission-Matches.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Python-Regular-Expressions.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/README.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Rclone.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Reports.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Reseller.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Resources.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Running-GAM7-securely-on-a-Google-Compute-Engine.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/SSL-Root-CA-Certificates.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Schemas.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Scripts.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Send-Email.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Sites.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Tag-Replace.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Todrive.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Unmanaged-Accounts.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Upgrade-Benefits.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Analytics-Admin.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Application-Specific-Passwords.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Backup-Verification-Codes.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Calendars-Access.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Calendars-Events.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Calendars.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Chat.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Classification-Labels.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Classroom-Profile.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Contacts-Delegates.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Contacts.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Deprovision.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Drive-Activity-Settings.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Drive-Cleanup.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Drive-Comments.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Drive-Copy-Move.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Drive-Files-Display.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Drive-Files-Manage.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Drive-Orphans.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Drive-Ownership.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Drive-Permissions.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Drive-Query.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Drive-Revisions.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Drive-Shortcuts.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Drive-Transfer.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Forms.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Gmail-CSE.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Gmail-Delegates.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Gmail-Filters.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Gmail-Forwarding.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Gmail-Labels.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Gmail-Messages-Threads.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Gmail-Profile.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Gmail-S-MIME.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Gmail-Send-As-Signature-Vacation.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Gmail-Settings.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Group-Membership.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Keep-Notes.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Looker-Studio.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Meet.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-People-Contacts-Profiles.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Photo.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Profile-Photo.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Profile-Sharing.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Signout-Turnoff2SV.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Spreadsheets.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Tasks.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-Tokens.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users-YouTube.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Users.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Using-GAM7-with-a-YubiKey.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Using-GAM7-with-a-delegated-admin-service-account.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Vault-Takeout.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/Verifying-a-GAM7-Build-is-Legitimate-and-Official.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/_Sidebar.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/gam.cfg.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-AdminSettingsExamples.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Android-Installation.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-BulkOperations.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-CalendarExamples.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Chat-Bot.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Chrome-Browser-Management.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Chrome-OS-Installation.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Chrome-Policy-Settings.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Cloud-Identity-Groups.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Command-Reference-Calendar-Resources.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Command-Reference-Calendars.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Command-Reference-Definitions.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Command-Reference-Drive.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Command-Reference-Email.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Command-Reference-Group-Attributes.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Command-Reference-Groups.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Command-Reference-Users.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Context-Aware-Access-Levels.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Creating-client_secrets.json-and-oauth2service.json.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-CreatingClientSecretsFile.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Custom-Schemas.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Data-Transfers.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-DomainVerification.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-ExamplesAccountAuditing.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-ExamplesCSV.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-ExamplesEmailSettings.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-ExamplesOrganizations.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-GAM-Discussion-Group.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-GAM-on-Android-and-Chrome-OS.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-GAM-options-files.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-GAM-with--minimal-GCP-rights.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-GAM3CSVListings.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-GAM3DirectoryCommands.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-GAM3GroupSettings.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-GAM7-FAQ.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Google-Vault---Takeout-Commands.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-GoogleDriveManagement.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Grouping-18-or-Older-Users.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Home.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-How-to-upgrade-from-Standard-GAM.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Inbound-SSO-Settings.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-LicenseExamples.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Managing-Admins.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Managing-CloudPrint-Printers.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Managing-Devices.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Managing-Google-Classroom.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-OAuthKeyManagement.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Printers.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-ResellerCommands.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Running-GAM-on-Google-Compute-Engine-(GCE)-Securely.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-SecurityExamples.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-UnmanagedUsersExamples.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Use-a-Yubikey.md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-Using-GAM-with-a-delegated-admin-service-account-(DASA).md +0 -0
- {gam7-7.10.7 → gam7-7.10.9}/wiki/l-_Footer.md +0 -0
|
@@ -4817,11 +4817,13 @@ gam print shareddrives [todrive <ToDriveAttribute>*]
|
|
|
4817
4817
|
[teamdriveadminquery|query <QueryTeamDrive>]
|
|
4818
4818
|
[matchname <REMatchPattern>] [orgunit|org|ou <OrgUnitPath>]
|
|
4819
4819
|
[fields <SharedDriveFieldNameList>] [noorgunits [<Boolean>]]
|
|
4820
|
+
[showwebviewlink]
|
|
4820
4821
|
[formatjson [quotechar <Character>]]
|
|
4821
4822
|
gam show shareddrives
|
|
4822
4823
|
[teamdriveadminquery|query <QueryTeamDrive>]
|
|
4823
4824
|
[matchname <REMatchPattern>] [orgunit|org|ou <OrgUnitPath>]
|
|
4824
4825
|
[fields <SharedDriveFieldNameList>] [noorgunits [<Boolean>]]
|
|
4826
|
+
[showwebviewlink]
|
|
4825
4827
|
[formatjson] [noorgunits [<Boolean>]]
|
|
4826
4828
|
|
|
4827
4829
|
gam print shareddriveorganizers [todrive <ToDriveAttribute>*]
|
|
@@ -4902,12 +4904,14 @@ gam <UserTypeEntity> print shareddrives [todrive <ToDriveAttribute>*]
|
|
|
4902
4904
|
[matchname <REMatchPattern>] [orgunit|org|ou <OrgUnitPath>]
|
|
4903
4905
|
(role|roles <SharedDriveACLRoleList>)*
|
|
4904
4906
|
[fields <SharedDriveFieldNameList>]
|
|
4907
|
+
[showwebviewlink]
|
|
4905
4908
|
[guiroles [<Boolean>]] [formatjson [quotechar <Character>]]
|
|
4906
4909
|
gam <UserTypeEntity> show shareddrives
|
|
4907
4910
|
[teamdriveadminquery|query <QueryTeamDrive>]
|
|
4908
4911
|
[matchname <REMatchPattern>] [orgunit|org|ou <OrgUnitPath>]
|
|
4909
4912
|
(role|roles <SharedDriveACLRoleList>)*
|
|
4910
4913
|
[fields <SharedDriveFieldNameList>]
|
|
4914
|
+
[showwebviewlink]
|
|
4911
4915
|
[guiroles [<Boolean>]] [formatjson]
|
|
4912
4916
|
|
|
4913
4917
|
<PermissionMatch> ::=
|
|
@@ -1,3 +1,14 @@
|
|
|
1
|
+
7.10.09
|
|
2
|
+
|
|
3
|
+
Added option `showwebviewlink` to `gam [<UserTypeEntity>] print|show shareddrives` that
|
|
4
|
+
displays the web view link for the Shared Drive: `https://drive.google.com/drive/folders/<SharedDriveID>`.
|
|
5
|
+
|
|
6
|
+
7.10.08
|
|
7
|
+
|
|
8
|
+
Fixed bug in commands that modify messages where the `labelids <LabelIdList>` option
|
|
9
|
+
could not be used unless one of these options was also specified: `query`, `matchlabel`, `ids`;
|
|
10
|
+
it can be now be used by itself.
|
|
11
|
+
|
|
1
12
|
7.10.07
|
|
2
13
|
|
|
3
14
|
Updated `gam <UserTypeEntity> copy|move drivefile` to hanndle additional instances of
|
|
@@ -25,7 +25,7 @@ https://github.com/GAM-team/GAM/wiki
|
|
|
25
25
|
"""
|
|
26
26
|
|
|
27
27
|
__author__ = 'GAM Team <google-apps-manager@googlegroups.com>'
|
|
28
|
-
__version__ = '7.10.
|
|
28
|
+
__version__ = '7.10.09'
|
|
29
29
|
__license__ = 'Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0)'
|
|
30
30
|
|
|
31
31
|
#pylint: disable=wrong-import-position
|
|
@@ -5187,6 +5187,12 @@ def checkGAPIError(e, softErrors=False, retryOnHttpError=False, mapNotFound=True
|
|
|
5187
5187
|
return (0, None, None)
|
|
5188
5188
|
else:
|
|
5189
5189
|
systemErrorExit(HTTP_ERROR_RC, eContent)
|
|
5190
|
+
requiredScopes = ''
|
|
5191
|
+
wwwAuthenticate = e.resp.get('www-authenticate', '')
|
|
5192
|
+
if 'insufficient_scope' in wwwAuthenticate:
|
|
5193
|
+
mg = re.match(r'.+scope="(.+)"', wwwAuthenticate)
|
|
5194
|
+
if mg:
|
|
5195
|
+
requiredScopes = mg.group(1).split(' ')
|
|
5190
5196
|
if 'error' in error:
|
|
5191
5197
|
http_status = error['error']['code']
|
|
5192
5198
|
reason = ''
|
|
@@ -5256,6 +5262,8 @@ def checkGAPIError(e, softErrors=False, retryOnHttpError=False, mapNotFound=True
|
|
|
5256
5262
|
elif 'the authenticated user cannot access this service' in lmessage:
|
|
5257
5263
|
error = makeErrorDict(http_status, GAPI.SERVICE_NOT_AVAILABLE, message)
|
|
5258
5264
|
elif status == 'PERMISSION_DENIED' or 'the caller does not have permission' in lmessage or 'permission iam.serviceaccountkeys' in lmessage:
|
|
5265
|
+
if requiredScopes:
|
|
5266
|
+
message += f', {Msg.NO_SCOPES_FOR_API.format(API.findAPIforScope(requiredScopes))}'
|
|
5259
5267
|
error = makeErrorDict(http_status, GAPI.PERMISSION_DENIED, message)
|
|
5260
5268
|
elif http_status == 404:
|
|
5261
5269
|
if status == 'NOT_FOUND' or 'requested entity was not found' in lmessage or 'does not exist' in lmessage:
|
|
@@ -65792,7 +65800,7 @@ def _showSharedDrive(user, shareddrive, j, jcount, FJQC):
|
|
|
65792
65800
|
printKeyValueList(['hidden', shareddrive['hidden']])
|
|
65793
65801
|
if 'createdTime' in shareddrive:
|
|
65794
65802
|
printKeyValueList(['createdTime', formatLocalTime(shareddrive['createdTime'])])
|
|
65795
|
-
for setting in ['backgroundImageLink', 'colorRgb', 'themeId', 'orgUnit', 'orgUnitId']:
|
|
65803
|
+
for setting in ['backgroundImageLink', 'colorRgb', 'themeId', 'orgUnit', 'orgUnitId', 'webViewLink']:
|
|
65796
65804
|
if setting in shareddrive:
|
|
65797
65805
|
printKeyValueList([setting, shareddrive[setting]])
|
|
65798
65806
|
if 'role' in shareddrive:
|
|
@@ -65867,6 +65875,7 @@ SHAREDDRIVE_ACL_ROLES_MAP = {
|
|
|
65867
65875
|
# [matchname <REMatchPattern>] [orgunit|org|ou <OrgUnitPath>]
|
|
65868
65876
|
# (role|roles <SharedDriveACLRoleList>)*
|
|
65869
65877
|
# [fields <SharedDriveFieldNameList>] [noorgunits [<Boolean>]]
|
|
65878
|
+
# [showwebviewlink]
|
|
65870
65879
|
# [guiroles [<Boolean>]] [formatjson [quotechar <Character>]]
|
|
65871
65880
|
# [showitemcountonly]
|
|
65872
65881
|
# gam <UserTypeEntity> show shareddrives
|
|
@@ -65874,6 +65883,7 @@ SHAREDDRIVE_ACL_ROLES_MAP = {
|
|
|
65874
65883
|
# [matchname <REMatchPattrn>] [orgunit|org|ou <OrgUnitPath>]
|
|
65875
65884
|
# (role|roles <SharedDriveACLRoleLIst>)*
|
|
65876
65885
|
# [fields <SharedDriveFieldNameList>] [noorgunits [<Boolean>]]
|
|
65886
|
+
# [showwebviewlink]
|
|
65877
65887
|
# [guiroles [<Boolean>]] [formatjson]
|
|
65878
65888
|
# [showitemcountonly]
|
|
65879
65889
|
def printShowSharedDrives(users, useDomainAdminAccess=False):
|
|
@@ -65882,6 +65892,8 @@ def printShowSharedDrives(users, useDomainAdminAccess=False):
|
|
|
65882
65892
|
td_ouid = shareddrive.get('orgUnitId')
|
|
65883
65893
|
if td_ouid:
|
|
65884
65894
|
shareddrive['orgUnit'] = orgUnitIdToPathMap.get(f'id:{td_ouid}', UNKNOWN)
|
|
65895
|
+
if showWebViewLink:
|
|
65896
|
+
shareddrive['webViewLink'] = 'https://drive.google.com/drive/folders/'+shareddrive['id']
|
|
65885
65897
|
if not showFields:
|
|
65886
65898
|
return shareddrive
|
|
65887
65899
|
sshareddrive = {}
|
|
@@ -65900,6 +65912,7 @@ def printShowSharedDrives(users, useDomainAdminAccess=False):
|
|
|
65900
65912
|
showOrgUnitPaths = True
|
|
65901
65913
|
orgUnitIdToPathMap = None
|
|
65902
65914
|
guiRoles = showItemCountOnly = False
|
|
65915
|
+
showWebViewLink = False
|
|
65903
65916
|
while Cmd.ArgumentsRemaining():
|
|
65904
65917
|
myarg = getArgument()
|
|
65905
65918
|
if csvPF and myarg == 'todrive':
|
|
@@ -65929,6 +65942,8 @@ def printShowSharedDrives(users, useDomainAdminAccess=False):
|
|
|
65929
65942
|
showOrgUnitPaths = not getBoolean()
|
|
65930
65943
|
elif myarg == 'guiroles':
|
|
65931
65944
|
guiRoles = getBoolean()
|
|
65945
|
+
elif myarg == 'showwebviewlink':
|
|
65946
|
+
showWebViewLink = True
|
|
65932
65947
|
elif myarg == 'showitemcountonly':
|
|
65933
65948
|
showItemCountOnly = True
|
|
65934
65949
|
showOrgUnitPaths = False
|
|
@@ -65953,6 +65968,14 @@ def printShowSharedDrives(users, useDomainAdminAccess=False):
|
|
|
65953
65968
|
orgUnitIdToPathMap = getOrgUnitIdToPathMap(cd)
|
|
65954
65969
|
if showFields:
|
|
65955
65970
|
showFields.add('orgUnit')
|
|
65971
|
+
if showWebViewLink:
|
|
65972
|
+
if showFields:
|
|
65973
|
+
showFields.add('webViewLink')
|
|
65974
|
+
if csvPF:
|
|
65975
|
+
csvPF.AddTitle('webViewLink')
|
|
65976
|
+
if FJQC.formatJSON:
|
|
65977
|
+
csvPF.AddJSONTitles(['webViewLink'])
|
|
65978
|
+
csvPF.MoveJSONTitlesToEnd(['JSON'])
|
|
65956
65979
|
i, count, users = getEntityArgument(users)
|
|
65957
65980
|
for user in users:
|
|
65958
65981
|
i += 1
|
|
@@ -66021,6 +66044,8 @@ def printShowSharedDrives(users, useDomainAdminAccess=False):
|
|
|
66021
66044
|
row = {'User': user, 'id': shareddrive['id'], 'name': shareddrive['name']}
|
|
66022
66045
|
if not useDomainAdminAccess:
|
|
66023
66046
|
row['role'] = shareddrive['role'] if not guiRoles else SHAREDDRIVE_API_GUI_ROLES_MAP[shareddrive['role']]
|
|
66047
|
+
if showWebViewLink:
|
|
66048
|
+
row['webViewLink'] = shareddrive['webViewLink']
|
|
66024
66049
|
row['JSON'] = json.dumps(cleanJSON(shareddrive, timeObjects=SHAREDDRIVE_TIME_OBJECTS), ensure_ascii=False, sort_keys=True)
|
|
66025
66050
|
csvPF.WriteRow(row)
|
|
66026
66051
|
else:
|
|
@@ -70247,14 +70272,16 @@ def _finalizeMessageSelectParameters(parameters, queryOrIdsRequired):
|
|
|
70247
70272
|
for queryTimeName, queryTimeValue in iter(parameters['queryTimes'].items()):
|
|
70248
70273
|
parameters['query'] = parameters['query'].replace(f'#{queryTimeName}#', queryTimeValue)
|
|
70249
70274
|
_mapMessageQueryDates(parameters)
|
|
70250
|
-
elif queryOrIdsRequired and parameters['messageEntity'] is None:
|
|
70251
|
-
missingArgumentExit('query|matchlabel|ids')
|
|
70275
|
+
elif queryOrIdsRequired and parameters['messageEntity'] is None and not parameters['labelIds']:
|
|
70276
|
+
missingArgumentExit('query|matchlabel|ids|labelids')
|
|
70252
70277
|
else:
|
|
70253
70278
|
parameters['query'] = None
|
|
70254
70279
|
parameters['maxItems'] = parameters['maxToProcess'] if parameters['quick'] and not parameters['labelMatchPattern'] else 0
|
|
70255
70280
|
|
|
70256
70281
|
# gam <UserTypeEntity> archive messages <GroupItem>
|
|
70257
|
-
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70282
|
+
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70283
|
+
# [labelids <LabelIDList>]
|
|
70284
|
+
# [quick|notquick] [doit] [max_to_archive <Number>])|(ids <MessageIDEntity>)
|
|
70258
70285
|
# [csv [todrive <ToDriveAttribute>*]]
|
|
70259
70286
|
def archiveMessages(users):
|
|
70260
70287
|
def _processMessageFailed(user, idsList, errMsg, j=0, jcount=0):
|
|
@@ -70539,39 +70566,59 @@ def _processMessagesThreads(users, entityType):
|
|
|
70539
70566
|
csvPF.writeCSVfile(f'{Act.ToPerform()} Messages')
|
|
70540
70567
|
|
|
70541
70568
|
# gam <UserTypeEntity> delete message|messages
|
|
70542
|
-
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70569
|
+
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70570
|
+
# [labelids <LabelIDList>]
|
|
70571
|
+
# [quick|notquick] [doit] [max_to_delete <Number>])|(ids <MessageIDEntity>)
|
|
70543
70572
|
# [csv [todrive <ToDriveAttribute>*]]
|
|
70544
70573
|
# gam <UserTypeEntity> modify message|messages
|
|
70545
|
-
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70574
|
+
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70575
|
+
# [labelids <LabelIDList>]
|
|
70576
|
+
# [quick|notquick] [doit] [max_to_modify <Number>])|(ids <MessageIDEntity>)
|
|
70546
70577
|
# (addlabel <LabelName>)* (removelabel <LabelName>)*
|
|
70547
70578
|
# [csv [todrive <ToDriveAttribute>*]]
|
|
70548
70579
|
# gam <UserTypeEntity> spam message|messages
|
|
70549
|
-
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70580
|
+
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70581
|
+
# [labelids <LabelIDList>]
|
|
70582
|
+
# [quick|notquick] [doit] [max_to_spam <Number>])|(ids <MessageIDEntity>)
|
|
70550
70583
|
# [csv [todrive <ToDriveAttribute>*]]
|
|
70551
70584
|
# gam <UserTypeEntity> trash message|messages
|
|
70552
|
-
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70585
|
+
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70586
|
+
# [labelids <LabelIDList>]
|
|
70587
|
+
# [quick|notquick] [doit] [max_to_trash <Number>])|(ids <MessageIDEntity>)
|
|
70553
70588
|
# [csv [todrive <ToDriveAttribute>*]]
|
|
70554
70589
|
# gam <UserTypeEntity> untrash message|messages
|
|
70555
|
-
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70590
|
+
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70591
|
+
# [labelids <LabelIDList>]
|
|
70592
|
+
# [quick|notquick] [doit] [max_to_untrash <Number>])|(ids <MessageIDEntity>)
|
|
70556
70593
|
# [csv [todrive <ToDriveAttribute>*]]
|
|
70557
70594
|
def processMessages(users):
|
|
70558
70595
|
_processMessagesThreads(users, Ent.MESSAGE)
|
|
70559
70596
|
|
|
70560
70597
|
# gam <UserTypeEntity> delete thread|threads
|
|
70561
|
-
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70598
|
+
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70599
|
+
# [labelids <LabelIDList>]
|
|
70600
|
+
# [quick|notquick] [doit] [max_to_delete <Number>])|(ids <ThreadIDEntity>)
|
|
70562
70601
|
# [csv [todrive <ToDriveAttribute>*]]
|
|
70563
70602
|
# gam <UserTypeEntity> modify thread|threads
|
|
70564
|
-
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70603
|
+
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70604
|
+
# [labelids <LabelIDList>]
|
|
70605
|
+
# [quick|notquick] [doit] [max_to_modify <Number>])|(ids <ThreadIDEntity>)
|
|
70565
70606
|
# (addlabel <LabelName>)* (removelabel <LabelName>)*
|
|
70566
70607
|
# [csv [todrive <ToDriveAttribute>*]]
|
|
70567
70608
|
# gam <UserTypeEntity> spam thread|threads
|
|
70568
|
-
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70609
|
+
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70610
|
+
# [labelids <LabelIDList>]
|
|
70611
|
+
# [quick|notquick] [doit] [max_to_spam <Number>])|(ids <ThreadIDEntity>)
|
|
70569
70612
|
# [csv [todrive <ToDriveAttribute>*]]
|
|
70570
70613
|
# gam <UserTypeEntity> trash thread|threads
|
|
70571
|
-
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70614
|
+
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70615
|
+
# [labelids <LabelIDList>]
|
|
70616
|
+
# [quick|notquick] [doit] [max_to_trash <Number>])|(ids <ThreadIDEntity>)
|
|
70572
70617
|
# [csv [todrive <ToDriveAttribute>*]]
|
|
70573
70618
|
# gam <UserTypeEntity> untrash thread|threads
|
|
70574
|
-
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70619
|
+
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])+
|
|
70620
|
+
# [labelids <LabelIDList>]
|
|
70621
|
+
# [quick|notquick] [doit] [max_to_untrash <Number>])|(ids <ThreadIDEntity>)
|
|
70575
70622
|
# [csv [todrive <ToDriveAttribute>*]]
|
|
70576
70623
|
def processThreads(users):
|
|
70577
70624
|
_processMessagesThreads(users, Ent.THREAD)
|
|
@@ -71993,7 +72040,9 @@ def printShowMessagesThreads(users, entityType):
|
|
|
71993
72040
|
csvPF.writeCSVfile('Message Counts' if not show_labels else 'Message Label Counts')
|
|
71994
72041
|
|
|
71995
72042
|
# gam <UserTypeEntity> print message|messages [todrive <ToDriveAttribute>*]
|
|
71996
|
-
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])*
|
|
72043
|
+
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])*
|
|
72044
|
+
# [labelids <LabelIDList>]
|
|
72045
|
+
# [quick|notquick] [max_to_print <Number>] [includespamtrash])|(ids <MessageIDEntity>)
|
|
71997
72046
|
# [labelmatchpattern <REMatchPattern>] [sendermatchpattern <REMatchPattern>]
|
|
71998
72047
|
# [headers all|<SMTPHeaderList>] [dateheaderformat iso|rfc2822|<String>] [dateheaderconverttimezone [<Boolean>]]
|
|
71999
72048
|
# [showlabels] [showbody] [showhtml] [showdate] [showsize] [showsnippet]
|
|
@@ -72003,7 +72052,9 @@ def printShowMessagesThreads(users, entityType):
|
|
|
72003
72052
|
# [showattachments [noshowtextplain]]]
|
|
72004
72053
|
# (addcsvdata <FieldName> <String>)*
|
|
72005
72054
|
# gam <UserTypeEntity> show message|messages
|
|
72006
|
-
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])*
|
|
72055
|
+
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])*
|
|
72056
|
+
# [labelids <LabelIDList>]
|
|
72057
|
+
# [quick|notquick] [max_to_show <Number>] [includespamtrash])|(ids <MessageIDEntity>)
|
|
72007
72058
|
# [labelmatchpattern <REMatchPattern>] [sendermatchpattern <REMatchPattern>]
|
|
72008
72059
|
# [headers all|<SMTPHeaderList>] [dateheaderformat iso|rfc2822|<String>] [dateheaderconverttimezone [<Boolean>]]
|
|
72009
72060
|
# [showlabels] [showbody] [showhtml] [showdate] [showsize] [showsnippet]
|
|
@@ -72016,7 +72067,9 @@ def printShowMessages(users):
|
|
|
72016
72067
|
printShowMessagesThreads(users, Ent.MESSAGE)
|
|
72017
72068
|
|
|
72018
72069
|
# gam <UserTypeEntity> print thread|threads [todrive <ToDriveAttribute>*]
|
|
72019
|
-
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])*
|
|
72070
|
+
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])*
|
|
72071
|
+
# [labelids <LabelIDList>]
|
|
72072
|
+
# [quick|notquick] [max_to_print <Number>] [includespamtrash])|(ids <ThreadIDEntity>)
|
|
72020
72073
|
# [labelmatchpattern <REMatchPattern>]
|
|
72021
72074
|
# [headers all|<SMTPHeaderList>] [dateheaderformat iso|rfc2822|<String>] [dateheaderconverttimezone [<Boolean>]]
|
|
72022
72075
|
# [showlabels] [showbody] [showhtml] [showdate] [showsize] [showsnippet]
|
|
@@ -72026,7 +72079,9 @@ def printShowMessages(users):
|
|
|
72026
72079
|
# [showattachments [noshowtextplain]]]
|
|
72027
72080
|
# (addcsvdata <FieldName> <String>)*
|
|
72028
72081
|
# gam <UserTypeEntity> show thread|threads
|
|
72029
|
-
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])*
|
|
72082
|
+
# (((query <QueryGmail> [querytime<String> <Date>]*) (matchlabel <LabelName>) [or|and])*
|
|
72083
|
+
# [labelids <LabelIDList>]
|
|
72084
|
+
# [quick|notquick] [max_to_show <Number>] [includespamtrash])|(ids <ThreadIDEntity>)
|
|
72030
72085
|
# [labelmatchpattern <REMatchPattern>]
|
|
72031
72086
|
# [headers all|<SMTPHeaderList>] [dateheaderformat iso|rfc2822|<String>] [dateheaderconverttimezone [<Boolean>]]
|
|
72032
72087
|
# [showlabels] [showbody] [showhtml] [showdate] [showsize] [showsnippet]
|
|
@@ -226,15 +226,15 @@ _INFO = {
|
|
|
226
226
|
CHROMEMANAGEMENT_TELEMETRY: {'name': 'Chrome Management API - Telemetry', 'version': 'v1', 'v2discovery': True, 'mappedAPI': CHROMEMANAGEMENT},
|
|
227
227
|
CHROMEPOLICY: {'name': 'Chrome Policy API', 'version': 'v1', 'v2discovery': True},
|
|
228
228
|
CHROMEVERSIONHISTORY: {'name': 'Chrome Version History API', 'version': 'v1', 'v2discovery': True},
|
|
229
|
-
CLOUDCHANNEL: {'name': '
|
|
230
|
-
CLOUDIDENTITY_DEVICES: {'name': 'Cloud Identity Devices
|
|
231
|
-
CLOUDIDENTITY_GROUPS: {'name': 'Cloud Identity Groups
|
|
232
|
-
CLOUDIDENTITY_GROUPS_BETA: {'name': 'Cloud Identity Groups
|
|
233
|
-
CLOUDIDENTITY_INBOUND_SSO: {'name': 'Cloud Identity Inbound SSO
|
|
234
|
-
CLOUDIDENTITY_ORGUNITS: {'name': 'Cloud Identity OrgUnits
|
|
235
|
-
CLOUDIDENTITY_ORGUNITS_BETA: {'name': 'Cloud Identity OrgUnits
|
|
236
|
-
CLOUDIDENTITY_POLICY: {'name': 'Cloud Identity Policy
|
|
237
|
-
CLOUDIDENTITY_USERINVITATIONS: {'name': 'Cloud Identity User Invitations
|
|
229
|
+
CLOUDCHANNEL: {'name': 'Cloud Channel API', 'version': 'v1', 'v2discovery': True},
|
|
230
|
+
CLOUDIDENTITY_DEVICES: {'name': 'Cloud Identity API - Devices', 'version': 'v1', 'v2discovery': True, 'mappedAPI': 'cloudidentity'},
|
|
231
|
+
CLOUDIDENTITY_GROUPS: {'name': 'Cloud Identity API - Groups', 'version': 'v1', 'v2discovery': True, 'mappedAPI': 'cloudidentity'},
|
|
232
|
+
CLOUDIDENTITY_GROUPS_BETA: {'name': 'Cloud Identity API - Groups Beta', 'version': 'v1beta1', 'v2discovery': True, 'mappedAPI': 'cloudidentity'},
|
|
233
|
+
CLOUDIDENTITY_INBOUND_SSO: {'name': 'Cloud Identity API - Inbound SSO Settings', 'version': 'v1', 'v2discovery': True, 'mappedAPI': 'cloudidentity'},
|
|
234
|
+
CLOUDIDENTITY_ORGUNITS: {'name': 'Cloud Identity API - OrgUnits', 'version': 'v1', 'v2discovery': True, 'mappedAPI': 'cloudidentity'},
|
|
235
|
+
CLOUDIDENTITY_ORGUNITS_BETA: {'name': 'Cloud Identity API - OrgUnits Beta', 'version': 'v1beta1', 'v2discovery': True, 'mappedAPI': 'cloudidentity'},
|
|
236
|
+
CLOUDIDENTITY_POLICY: {'name': 'Cloud Identity API - Policy', 'version': 'v1', 'v2discovery': True, 'mappedAPI': 'cloudidentity'},
|
|
237
|
+
CLOUDIDENTITY_USERINVITATIONS: {'name': 'Cloud Identity API - User Invitations', 'version': 'v1', 'v2discovery': True, 'mappedAPI': 'cloudidentity'},
|
|
238
238
|
CLOUDRESOURCEMANAGER: {'name': 'Cloud Resource Manager API v3', 'version': 'v3', 'v2discovery': True},
|
|
239
239
|
CONTACTS: {'name': 'Contacts API', 'version': 'v3', 'v2discovery': False},
|
|
240
240
|
CONTACTDELEGATION: {'name': 'Contact Delegation API', 'version': 'v1', 'v2discovery': True, 'localjson': True},
|
|
@@ -258,13 +258,13 @@ _INFO = {
|
|
|
258
258
|
LICENSING: {'name': 'License Manager API', 'version': 'v1', 'v2discovery': True},
|
|
259
259
|
LOOKERSTUDIO: {'name': 'Looker Studio API', 'version': 'v1', 'v2discovery': True, 'localjson': True},
|
|
260
260
|
MEET: {'name': 'Meet API', 'version': 'v2', 'v2discovery': True},
|
|
261
|
-
MEET_BETA: {'name': 'Meet API', 'version': 'v2beta', 'v2discovery': True, 'localjson': True, 'mappedAPI': MEET},
|
|
261
|
+
MEET_BETA: {'name': 'Meet API Beta', 'version': 'v2beta', 'v2discovery': True, 'localjson': True, 'mappedAPI': MEET},
|
|
262
262
|
OAUTH2: {'name': 'OAuth2 API', 'version': 'v2', 'v2discovery': False},
|
|
263
263
|
ORGPOLICY: {'name': 'Organization Policy API', 'version': 'v2', 'v2discovery': True},
|
|
264
264
|
PEOPLE: {'name': 'People API', 'version': 'v1', 'v2discovery': True},
|
|
265
265
|
PEOPLE_DIRECTORY: {'name': 'People Directory API', 'version': 'v1', 'v2discovery': True, 'mappedAPI': PEOPLE},
|
|
266
266
|
PEOPLE_OTHERCONTACTS: {'name': 'People API - Other Contacts', 'version': 'v1', 'v2discovery': True, 'mappedAPI': PEOPLE},
|
|
267
|
-
PRINTERS: {'name': 'Directory API Printers', 'version': 'directory_v1', 'v2discovery': True, 'mappedAPI': 'admin'},
|
|
267
|
+
PRINTERS: {'name': 'Directory API - Printers', 'version': 'directory_v1', 'v2discovery': True, 'mappedAPI': 'admin'},
|
|
268
268
|
PUBSUB: {'name': 'Pub / Sub API', 'version': 'v1', 'v2discovery': True},
|
|
269
269
|
REPORTS: {'name': 'Reports API', 'version': 'reports_v1', 'v2discovery': True, 'mappedAPI': 'admin'},
|
|
270
270
|
RESELLER: {'name': 'Reseller API', 'version': 'v1', 'v2discovery': True},
|
|
@@ -362,29 +362,29 @@ _CLIENT_SCOPES = [
|
|
|
362
362
|
'subscopes': READONLY,
|
|
363
363
|
'offByDefault': True,
|
|
364
364
|
'scope': 'https://www.googleapis.com/auth/apps.order'},
|
|
365
|
-
{'name': 'Cloud Identity Groups
|
|
365
|
+
{'name': 'Cloud Identity API - Groups',
|
|
366
366
|
'api': CLOUDIDENTITY_GROUPS,
|
|
367
367
|
'subscopes': READONLY,
|
|
368
368
|
'scope': 'https://www.googleapis.com/auth/cloud-identity.groups'},
|
|
369
|
-
{'name': 'Cloud Identity Groups
|
|
369
|
+
{'name': 'Cloud Identity API - Groups Beta (Enables group locking/unlocking)',
|
|
370
370
|
'api': CLOUDIDENTITY_GROUPS_BETA,
|
|
371
371
|
'subscopes': [],
|
|
372
372
|
'scope': 'https://www.googleapis.com/auth/cloud-identity.groups'},
|
|
373
|
-
{'name': 'Cloud Identity - Inbound SSO Settings',
|
|
373
|
+
{'name': 'Cloud Identity API - Inbound SSO Settings',
|
|
374
374
|
'api': CLOUDIDENTITY_INBOUND_SSO,
|
|
375
375
|
'subscopes': READONLY,
|
|
376
376
|
'scope': 'https://www.googleapis.com/auth/cloud-identity.inboundsso'},
|
|
377
|
-
{'name': 'Cloud Identity OrgUnits
|
|
377
|
+
{'name': 'Cloud Identity API - OrgUnits Beta',
|
|
378
378
|
'api': CLOUDIDENTITY_ORGUNITS_BETA,
|
|
379
379
|
'subscopes': READONLY,
|
|
380
380
|
'scope': 'https://www.googleapis.com/auth/cloud-identity.orgunits'},
|
|
381
|
-
{'name': 'Cloud Identity - Policy',
|
|
381
|
+
{'name': 'Cloud Identity API - Policy',
|
|
382
382
|
'api': CLOUDIDENTITY_POLICY,
|
|
383
383
|
'subscopes': READONLY,
|
|
384
384
|
'roByDefault': True,
|
|
385
385
|
'scope': 'https://www.googleapis.com/auth/cloud-identity.policies'
|
|
386
386
|
},
|
|
387
|
-
{'name': 'Cloud Identity User Invitations
|
|
387
|
+
{'name': 'Cloud Identity API - User Invitations',
|
|
388
388
|
'api': CLOUDIDENTITY_USERINVITATIONS,
|
|
389
389
|
'subscopes': READONLY,
|
|
390
390
|
'scope': 'https://www.googleapis.com/auth/cloud-identity.userinvitations'},
|
|
@@ -833,3 +833,27 @@ def getSvcAcctScopesList(userServiceAccountAccessOnly, svcAcctSpecialScopes):
|
|
|
833
833
|
|
|
834
834
|
def hasLocalJSON(api):
|
|
835
835
|
return _INFO[api].get('localjson', False)
|
|
836
|
+
|
|
837
|
+
def findAPIforScope(scopesList):
|
|
838
|
+
def checkScopeMatch(scope, cscope):
|
|
839
|
+
if cscope['scope'] == scope:
|
|
840
|
+
requiredAPIs.append(cscope['name'])
|
|
841
|
+
return True
|
|
842
|
+
if cscope['subscopes'] == READONLY and cscope['scope']+'.readonly' == scope:
|
|
843
|
+
requiredAPIs.append(cscope['name']+' (supports readonly)')
|
|
844
|
+
return True
|
|
845
|
+
return False
|
|
846
|
+
|
|
847
|
+
requiredAPIs = []
|
|
848
|
+
for scope in scopesList:
|
|
849
|
+
for cscope in _CLIENT_SCOPES:
|
|
850
|
+
if checkScopeMatch(scope, cscope):
|
|
851
|
+
break
|
|
852
|
+
else:
|
|
853
|
+
for cscope in _SVCACCT_SCOPES:
|
|
854
|
+
if checkScopeMatch(scope, cscope):
|
|
855
|
+
break
|
|
856
|
+
if not requiredAPIs:
|
|
857
|
+
requiredAPIs = scopesList
|
|
858
|
+
return ' or '.join(requiredAPIs)
|
|
859
|
+
|
|
@@ -184,8 +184,8 @@ ALREADY_EXISTS_IN_TARGET_FOLDER = 'Already exists in {0}: {1}'
|
|
|
184
184
|
ALREADY_EXISTS_USE_MERGE_ARGUMENT = 'Already exists; use the "merge" argument to merge the labels'
|
|
185
185
|
API_ACCESS_DENIED = 'API access Denied'
|
|
186
186
|
API_CALLS_RETRY_DATA = 'API calls retry data\n'
|
|
187
|
-
API_CHECK_CLIENT_AUTHORIZATION = 'Please make sure the Client ID: {0} is authorized for the appropriate API or scopes
|
|
188
|
-
API_CHECK_SVCACCT_AUTHORIZATION = 'Please make sure the Service Account Client ID: {0} is authorized for the appropriate API or scopes
|
|
187
|
+
API_CHECK_CLIENT_AUTHORIZATION = 'Please make sure the Client ID: {0} is authorized for the appropriate API or scopes: {1}\n\nRun: gam oauth create\n'
|
|
188
|
+
API_CHECK_SVCACCT_AUTHORIZATION = 'Please make sure the Service Account Client ID: {0} is authorized for the appropriate API or scopes: {1}\n\nRun: gam user {2} update serviceaccount\n'
|
|
189
189
|
API_ERROR_SETTINGS = 'API error, some settings not set'
|
|
190
190
|
ARE_BOTH_REQUIRED = 'Arguments {0} and {1} are both required'
|
|
191
191
|
ARE_MUTUALLY_EXCLUSIVE = 'Arguments {0} and {1} are mutually exclusive'
|
|
@@ -425,7 +425,7 @@ NO_LABELS_TO_PROCESS = 'No Labels to process'
|
|
|
425
425
|
NO_MESSAGES_WITH_LABEL = 'No Messages with Label'
|
|
426
426
|
NO_PARENTS_TO_CONVERT_TO_SHORTCUTS = 'No parents to convert to shortcuts'
|
|
427
427
|
NO_REPORT_AVAILABLE = 'No {0} report available.'
|
|
428
|
-
NO_SCOPES_FOR_API = 'There are no scopes authorized for the {0}'
|
|
428
|
+
NO_SCOPES_FOR_API = 'There are no scopes authorized for the API(s): {0}'
|
|
429
429
|
NO_SERIAL_NUMBERS_SPECIFIED = 'No serial numbers specified'
|
|
430
430
|
NO_SSO_PROFILE_MATCHES = 'No SSO profile matches display name {0}'
|
|
431
431
|
NO_SSO_PROFILE_ASSIGNED = 'No SSO profile assigned to {0} {1}'
|
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
- [Python Regular Expressions](Python-Regular-Expressions)
|
|
6
6
|
- [Definitions](#definitions)
|
|
7
7
|
- [Manage Projects](#manage-projects)
|
|
8
|
-
- [Authorize a
|
|
8
|
+
- [Authorize a user to create projects](#authorize-a-user-to-create-projects)
|
|
9
9
|
- [Authorize Service Account Key Uploads](#authorize-service-account-key-uploads)
|
|
10
10
|
- [Authorize GAM to create projects](#authorize-gam-to-create-projects)
|
|
11
11
|
- [Create a new GCP project folder](#create-a-new-gcp-project-folder)
|
|
@@ -74,11 +74,6 @@ Verify that all scopes are available:
|
|
|
74
74
|
* Select "ON for everyone"
|
|
75
75
|
* Click "SAVE"
|
|
76
76
|
|
|
77
|
-
Verify that internal apps are trusted.
|
|
78
|
-
* Access the admin console and go to Security -> Access and data control -> API Controls
|
|
79
|
-
* Check that "Trust internal, domain-owned apps" is present in the **Settings** section
|
|
80
|
-
* Click "SAVE"
|
|
81
|
-
|
|
82
77
|
If you run a Google Workspace Education SKU, verify that Classroom API is enabled if required.
|
|
83
78
|
* Access the admin console and go to Apps -> Google Workspace - Classroom
|
|
84
79
|
* Expand "Data access"
|
|
@@ -110,12 +105,13 @@ Verify whether the super admin you'll be using is in an OU where reauthenticatio
|
|
|
110
105
|
* Access the admin console and go to Security -> Overview
|
|
111
106
|
* Scroll down and open Google Cloud session control section
|
|
112
107
|
* Select the OU containing the super admin
|
|
113
|
-
* If Require reauthentication is selected
|
|
114
|
-
*
|
|
115
|
-
*
|
|
108
|
+
* If Require reauthentication is selected, you'll need either:
|
|
109
|
+
* uncheck Google Cloud Storage and any other GCP APIs that you selected on `gam oauth create` (reauth is only necessary for GCP APIs)
|
|
110
|
+
* enable "Exempt Trusted apps"
|
|
111
|
+
* rerun `gam oauth create` at whatever frequency is specified
|
|
116
112
|
|
|
117
113
|
Additional steps may be required if errors are encountered.
|
|
118
|
-
* [Authorize a
|
|
114
|
+
* [Authorize a user to create projects](#authorize-a-user-to-create-projects)
|
|
119
115
|
* [Authorize Service Account Key Uploads](#authorize-service-account-key-uploads)
|
|
120
116
|
* [Authorize GAM to create projects](#authorize-gam-to-create-projects)
|
|
121
117
|
|
|
@@ -169,8 +165,8 @@ For `print|show projects`, you can eliminate the password prompt and authenticat
|
|
|
169
165
|
gam print projects admin admin@domain.com
|
|
170
166
|
```
|
|
171
167
|
|
|
172
|
-
## Authorize a
|
|
173
|
-
If you try to create a project and get an error saying that the
|
|
168
|
+
## Authorize a user to create projects
|
|
169
|
+
If you try to create a project and get an error saying that the user you specified is not authorized to create projects,
|
|
174
170
|
perform these steps and then retry the create project command.
|
|
175
171
|
|
|
176
172
|
* Login as an existing super admin at console.cloud.google.com
|
|
@@ -184,13 +180,12 @@ perform these steps and then retry the create project command.
|
|
|
184
180
|
* Click in the Select a role box
|
|
185
181
|
* Type project creator in the Filter box
|
|
186
182
|
* Click Project Creator
|
|
187
|
-
* Click + Add Another Role
|
|
188
|
-
* Type orgpolicy.policyAdmin in the Filter box
|
|
189
|
-
* Click Organization Policy Administrator
|
|
190
183
|
* Click Save
|
|
191
184
|
|
|
192
185
|
## Authorize Service Account Key Uploads
|
|
193
186
|
|
|
187
|
+
*IMPORTANT:* Google best practice is to NOT use service account keys. Rather than overriding Google's default policy please consider [running GAM on Google Compute Engine Securely](https://github.com/GAM-team/GAM/wiki/l-Running-GAM-on-Google-Compute-Engine-(GCE)-Securely) so that service account keys are not necessary.
|
|
188
|
+
|
|
194
189
|
If you try to create a project and get an error saying that Constraint `constraints/iam.disableServiceAccountKeyUpload violated for service account projects/gam-project-xxxxx`,
|
|
195
190
|
perform these steps and then you should be able to authorize and use your project.
|
|
196
191
|
|
|
@@ -20,7 +20,8 @@
|
|
|
20
20
|
|
|
21
21
|
## Query documentation
|
|
22
22
|
* [Cloud Identity Groups API - Search Dynamic Groups](https://cloud.google.com/identity/docs/reference/rest/v1/groups#dynamicgroupquery)
|
|
23
|
-
* [Member
|
|
23
|
+
* [Dynamic Groups Member Attributes](https://cloud.google.com/identity/docs/how-to/dynamic-groups-attributes)
|
|
24
|
+
* [Member Restrictions](https://cloud.google.com/identity/docs/reference/rest/v1/SecuritySettings#MemberRestriction)
|
|
24
25
|
|
|
25
26
|
## Notes
|
|
26
27
|
|
|
@@ -12,14 +12,28 @@
|
|
|
12
12
|
|
|
13
13
|
## Notes
|
|
14
14
|
To use these commands you must update your client access authentication.
|
|
15
|
-
You'll enter
|
|
15
|
+
You'll enter 20r to turn on the Cloud Identity Policy scope; then continue
|
|
16
16
|
with authentication.
|
|
17
17
|
```
|
|
18
18
|
gam oauth delete
|
|
19
19
|
gam oauth create
|
|
20
20
|
...
|
|
21
|
-
[R]
|
|
21
|
+
[R] 20) Cloud Identity - Policy (supports readonly)
|
|
22
22
|
```
|
|
23
|
+
You must enable access to policies in the GCP cloud console.
|
|
24
|
+
|
|
25
|
+
* Login at console.cloud.google.com
|
|
26
|
+
* In the upper left click the three lines to the left of Google Cloud and select IAM & Admin
|
|
27
|
+
* Under IAM & Admin select IAM
|
|
28
|
+
* Click in the box to the right of Google Cloud
|
|
29
|
+
* Click the three dots at the right and select IAM/Permissions
|
|
30
|
+
* Now you should be at "Permissions for organization ..."
|
|
31
|
+
* Click on Grant Access
|
|
32
|
+
* Enter the GAM project creator address in Principals
|
|
33
|
+
* Click in the Select a role box
|
|
34
|
+
* Type orgpolicy.policyAdmin in the Filter box
|
|
35
|
+
* Click Organization Policy Administrator
|
|
36
|
+
* Click Save
|
|
23
37
|
|
|
24
38
|
## Definitions
|
|
25
39
|
```
|
|
@@ -10,13 +10,33 @@ Add the `-s` option to the end of the above commands to suppress creating the `g
|
|
|
10
10
|
|
|
11
11
|
See [Downloads-Installs-GAM7](https://github.com/GAM-team/GAM/wiki/Downloads-Installs) for Windows or other options, including manual installation
|
|
12
12
|
|
|
13
|
+
### 7.10.09
|
|
14
|
+
|
|
15
|
+
Added option `showwebviewlink` to `gam [<UserTypeEntity>] print|show shareddrives` that
|
|
16
|
+
displays the web view link for the Shared Drive: `https://drive.google.com/drive/folders/<SharedDriveID>`.
|
|
17
|
+
|
|
18
|
+
### 7.10.08
|
|
19
|
+
|
|
20
|
+
Fixed bug in commands that modify messages where the `labelids <LabelIdList>` option
|
|
21
|
+
could not be used unless one of these options was also specified: `query`, `matchlabel`, `ids`;
|
|
22
|
+
it can be now be used by itself.
|
|
23
|
+
|
|
24
|
+
### 7.10.07
|
|
25
|
+
|
|
26
|
+
Updated `gam <UserTypeEntity> copy|move drivefile` to hanndle additional instances of
|
|
27
|
+
the `cannotModifyInheritedPermission` error.
|
|
28
|
+
|
|
29
|
+
Added license SKU `Google AI Ultra for Business`
|
|
30
|
+
* ProductID - 101047
|
|
31
|
+
* SKUID - 1010470008 | geminiultra
|
|
32
|
+
|
|
13
33
|
### 7.10.06
|
|
14
34
|
|
|
15
35
|
Added option `clientstates` to `gam print devices` to include client states in device output.
|
|
16
36
|
|
|
17
37
|
### 7.10.05
|
|
18
38
|
|
|
19
|
-
Google renamed an error: cannotModifyInheritedTeamDrivePermission became cannotModifyInheritedPermission
|
|
39
|
+
Google renamed an error: `cannotModifyInheritedTeamDrivePermission` became `cannotModifyInheritedPermission`.
|
|
20
40
|
GAM will now handle the new error.
|
|
21
41
|
|
|
22
42
|
### 7.10.04
|
|
@@ -251,7 +251,7 @@ writes the credentials into the file oauth2.txt.
|
|
|
251
251
|
admin@server:/Users/admin$ rm -f /Users/admin/GAMConfig/oauth2.txt
|
|
252
252
|
admin@server:/Users/admin$ gam version
|
|
253
253
|
WARNING: Config File: /Users/admin/GAMConfig/gam.cfg, Section: DEFAULT, Item: oauth2_txt, Value: /Users/admin/GAMConfig/oauth2.txt, Not Found
|
|
254
|
-
GAM 7.10.
|
|
254
|
+
GAM 7.10.09 - https://github.com/GAM-team/GAM - pyinstaller
|
|
255
255
|
GAM Team <google-apps-manager@googlegroups.com>
|
|
256
256
|
Python 3.13.5 64-bit final
|
|
257
257
|
MacOS Sequoia 15.5 x86_64
|
|
@@ -989,7 +989,7 @@ writes the credentials into the file oauth2.txt.
|
|
|
989
989
|
C:\>del C:\GAMConfig\oauth2.txt
|
|
990
990
|
C:\>gam version
|
|
991
991
|
WARNING: Config File: C:\GAMConfig\gam.cfg, Section: DEFAULT, Item: oauth2_txt, Value: C:\GAMConfig\oauth2.txt, Not Found
|
|
992
|
-
GAM 7.10.
|
|
992
|
+
GAM 7.10.09 - https://github.com/GAM-team/GAM - pythonsource
|
|
993
993
|
GAM Team <google-apps-manager@googlegroups.com>
|
|
994
994
|
Python 3.13.5 64-bit final
|
|
995
995
|
Windows-10-10.0.17134 AMD64
|
|
@@ -62,6 +62,7 @@
|
|
|
62
62
|
| Gemini Education | 1010470004 | geminiedu |
|
|
63
63
|
| Gemini Education Premium | 1010470005 | geminiedupremium |
|
|
64
64
|
| Gemini Enterprise | 1010470001 | geminient | duetai |
|
|
65
|
+
| Google AI Ultra for Business | 1010470008 | geminiultra |
|
|
65
66
|
| Google Apps Message Security | Google-Apps-For-Postini | postini |
|
|
66
67
|
| Google Chrome Device Management | Google-Chrome-Device-Management | cdm |
|
|
67
68
|
| Google Drive Storage 16TB | Google-Drive-storage-16TB | 16tb |
|
|
@@ -372,7 +372,9 @@ By default, Gam displays the information as an indented list of keys and values.
|
|
|
372
372
|
gam [<UserTypeEntity>] show shareddrives
|
|
373
373
|
[adminaccess|asadmin] [teamdriveadminquery|query <QueryTeamDrive>]
|
|
374
374
|
[matchname <REMatchPattern>] [orgunit|org|ou <OrgUnitPath>]
|
|
375
|
-
[fields <SharedDriveFieldNameList>]
|
|
375
|
+
[fields <SharedDriveFieldNameList>]
|
|
376
|
+
[showwebviewlink]
|
|
377
|
+
[formatjson]
|
|
376
378
|
```
|
|
377
379
|
By default, all Shared Drives are displayed; use the following options to select a subset of Shared Drives:
|
|
378
380
|
* `teamdriveadminquery|query <QueryTeamDrive>` - Use a query to select Shared Drives
|
|
@@ -385,7 +387,9 @@ By default, Gam displays the information as an indented list of keys and values.
|
|
|
385
387
|
gam [<UserTypeEntity>] print shareddrives [todrive <ToDriveAttribute>*]
|
|
386
388
|
[adminaccess|asadmin] [teamdriveadminquery|query <QueryTeamDrive>]
|
|
387
389
|
[matchname <REMatchPattern>] [orgunit|org|ou <OrgUnitPath>]
|
|
388
|
-
[fields <SharedDriveFieldNameList>]
|
|
390
|
+
[fields <SharedDriveFieldNameList>]
|
|
391
|
+
[showwebviewlink]
|
|
392
|
+
[formatjson [quotechar <Character>]]
|
|
389
393
|
```
|
|
390
394
|
By default, all Shared Drives are displayed; use the following options to select a subset of Shared Drives:
|
|
391
395
|
* `teamdriveadminquery|query <QueryTeamDrive>` - Use a query to select Shared Drives
|