data:image/s3,"s3://crabby-images/06d6f/06d6fde55b4e48c8cfaa8aced0624d3efee0dfa8" alt="Gmail"
As part of a wider use case involving OIC, ODA and OCI AI Services, I need to be able to get emails. For that I will try out the OIC Google Gmail Adapter.
All about it here.
Pre-Requisites
On the Google side we need to configure a couple of things.
Under your google account go to https://console.developers.google.com/
Choose an existing project or create a new one. Under the option Library, search for Gmail API.
data:image/s3,"s3://crabby-images/d6d55/d6d553c78b11a011652373578837e22c4af7599c" alt=""
data:image/s3,"s3://crabby-images/72a8b/72a8bdc03de09fae5487e0d53b1ad93d8fc75209" alt=""
data:image/s3,"s3://crabby-images/a5303/a53038c1de853649f60c409c124ce4a2de4db8c8" alt=""
Add your callback URL
data:image/s3,"s3://crabby-images/7d336/7d3367bf4127e7bcae6dda1b9e87db2c35569072" alt=""
Create a connection
Pick up the Gmail Adapter from the list and provide a Client ID, Client Secret, and the Scope.
Once that is done Provide Consent, which will finalize the connection. Make sure your user is added in the Gmail OAuth consent list.
data:image/s3,"s3://crabby-images/e470c/e470c0381cffcdd51a91a374a1ec1c6f158aea19" alt=""
This is the list of available scopes:
https://mail.google.com/
https://www.googleapis.com/auth/gmail.compose
https://www.googleapis.com/auth/gmail.metadata
https://www.googleapis.com/auth/gmail.labels
https://www.googleapis.com/auth/gmail.modify
https://www.googleapis.com/auth/gmail.readonly
https://www.googleapis.com/auth/gmail.send
Available Operations:
- Get Thread
- Trash Thread
- List Messages
- Get Message
- Get Message Attachment
- Send Message
- List Drafts
- Create Draft
- Get Draft
- Delete Draft
- Send Draft
- List Labels
- Create Label
- Delete Label
Create an Integration
For this exercise I will simply read the last email. For that we need to call ListMessages, which will retrieve a list of email ids (based on our query parameters) and then with the method GetMessage, we can ready a specific email.
The Integration will be an AppDriven one with a REST trigger that takes no parameters and returns the email body in the response.
Configure Gmail Connection
data:image/s3,"s3://crabby-images/36f45/36f4591a1cd2f3a32251dbfab321fc0401799d74" alt=""
I will choose 3 query parameters.
data:image/s3,"s3://crabby-images/5f6b6/5f6b659536e7d20ebe3328fffc4fa7c03b4a7438" alt=""
Everything will be hardcoded – it’s the fast way 🙂
data:image/s3,"s3://crabby-images/5ecfc/5ecfca87b846801d69a18a9dda7e9bee2059b574" alt=""
maxResults: 1
includeSpamTrash: false
q: from:” danielxxxx@oracle.com”
The above says that I want 1 message back, from the email “danielxxxx@oracle.com:
Add another Gmail Connection – Get Message
Ideally one would get a list of messages and then perform a For-Each and loop over all of those email ids. In this case there is only one id returned, so no need for a loop. We pass that id along to the next method (GetMessage)
data:image/s3,"s3://crabby-images/161c4/161c446fcb4375e08838e34c76c98f5ae0a49809" alt=""
data:image/s3,"s3://crabby-images/d2c43/d2c4331f1463684b99fed00506e9c7fccbe6c9c3" alt=""
This is how the integration looks like.
data:image/s3,"s3://crabby-images/d8e52/d8e52ed8c976c3a1d35aa1cc8cd261caac18f67b" alt=""
The last mapping is the Map to GetLastEmail
data:image/s3,"s3://crabby-images/a2008/a200865ffc15e25468a54900a183f5905492ebb0" alt=""
Test
The test confirms it all, and returns the last email send by my Oracle’s email to my Gmail account!
data:image/s3,"s3://crabby-images/0befe/0befe3b84acc48b6d0b758dbe05de13fd0015c95" alt=""