Incoming Webhooks

Incoming webhooks allow external applications to post messages into Mattermost channels and direct messages. They are a simple way to receive notifications and data from other services in real-time.

You can create an incoming webhook in Mattermost, which generates a unique URL. External systems send HTTP POST requests to that URL with a JSON payload containing the message text and optional formatting (attachments, images, links, etc.). Messages are created under the webhook’s configured user (typically the creator). Username/icon can be overridden in the payload.

For example, your monitoring tool detects high CPU usage and sends an alert message directly into your #devops-alerts channel. All webhook posts will display a BOT indicator next to the username in Mattermost clients to help prevent against phishing attacks.

Create

  1. In Mattermost, go to Product Menu > Integrations. If you don’t have the Integrations option, incoming webhooks may not be enabled on your Mattermost server or may be disabled for non-admins. A System Admin can enable them from System Console > Integrations > Integration Management.

Mattermost menu options showing the ability to work with integrations.
  1. From the Integrations page, select Incoming Webhooks.

Dialog box showing the option to add an incoming webhook.
  1. Select Add Incoming Webhook.

Dialog box showing the option to add an incoming webhook.
  1. Enter a name and description for the webhook, and then select the channel. You can optionally limit bot posts to a specific channel by selecting Lock to this channel, or you can allow the webhook to post to any public channel or private channel the incoming webhook creator is a member of. Select Save.

Dialog box showing the incoming webhook details.

5. Select Done to confirm. Mattermost generates a unique webhook URL, which will look something like this: https://your-mattermost-server.com/hooks/xxx-generatedkey-xxx. Treat this URL as a secret. Anyone who has it will be able to post messages to your Mattermost instance.

Dialog box showing the incoming webhook URL.

Use

To post a message, your application needs to send an HTTP POST request to the webhook URL with a JSON payload in the request body.

curl -i -X POST -H 'Content-Type: application/json' -d '{"text": "Hello, this is some text\nThis is more text. :tada:"}' https://your-mattermost-server.com/hooks/xxx-generatedkey-xxx

A successful request will receive an HTTP 200 response with ok in the response body.

For compatibility with Slack incoming webhooks, if no Content-Type header is set, the request body must be prefixed with payload=.

Post examples

Here are some examples of simple messages posted using incoming webhooks:

Example of a GitHub notification posted to Mattermost using an incoming webhook. Example of a Jira notification posted to Mattermost using an incoming webhook. Example of a Mattermost notification posted to Mattermost using an incoming webhook. Example of a Fastlane notification posted to Mattermost using an incoming webhook. Example of a Weblate notification posted to Mattermost using an incoming webhook.

Parameters

The JSON payload can contain the following parameters:

Parameter

Required

Description

text

Yes (if attachments is not set)

Markdown-formatted message. Use @<username>, @channel, and @here for notifications.

channel

No

Overrides the default channel. Use the channel’s name (e.g., town-square), not the display name. Use @<username> to send a Direct Message. The webhook can post to any public channel, and any private channel the creator is a member of.

username

No

Overrides the default username. The Enable integrations to override usernames setting must be enabled.

icon_url

No

Overrides the default profile picture URL. The Enable integrations to override profile picture icons setting must be enabled.

icon_emoji

No

Overrides the icon_url with an emoji. Use the emoji name (e.g., :tada:). The Enable integrations to override profile picture icons setting must be enabled.

attachments

Yes (if text is not set)

An array of message attachment objects for richer formatting.

type

No

Sets the post type, mainly for use by plugins. If set, must begin with custom_.

props

No

A JSON object for storing metadata. The card property can be used to display extra Markdown-formatted text in the post’s info panel (RHS). This is available in Mattermost v5.14 and later, and is not yet supported on mobile.

priority

No

Sets the priority of the message. See message priorities.

Example with Parameters

{
  "channel": "town-square",
  "username": "test-automation",
  "icon_url": "https://mattermost.com/wp-content/uploads/2022/02/icon.png",
  "text": "#### Test results for July 27th, 2017\n@channel please review failed tests.\n\n| Component  | Tests Run   | Tests Failed                                   |\n|:-----------|:-----------:|:-----------------------------------------------|\n| Server     | 948         | :white_check_mark: 0                           |\n| Web Client | 123         | :warning: 2 [(see details)](https://linktologs) |\n| iOS Client | 78          | :warning: 3 [(see details)](https://linktologs) |"
}

This renders as:

Example of a webhook post with a custom username, icon, and formatted text.

Example with Card Prop

Using the card property inside props will display an info icon on the post. Clicking the icon opens the right-hand sidebar to display the content.

{
  "channel": "town-square",
  "username": "Winning-bot",
  "text": "#### We won a new deal!",
  "props": {
    "card": "Salesforce Opportunity Information:\n\n [Opportunity Name](https://salesforce.com/OPPORTUNITY_ID)\n\n-Salesperson: **Bob McKnight** \n\n Amount: **$300,020.00**"
  }
}
Example of a post with a card property displaying more information in the sidebar.

Slack Compatibility

Mattermost provides compatibility with Slack’s webhook format to make migration easier.

Translating Slack’s Data Format

Mattermost automatically translates JSON payloads from Slack format:

  • <https://mattermost.com/> is rendered as a link.

  • <https://mattermost.com/|Click here> is rendered as linked text.

  • <userid> triggers a user mention.

  • <!channel>, <!here>, or <!all> trigger channel-wide mentions.

You can also send a direct message by overriding the channel name with @username, e.g., "channel": "@jim".

Using Mattermost Webhooks in GitLab

You can use GitLab’s built-in Slack integration to send notifications to Mattermost:

  1. In GitLab, go to Settings > Services and select Slack.

  2. Paste the Mattermost incoming webhook URL.

  3. Optionally, set a Username. Leave the Channel field blank.

  4. Select Save and test the integration.

Known Slack Compatibility Issues

  • Referencing channels using <#CHANNEL_ID> is not supported.

  • <!everyone> and <!group> are not supported.

  • *bold* formatting is not supported; use **bold** instead.

  • Webhooks cannot send a direct message to the user who created the webhook.

Troubleshooting

To debug incoming webhooks, a System Admin can enable Webhook Debugging and set the Console Log Level to DEBUG in System Console > Logging.

Common error messages include:

  • Couldn’t find the channel: The channel specified in the channel parameter does not exist.

  • Couldn’t find the user: The user specified does not exist.

  • Unable to parse incoming data: The JSON payload is malformed.

If your integration posts the JSON payload as plain text instead of a rendered message, ensure the request includes the Content-Type: application/json header.

Do More with Incoming Webhooks

Transform basic message posts into rich, interactive notifications by including buttons, menus, and other interactive elements in your webhook messages, making them more engaging and useful for your team.

  • Message Attachments: Present rich, structured summaries such as status, priority, fields, links, or images for faster triage and comprehension. (Slack‑compatible schema.)

  • Interactive Messages: Make notifications actionable with buttons or menus such as Acknowledge, Assign, or Escalate that enable an immediate user response without switching tools or context.

  • Interactive Dialogs: Guide users to successful outcomes when interactions need structured input or confirmation (for example, “Acknowledge with note” or “Assign to user”). Improve data quality with required fields, minimum/maximum input lengths, server‑driven user/channel pickers, validated defaults, inline field errors, placeholders, and help text that help users enter the right data the first time.

  • Message Priority: Set priority to elevate critical posts and optionally request acknowledgements or persistent notifications.

Tip

  • Need a dedicated identity, permissions scoping, or need to post outside of webhook/command flows? Use a bot account if you need a more permanent solution than using overrides for simple branding.

  • If your system later needs to call Mattermost APIs (e.g., post follow-ups, open dialogs), authenticate with a bot user personal access token. We recommend avoiding human/System Admin personal access tokens for automations and rotating and storing tokens securely.