Email API

Aurinko Email API

The Aurinko Email API abstracts away differences between popular email APIs (Gmail, Office 365, Outlook.com, MS Exchange) to make it easy to develop email integrations.

The Aurinko Email API provides a REST interface that focuses on accessing and syncing email messages in a uniform manner.

  • Access data for email messages, such as email content, sender and recipient information, subject lines, dates, and more.
  • Search email inboxes for specific content.
  • Update the unread and flagged status of email messages.
  • Manage and download file attachments.
  • Create drafts and send emails.
  • Incremental synchronization

Email API Endpoints

Email messages

Email messages are the core building block for most email applications. They contain several pieces of information, such as when a message was sent, the sender's address, to whom it was sent, and the message body. They can also contain file attachments, calendar event invitations, and more.

Synchronization

Email sync methods allow developers to implement incremental synchronization of email messages in a uniform manner across different email providers. Aurinko supports requesting updated as well as deleted messages.

Email sync quickstart

Start a new sync

A new sync needs to be provisioned by calling the "sync start" method /messages/sync. The sync covers all email folders (i.e. Inbox, Sent Mail, and sub folders). daysWithin limits the initial scan to emails received in the past daysWithin days.

curl -X POST -H 'Authorization: Bearer <account_access_token>' \
	-G https:/api.aurinko.io/v1/email/sync -d daysWithin=10"

The Aurinko platform will initialize all necessary internal resources and let you know when it's ready to serve data. The response should look like this:

{
    "syncUpdatedToken": "asdfghjklpoiuytrew",
    "syncDeletedToken": "zxcvbnmlkjhgfdsaq",
    "ready": true
}

If the response shows  ready: false call the "sync start" method again. Once the sync is ready you will get delta tokens syncUpdatedTokensyncDeletedToken and can start loading updated and deleted email messages. 

Initial full sync

Initial requests /messages/sync/updated and /messages/sync/deleted are equivalent to a full sync in the specified timeMin,NOW range, plus loading all updated messages (deleted messages) since the sync start. 

curl -X GET -H 'Authorization: Bearer <access token>' \
	-G https:/api.aurinko.io/v1/email/sync/updated \
	-d deltaToken='{syncUpdatedToken}'

Response:

{   
    "nextPageToken": "string",
    "nextDeltaToken": "string",
    "records": [{...}]
}

Continue loading pages using provided 'nextPageToken' until you find another 'nextDeltaToken'.

curl -X GET -H 'Authorization: Bearer <access token>' \
	-G https:/api.aurinko.io/v1/email/sync/updated \
	-d pageToken='{nextPageToken}'
Incremental sync

A new deltaToken (nextDeltaToken in a response) is good for loading email messages that have been modified/deleted since the last sync-updated/sync-deleted request. In cases where a large number of messages have changed since the last incremental sync request, you may find a  nextPageToken instead of a nextDeltaToken in the response. Continue loading pages using provided nextPageToken until you find another nextDeltaToken.

Other examples

Email messages

To get a list of messages from, to, or cc'ing an email address, make a request to the /email/messages endpoint.

curl -X GET -H 'Authorization: Bearer <access token>' \
	-G https:/api.aurinko.io/v1/email/messages \
	-d q="text from:alexey"

To get an email message by id make a request to the /email/messages/{id} endpoint.

curl -X GET -H 'Authorization: Bearer <access token>' \
	https:/api.aurinko.io/v1/email/messages/{id}

Still need help? Contact Us Contact Us