I have recently been part of a project, Building Nomi, where I was able to work on different types of integration tasks. With Building Nomi we were analyzing everyday metadata from the calendar and email to map the cooperation within organizations.
I thought I might share some of the work here. In this post, I will walk through how to set up your google workspace to be able to access email and calendar metadata through API Google API’s.
Steps:
- Create project Building Nomi on your workspace (https://console.cloud.google.com)
- Enable APIs on Project (https://console.cloud.google.com)
- Create a Service Account (https://console.cloud.google.com)
- Assign permissions (https://admin.google.com/)
Create Project for Building Nomi
Go to https://console.cloud.google.com/ and login with an administrative account.
Select Project dropdown (just right of Google Cloud Platform label). Select New Project on the form.
data:image/s3,"s3://crabby-images/93b72/93b7218e0b3593c53e503569eb0ab45bb9a39b88" alt=""
Give a name to Project, e.g., BuildingNomi. Set Organization to the domain you will be accessing. Set the Location of your environment and click Create (it may take a few seconds to complete).
data:image/s3,"s3://crabby-images/8aae4/8aae435e4528ec3b47644b0ee88283753625d251" alt=""
Select and switch to the newly created Project BuildingNomi.
data:image/s3,"s3://crabby-images/b4da8/b4da8a5543706ac5f01ea96325497f4fc9c6c226" alt=""
Enable API’s for Building Nomi to interact with
From the top-left menu, go to APIs & Services -> Dashboard
data:image/s3,"s3://crabby-images/ad063/ad06330b03e037c53c24fe0d7e8cb921ed8a5d22" alt=""
Select ENABLE APIS AND SERVICES
*Note that this step is only to let google know that you want to use your APIS. How to authenticate and access, we’ll get to later.
data:image/s3,"s3://crabby-images/53f39/53f390dcab630c2dc748a9fbbb30214a27b30018" alt=""
Search and Enable the following API’s:
- Admin SDK – API will be used by Building Nomi to retrieve users and groups
- Gmail API – API will be used by Building Nomi to analyze email metadata
- Google Calendar API – API will be used by Building Nomi to analyze calendar metadata
data:image/s3,"s3://crabby-images/3ac6e/3ac6e5305e10965ae1d0671d296a04c4204bbc2a" alt=""
From API’s & Services dashboard, you see enabled APIs. Make sure APIs added in #7 is there.
data:image/s3,"s3://crabby-images/c8a6c/c8a6c4d086632c22e7fc89afb4d1d366edd3a520" alt=""
Create a service account
From top-left menu go to APIs & Services -> Credentials
data:image/s3,"s3://crabby-images/fedff/fedff95c6b187a9877a30f73152d14c366edb2cd" alt=""
Click CREATE CREDENTIALS and select Service account
data:image/s3,"s3://crabby-images/b1d67/b1d67fad0dc4c815e25f00651880f63303ee3b48" alt=""
In step 1, type a Service account name, e.g., BuildingNomi. Also, type a Service account description, e.g., Service account used by Building Nomi. Now click CREATE.
data:image/s3,"s3://crabby-images/7cafe/7cafefdcb328b82952bcbbd82ceaa909052d6d0e" alt=""
In step 2, Select role Basic -> Viewer and click DONE (we skip step 3)
data:image/s3,"s3://crabby-images/18dbd/18dbd73d189f3c4cecce94d6332b0bb2a288fbf4" alt=""
From the top-left menu, go to APIs & Services -> Credentials and click the modify icon for the newly created Service Account.
data:image/s3,"s3://crabby-images/7dd4c/7dd4ccc8f5355ac9671a06742dc5b61cb90b2510" alt=""
On the Service account status section, click SHOW DOMAIN-WIDE DELEGATION and put a checkmark in Enable G Suite domain-wide delegation. Also, type a Product name for the consent screen, e.g., Building Nomi.
data:image/s3,"s3://crabby-images/e9dae/e9daead67cf49e4bfbaf33ae33843c99dcee9b10" alt=""
In the Keys section, click ADD KEY and then Create new key.
data:image/s3,"s3://crabby-images/a2048/a2048577ac7f0e40d09bbcc58277e314cd6fc6d2" alt=""
Create a private key with JSON as a Key type.
data:image/s3,"s3://crabby-images/3099f/3099fae3d5da8ec2200f37f348686dc35d2dfda2" alt=""
A key file with Service Account credentials has been created and downloaded. Store file securely.
data:image/s3,"s3://crabby-images/15dc3/15dc326668fac7f80986ab5159de9a3f7c2255ce" alt=""
On the service account page, click SAVE
data:image/s3,"s3://crabby-images/2eb23/2eb2341901fbd87003ad83cb620073aa6b75d705" alt=""
From the Credentials page in section OAUTH 2.0 Client IDs, copy ClientID to clipboard (to be used in next step)
data:image/s3,"s3://crabby-images/1969c/1969c914f1a0ba128c6ffc132740f2b14e799f56" alt=""
Assign permissions (scopes)
Go to https://admin.google.com/ and go to Security
data:image/s3,"s3://crabby-images/e367c/e367c6ee31dd4ae58b2cc25b635e2fe296664294" alt=""
On the Security page, scroll down to select API Controls
data:image/s3,"s3://crabby-images/177bd/177bd70163d8aa4c6a49be055053866ed45bcee4" alt=""
Click MANAGE DOMAIN-WIDE DELEGATION
data:image/s3,"s3://crabby-images/8e387/8e387911f38789b4106ae89958805410e5a21900" alt=""
Click Add new to add API client
data:image/s3,"s3://crabby-images/170a0/170a0324e24f42e8f163c38a796c4cf5d1abd699" alt=""
Paste the Client ID from the clipboard in the Client ID field. Then add the following permissions (OAuth scopes):
Building Nomi permissions/scopes | Option |
https://www.googleapis.com/auth/admin.directory.user.readonly – Used by Building Nomi to read users https://www.googleapis.com/auth/admin.directory.group.readonly – Used by Building Nomi to read groups https://www.googleapis.com/auth/admin.directory.group.member.readonly – Used by Building Nomi to read group memberships of users | Users and groups (Required) |
https://www.googleapis.com/auth/gmail.metadata – Used by Building Nomi to read Gmail metadata of users | Gmail (Optional) |
https://www.googleapis.com/auth/calendar.readonly – Used by Building Nomi to get user’s primary Google Calendar https://www.googleapis.com/auth/calendar.events.readonly – Used by Building Nomi to read metadata events from a user’s primary Google Calendar | Google Calendar (Optional) |
Instead of copy-pasting all scopes, it’s possible to insert oneliner below:
—
https://www.googleapis.com/auth/admin.directory.user.readonly,https://www.googleapis.com/auth/admin.directory.group.readonly,https://www.googleapis.com/auth/admin.directory.group.member.readonly,https://www.googleapis.com/auth/gmail.metadata,https://www.googleapis.com/auth/calendar.events.readonly,https://www.googleapis.com/auth/calendar.readonly
—
data:image/s3,"s3://crabby-images/9ef57/9ef57209a4ad4180967ab557a1e643cc270733c2" alt=""
You are all set! 🙂