This article provides installation, configuration, and implementation details when integrating xMatters On-Demand with Slack.
Slack is a popular cloud-based team collaboration tool.
Coupled with the power of xMatters alerts, the integration:
- Lets people know when they are needed to participate in a Slack conversation.
- Quickly identifies and notify on-call members of xMatters groups
- Allows for voice, SMS, and push messages to users.
- Allows users to reply with "Acknowledge" and "Ignore" from their device.
- Allows users to post responses back to Slack channel from their device.
Event injection is initiated when a custom "slash-command" is used in Slack to identify the xMatters groups you want to invite to a channel; for example:
Slack server builds a payload and sends it to the xMatters inbound integration URL configured in Slack's custom slash-command integration.
The integration includes the inbound integration "Inbound from Slack" that handles Slack submissions by notifying the xMatters group with the name that matches the one typed into the Slack channel.
Recipients can respond with "On my way" or "Can't make it". By default, the responses and delivery notifications are posted back to Slack channel.
NOTE: If you prefer not to receive delivery notifications, just disable the Delivery updates outbound integration.
The first step in setting up your integration is to configure xMatters.
To begin, download the communication plan (.zip file) attached to this article; it contains everything needed for this integration. You do NOT need to extract the contents - you can import it directly into xMatters.
This integration requires a user who can authenticate REST web service calls when working with events – these permissions are provided by the "REST Web Service User" role in xMatters.
For Free and Trial customers, your system has an "Integration User" already configured with the REST Web Service User role, so you don't need to burn up an extra user from your limited supply. Make sure you've changed this user's password from the default, then you're good to go.
For everyone else, we recommend you create a user specifically for this integration because this user appears as the initiator or submitter of events from the integration (in messages, the Communication Center, event reports, etc.). Give this user the "REST Web Service User" role and a profile that lets you easily identify the user as specific to the integration – for example:
- User ID: slack
- First name: Slack
- Last name: Integration
Note: Make sure you keep the user ID and password of this user handy. You'll need them when configuring other parts of this integration.
The integration notifies the xMatters group whose name matches the Slack channel. If the group does not exist, the xMatters event will not be created.
For more information about creating users and devices in xMatters, refer to the xMatters On-Demand help.
The next step is to import the communication plan you already downloaded. It contains all of the forms, properties, and integration details you'll need.
To import the communication plan:
- In the target xMatters system, on the Developer tab, click Import Plan.
- Click Choose File, and then locate the downloaded communication plan (.zip file).
- Click Import Plan.
- Once the communication plan has been imported, it should be automatically enabled. If it isn't click Plan Disabled to enable the plan.
- Click the Edit drop-down list for the plan, and select Access Permissions.
- Add the integration user, and then click Save Changes.
- In the Edit drop-down list, select Forms.
- For the Invite to Channel form, in the drop-down list, click the Web UI, Web Service drop-down list, click Sender Permissions.
- Enter the integration user, and then click Save Changes.
You need to make sure the inbound integration is set to use URL authentication, and then retrieve the URLs to configure the app in Slack.
To configure an inbound integration and retrieve its URL:
- In the Integration Builder, expand the list of inbound integrations.
- Click the name of the integration to view its details.
- Scroll down to How to trigger the integration at the bottom of the page, and select the integration user as the authenticating user (make sure the authentication method is set to URL authentication). The URL trigger is updated to reflect the new user.
- To be able to select the integration user, you need to be a supervisor of that user and the user needs to be assigned to the REST Web Services role.
- Click Copy beside the field:
You'll need the URL for the inbound integration service when configuring Slack.
Now that you've configured xMatters, you can configure Slack to integrate with xMatters.
Slack uses Slash Commands to initiate the xMatters events when assistance is required from an on-call group.
- Log into Slack and access the App Directory.
- The easiest way to do this is to click the arrow beside your Slack domain and select Customize Slack. A page to customize Slack opens in your browser. From there, click Configure Apps.
- Under Manage, click Custom Integrations then select Slash Commands.
- You can also use the search box at the top of the page to find the Slash Commands integration option.
- Provide a name for the Slash command, for example /xMatters, then click Add Slash Command Integration:
- Scroll down to the Integration Settings and set the value of the URL field to the inbound integration URL, and then save the integration.
To test the integration, enter the slash command you created into a Slack channel following by a space delimited list of groups you want to notify.
To invite the on-call members of the DBA and Operations groups to the current channel in Slack, enter the following command.
/xmatters DBA Operations
When troubleshooting why an event doesn't seem to make it over to xMatters, the best place to look is the Integration Builder Activity Stream. While on the Integration Builder tab, click the gear icon beside an integration service, and then click Activity Stream.
The Activity Stream contains the incoming (and for outbound integrations, the outgoing) request, any logging statements as well as the final event creation messages.
Integration Builder endpoints can now be configured to use Slack authentication. If you want to change the imported default endpoint to use the Slack authentication type, you will also need to update the outbound integration scripts.
To update the endpoint:
- In xMatters, navigate to the Integration Builder for the Slack communication plan, and click Edit Endpoints.
- Click the Slack endpoint, and then, in the Authentication drop-down list, select Slack.
- Click Connect.
- A new browser window will open to slack.com to authorize access to your Slack account. (Make sure your browser allows popups for this step.)
- Select or sign into the Slack team that you want to allow xMatters to access.
- Click Authorize.
- In the Integration Builder, expand the list of outbound integrations and then click Delivery updates.
- In the "Transform the content" section, click Edit Script.
- Locate the following line:
var slackPath = slackWebHookURL.substring(slackWebHookURL.indexOf(".com") + 4);
- Replace the above line with the following code:
var slackPath = 'chat.postMessage?token=' + http.authenticate( 'Slack' ) + '&channel=' + callback.eventProperties.channel_name + '&text=' + encodeURI( JSON.stringify( payload.text ) );
- Click Save.
- Repeat steps 7 through 10 for the Response updates outbound integration.