GSuite Admin API Exporter
Project description
GSuite Exporter
This package handles exporting data from the GSuite Admin APIs to a destination.
The following GSuite Admin APIs are currently supported:
reports_v1
- Reports APIadmin
- Admin activity reportsdrive
- Google Drive activity reportslogin
- Login activity reportsmobile
- Mobile activity reportstoken
- Authorization Token activity reports
The following destinations are currently supported:
Requirements
- A GSuite Admin account
- A service account with:
- GSuite domain-wide delegation enabled.
- The IAM role
roles/iam.tokenCreator
granted to the service account on the project it was created in.
- On the service account's project:
- Enable the
Identity and Access Management (IAM) API
.
- Enable the
- On the destination project:
- Enable the
Admin Reports API
.
- Enable the
Collectors
To collect data from the Admin SDK APIs, you need to grant extra permissions to your service account:
- Go to your Admin Console and login with your GSuite administrator account
- Navigate to
Security > Advanced Settings > Manage API client access
- Grant the following scopes (comma-separated) to your service account's
client_id
:
Exporters
Stackdriver Logging
To use the Stackdriver Logging exporter, you need to grant extra IAM roles to your service account:
roles/logging.viewer
on the destination projectroles/logging.logWriter
on the destination project
Installation
pip install gsuite-exporter
Usage
The GSuite Exporter can be used either using the command-line interface or as a Python library.
Using the CLI
An example sync from the Admin Reports API to Stackdriver Logging for the 'login' application looks like:
gsuite-exporter
--credentials-path='/path/to/service/account/credentials.json'
--admin-user='<your_gsuite_admin>@<your_domain>'
--api='report_v1'
--applications='login drive token'
--project-id='<logging_project>'
--exporter='stackdriver_exporter.StackdriverExporter'
The credentials_path
variable is optional and you can use Application Default Credentials instead.
Using as a library
An example sync from the Admin Reports API to Stackdriver Logging looks like:
from gsuite_exporter.cli import sync_all
sync_all(
credentials_path=/path/to/service/account/credentials.json,
admin_user='<user>@<domain>',
api='reports_v1',
applications=['login', 'drive', 'token'],
project_id='<project-id>',
exporter_class='stackdriver_exporter.StackdriverExporter'
)
More examples are available using the library functions under the examples/ directory.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file gsuite-exporter-0.0.4.tar.gz
.
File metadata
- Download URL: gsuite-exporter-0.0.4.tar.gz
- Upload date:
- Size: 9.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.8.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0f2fd0707e522b06c64d8d780ef40bae04201784331250502e5aeb63114d7761 |
|
MD5 | b140e50275834d97d1bc252a4d3a23b3 |
|
BLAKE2b-256 | 1448e421b917e07753848eb4c05948639556d7d8611cfce2ab42ded47b05e3bf |
File details
Details for the file gsuite_exporter-0.0.4-py3-none-any.whl
.
File metadata
- Download URL: gsuite_exporter-0.0.4-py3-none-any.whl
- Upload date:
- Size: 13.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.8.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b7196b232675308c17a083006627f0320c2504d120a75c70b14b0f47f0d11afe |
|
MD5 | cd0815f48fcc573c7ef3d27a95b151ea |
|
BLAKE2b-256 | 90eb4ce3e1d22796882b5e7e298f0119a4df3c683b8b7234875649be02b054cc |