Skip to main content
This feature is currently in public beta, please contact us at [email protected] to enable it for your organization.
The Slack chat integration lets your application send notifications directly to your subscribers’ Slack workspaces using their own Slack accounts and workspace permissions. With this integration, Novu can deliver messages to Slack channels, direct messages (DMs) to Slack users, and incoming webhooks. For incoming webhooks, Novu can use Slack’s native channel picker during OAuth. Novu handles the full lifecycle of Slack connections and message delivery. You define where notifications should be delivered, and Novu automatically routes each message to the correct Slack workspace, channel, or user. This guide walks you through setting up Slack chat, connect workspaces, and deliver notifications to the exact Slack destinations your users expect it.
Check out the agents documentation for more information on how to build agents using Slack.

Configure a Slack app

Before integrating Slack chat with Novu, you must create and configure a Slack app. The Slack app manages the OAuth permissions, bot token scopes, and redirect URLs needed for Novu to connect to your users’ workspaces securely.

Create a Slack app

First, you need to create a Slack app. This provides you with the credential you need to create a Slack integration in Novu.
1

Open the Slack API dashboard

2

Create an app

Click Create an App.
3

Select From scratch

Select From scratch.
4

Enter app name and workspace

Enter an app name of your choice in the App Name field. Pick a Slack workspace to develop your app in.Create app
5

Create the app

Click Create App. You’ll be directed to the Basic Application for the Slack app which contains the credentials you need for configuring Slack chat inside Novu:
  • App ID
  • Client ID
  • Client Secret Basic application

Configure scopes (Permissions)

Your app needs permission to perform actions like sending messages or reading channel lists.
1

Open OAuth & Permissions

In the sidebar, select OAuth & Permissions.
2

Open Scopes

Scroll down to the Scopes section.
3

Add an OAuth Scope

Under Bot Token Scopes, click Add an OAuth Scope.Add an OAuth Scope
4

Add recommended scopes

Add the following recommended scopes:
  • chat:write
  • chat:write.public
  • channels:read
  • groups:read
  • users:read
  • users:read.email
  • (optional) incoming-webhook if you want Slack’s built-in channel picker.
These scopes are required for Novu to send messages, read channels and read users (for DMs and pickers). If you remove some of them, then certain features like channel or user selection might not work.

Set the redirect URL

This tells Slack where to send the user after they successfully authorize your app.
1

Open OAuth & Permissions

In the sidebar, select OAuth & Permissions.
2

Open Redirect URLs

Scroll down to the Redirect URLs section.
3

Add a redirect URL

Click Add New Redirect URL.Add New Redirect URL
4

Paste the Novu callback URL

Paste the Novu OAuth callback URL. Add the redirect URL that matches your Novu region:
https://api.novu.co/v1/integrations/chat/oauth/callback
5

Save the URLs

Click Add to save the URLs. If you use a self-hosted Novu instance, then add your instance’s callback URL instead.

Configure Slack integration in Novu

Once your Slack app is set up, the next step is to configure the Slack Chat integration inside Novu.
1

Log in to the Novu dashboard

Log in to the Novu dashboard.
2

Open Integrations Store

In the sidebar, click Integrations Store.
3

Connect a provider

Click Connect Provider
4

Select Slack

Select Chat and click Slack.
5

Fill in credentials

Fill in the required fields using the credentials from your Slack app:
  • Application Id: Paste your Slack app App ID.
  • Client ID: Paste your Slack App Client ID.
  • Client Secret: Paste your Slack App Client Secret.
  • Redirect URL (Optional): Enter the URL where you want users to be redirected to after they successfully connect their workspace. If there is no redirect URL, then Novu closes the tab immediately after the OAuth flow completes. Connect slack integration in Novu
6

Create the integration

Click Create Integration to create the Slack integration. Once saved, Novu is able to:
  • Generate OAuth (Connect Slack) URLs for your users
  • Receive Slack’s OAuth callback.
  • Store workspace tokens as connections.
You are now ready to implement the frontend flow to let users connect their workspaces.

Let users connect their Slack workspace

To send messages to Slack, your users must first authorize Novu to access one of their Slack workspaces. This authorization happens through Slack’s OAuth flow, which Novu generates and manages for you.

Generate the OAuth URL

When a user clicks Connect Slack in your application, your backend should request a unique authorization URL from Novu. This URL is specific to the Subscriber or the Context (Tenant) it will be generated for.
The generated OAuth URL is valid for only 5 minutes. Do not cache this URL; generate it dynamically when the user initiates the flow.
import { Novu } from '@novu/api'; 

const novu = new Novu({ secretKey: "<YOUR_SECRET_KEY_HERE>", });

// This function should be called by your API when the user requests to connect
async function getSlackUrl(user, orgId) {
  
  const oauthUrl = await novu.integrations.generateChatOAuthUrl({
    integrationIdentifier: 'slack',
    subscriberId: user.id,           // The ID of the user performing the action
    context: { tenant: orgId },      // The tenant/workspace context
  });

  return oauthUrl;
}
Your application can support multiple Slack workspace connections per user or per tenant by triggering separate OAuth flows. Novu allows one connection per (integration + subscriber + context). To connect multiple workspaces, provide different combinations of subscriber or context.

Redirect the user

Once your backend returns the oauthUrl, open it in a new tab or window.
window.open(oauthUrl, '_blank');
Slack then guides the user through:
1

Review permissions

Reviewing your app’s requested permissions
2

Approve authorization

Approving the authorization
3

Redirect to Novu

Redirecting back to Novu’s callback URL
After the user approves access, Novu handles the rest of the OAuth flow automatically.
1

Novu exchanges the code

Novu exchanges the code for a Slack token.
2

Novu creates a connection

Novu creates a Slack connection for that workspace, it is referenced by connectionIdentifier when creating endpoints.You can also provider a custom connectionIdentifier to the generateChatOAuthUrl() and then connection with such identifier will be created instead of randomly generated one.

Choose delivery destinations

After a workspace is connected, you or users decide where in Slack to send the messages. This can either be a Slack channel, to a user or an incoming webhook URLs. After the delivery location has been selected, a Slack endpoint is then created for that location.
This is the typical flow for sending notifications to public or private channels.
1

Get the channel ID

Get the channel ID: First, the channel where the message will be sent to must be selected, one way to do this is by using your Slack app token to list channels in your own UI.
curl -X GET "https://slack.com/api/conversations.list" \
  -H "Authorization: Bearer <YOUR_BOT_TOKEN>"
To learn more about using Slack conversations API to either get public or private channels, refer Slack documentation.
2

Create the endpoint

Create the endpoint: Once the user selects a channel, save it as an endpoint in Novu.
await novu.channelEndpoints.create({
  subscriberId: 'user-123',
  integrationIdentifier: 'slack',
  connectionIdentifier: 'conn_slack_acme', // The identifier of the connection created in Step 2
  context: { tenant: 'acme' },
  type: 'slack_channel',                   // TYPE: Channel
  endpoint: {
    channelId: 'C012345'                   // Slack channel ID of the channel selected by the user
  }
});

Send notifications

Once you have at least one Slack connection, and one or more Slack endpoints. You can trigger the workflow:
import { Novu } from '@novu/api';

const novu = new Novu({ secretKey: "<YOUR_SECRET_KEY_HERE>", });

await novu.trigger({
  name: 'order-shipped',
  to: {
    subscriberId: 'user-123',
  },
  context: { tenant: 'acme' },       // optional routing context
  payload: {
    orderNumber: 'ORD-12345',
    trackingUrl: 'https://acme.com/track/123',
  },
});
When the workflow is triggered, Novu will:
1

Find Slack endpoints

Find Slack endpoints matching subscriberId and context.
2

Use the workspace connection

Use the right Slack workspace connection.
3

Deliver messages

Deliver messages to the configured destinations.