Create a Google access_token using a Service Account
What does it do?
In some scenarios, you might want to access Google Admin APIs from your applications. Accessing those APIs require either a consent of the Google Apps administrator or creating a Service Account and obtain a token programmatically without interactive consent. This rule create such token based on a service account and put it under
To create a service account go to Google API Console, create a new Client ID and choose Service Account
You will get the key that you would have to convert to PEM and remove the passphrase using this command
openssl pkcs12 -in yourkey.p12 -out yourkey.pem -nocerts -nodes
Login to Google Apps Admin and go to https://admin.google.com/AdminHome?chromeless=1#OGX:ManageOauthClients (Security -> Advanced Settings -> Manage OAuth Client Access) Enter
Enter the Client ID created on the previous step and the scope you want to allow access to.
KEY: the string representation of the key (open the PEM and replace enters with \n to make it one line).
GOOGLE_CLIENT_ID_EMAIL: this is the email address of the service account created (NOT the Client ID).
SCOPE: the scope you want access to. Full list of scopes https://developers.google.com/admin-sdk/directory/v1/guides/authorizing.
ADMIN_EMAIL: a user of your Google Apps domain that this rule would impersonate.
NOTE: the Google access_token will last 1 hour, so you will have to either force a re-login or use a refresh token to trigger a token refresh on Auth0 and hence the rule running again.
Here's the rule:
How do I use it?
Just create a new rule in the Auth0 dashboard, and copy the following code replacing the placeholders with the appropriate values.
What is Rule-Based Authentication?
Rules can be used to enrich and transform the user profile, deny access to specific users under certain conditions, retrieve information from external services and much more. For more information about rules, please check the documentation