Integrating Outlook with ServiceNow Using the “Microsoft Exchange Online” Spoke

By Noah Boltik


If your organization uses Outlook, and you're interested in integrating with ServiceNow, the "Microsoft Exchange Online" Spoke might be what you need. While ServiceNow has published this helpful article on the setup process, there are things I've learned that weren't documented and are worth sharing!

BEFORE WE BEGIN

The "Microsoft Exchange Online" Spoke can do more than interact with emails: it can also let you manage Calendars, Webhooks, and Rooms. However, in this article, we're only going to talk about the "Mail" actions. So, we'll skip many optional steps in the official documentation.

YOU WILL NEED

  • A Dev instance – Unfortunately, Personal Developer Instances don’t have access to this plugin, so a proper Dev instance is required. However, your instance doesn’t need a MID server to access Mail actions, despite what the documentation implies.

  • Microsoft Azure Admin account – You’ll need admin access to the Microsoft Azure Portal.

  • Integrationhub rights – To use any Spoke, you’ll need IntegrationHub.

SETTING UP

Installing the Spoke

  • Navigate to “All > System Definition > Plugins”

  • Install the Microsoft Exchange Online Spoke

Registering the Application in Azure

Then “New Registration”

Fill out the form, using the format https://<instance-name>.service-now.com/oauth_redirect.do for the redirect URI

Specifying Permissions

  • Navigate to “API Permissions” on the side nav

Click the “Add a permission” button

Select “Microsoft Graph,” then “Application permissions”

Search “mail” and add the following:

Creating (and recording) the secret

  • Go to “Certificated & secrets,” and click “New client secret”

Remember to copy the secret! This becomes hidden once you navigate away from this page. Don’t make the same mistake I did my first time. If you do, simply create a new secret.

Getting the client and directory IDs

  • Navigate to the “Overview” section, and copy the “client” and “directory” IDs for the next step.

Registering the application in ServiceNow

  • In ServiceNow, navigate to “All > System OAuth > Application Registry”.

If you installed the spoke correctly, there should be an option called “Microsoft Exchange Online”

Use the information from the previous section to fill out the following fields

Client Secret: <This is the secret from step 3>

Client ID: <Client-ID>

Authorization URL: https://login.microsoftonline.com/<Directory-ID>/oauth2/v2.0/authorize

Token URL: https://login.microsoftonline.com/<Directory-ID>/oauth2/v2.0/token

Redirect URL: https://<instance-name>.service-now.com/oauth_redirect.do

  • Submit the record. You should now see a new record called “Microsoft Exchange Online default_profile” in the Oauth Entity Profiles related list.

  • Since we’re only configuring our application for mail basic actions, we don’t need to configure the “Microsoft Exchange Online_clientCredentials” Application Registry.

Creating the Credentials

  • Navigate to “All > Connections & Credentials > Credentials.”

  • Create a new record

  • Fill out the form, selecting the OAuth Entity Profile generated during the last step. Leave everything else default.

Save the record, then press the new “Get OAuth Token.”

You will then be prompted to sign into your Azure account and give mail permissions to ServiceNow.

Creating the connection

  • Almost done. Navigate to “All > Connections & Credentials > Connection & Credential Aliases.”

  • Select the “Microsoft_Exchange_Online” record.

Create a new “Connection” record from the related list.

Fill out the form as follows:

Name: Exchange_Online_Connection

Credential: Exchange_Online_Credentials (The one from the previous step)

Connection URL: https://graph.microsoft.com

Testing in Flow Designer

  • Create a test Flow and add the “Look up mail Folders by User” action.

  • For “User ID”, enter an email address belonging to your organization

Add a trigger condition and test the Flow

Congratulations! You should now be getting your mail info.