xMatters
xMatters is an on-call management platform. By integrating xMatters with Cortex, you can drive insights into your on-call rotations and trigger incidents directly.
Setup and configuration
Configuration
To connect Cortex to your xMatters instance, you’ll need to add your username, password, and host under xMatters settings in Cortex.
- Username: Username for your xMatters account.
- Password: Password for your xMatters account.
- Organization slug: Slug for your xMatters instance. Can be found in the URL for your instance (e.g.
https://{organization_slug}.xmatters.com
).- Only enter the slug, not the entire URL for your instance.
If you do not see the settings page you're looking for, you may not have permission to access that page. Please contact your admin for assistance.
If you’ve set everything up correctly, you’ll see the option to Remove Integration in settings.
You can also use the Test configuration button to confirm that the configuration was successful. If your configuration is valid, you’ll see a banner that says “Configuration is valid. If you see issues, please see documentation or reach out to Cortex support.”
Registration
Discovery
By default, Cortex will use the entity tag (e.g. my-entity
) as the "best guess" for xMatters group. For example, if your entity tag is my-entity
, then the corresponding group in xMatters should also be my-entity
.
If your xMatters group don’t cleanly match the Cortex entity tag, you can override this in the Cortex entity descriptor.
Entity descriptor
If you need to override automatic discovery, you can define the following block in your Cortex entity descriptor.
x-cortex-oncall:
xmatters:
id: engineering_group
type: SERVICE
Field | Description | Required |
---|---|---|
id | Name of the group in xMatters | ✓ |
type | SERVICE | ✓ |
Expected results
Entity pages
Once the integration with xMatters is configured, you'll be able to find the user or team on call in the Current On-call block on an entity's details page.
Integrations - On-call
You can find more detailed information from the xMatters integration on the On-call page under the Integrations tab.
The schedule associated with a given entity will be hyperlinked in the Escalation Policy block and the group will be hyperlinked in the Service block.
Under the Escalations section, you'll find each level associated with the policy. Owners assigned to each level will also be hyperlinked to the user or team's on-call page in xMatters.
Scorecards and CQL
With the xMatters integration, you can create Scorecard rules and write CQL queries based on xMatters services.
See more examples in the CQL Explorer in Cortex.
Check if on-call is set
Check if entity has a registered group.
Definition: oncall (==/!=) null
Example
For a Scorecard focused an production readiness, you can use this expression to make sure on-call is defined for entities:
oncall != null
This rule will pass if an entity has an on-call schedule set.
Number of escalations
Number of escalation tiers in escalation policy.
Definition: oncall.numOfEscalations()
Example
This expression could be used in a Scorecard focused on production readiness or service maturity. For example, you can check that there are at least two tiers in an escalation policy for a given entity, so that if the first on-call does not ack, there is a backup:
oncall.numOfEscalations() >= 2
While making sure an on-call policy set is a rule that would be defined in a Scorecard's first level, a rule focused on escalation tiers would make more sense in a higher level.
On-call metadata
On-call metadata, including type, ID, and name.
Definition: oncall.details()
Example
You can use this expression in the Query builder to find all entities with an on-call rotation associated with a given group. Let's say we want to find all entities that the "Sample team" is on-call for.
oncall.details().id.matches("Sample*") == true
Because the team/group name is registered in the ID
field in the entity descriptor, we would use .id
instead of .name
.
Triggering incidents
With the xMatters integration, you’ll also have the ability to trigger incidents from the On-call page under Integrations.
When you click Trugger incident, a modal where open where you can enter information about the incident: title, details, urgency, and associated email address. The incident will then be triggered directly in xMatters.
Still need help?
The following are all the ways to get assistance from our customer engineering team. Please use the option that is best for your users:
- Email: help@cortex.io, or open a support ticket in the in app Resource Center
- Chat: Available in the Resource Center
- Slack: Users with a connected Slack channel will have a workflow added to their account. From here, you can either @CortexTechnicalSupport or add a
:ticket:
reaction to a question in Slack, and the team will respond directly.
Don’t have a Slack channel? Talk with your customer success manager.