> ## Documentation Index
> Fetch the complete documentation index at: https://nango.dev/docs/llms.txt
> Use this file to discover all available pages before exploring further.

# Slack

> Integrate your application with the Slack API

## 🚀 Quickstart

Connect to Slack with Nango and see data flow in 2 minutes.

<Steps>
  <Step title="Create the integration">
    In Nango ([free signup](https://app.nango.dev)), go to [Integrations](https://app.nango.dev/dev/integrations) -> *Configure New Integration* -> *Slack*.
  </Step>

  <Step title="Authorize Slack">
    Go to [Connections](https://app.nango.dev/dev/connections) -> *Add Test Connection* -> *Authorize*, then log in to Slack. Later, you'll let your users do the same directly from your app.
  </Step>

  <Step title="Call the Slack API">
    Let's make your first request to the Slack API (fetch a list of channels in a Slack team). Replace the placeholders below with your [secret key](https://app.nango.dev/dev/environment-settings), [integration ID](https://app.nango.dev/dev/integrations), and [connection ID](https://app.nango.dev/dev/connections):

    <Tabs>
      <Tab title="cURL">
        ```bash theme={null}
        curl "https://api.nango.dev/proxy/conversations.list?limit=10" \
          -H "Authorization: Bearer <NANGO-SECRET-KEY>" \
          -H "Provider-Config-Key: <INTEGRATION-ID>" \
          -H "Connection-Id: <CONNECTION-ID>"
        ```
      </Tab>

      <Tab title="Node">
        Install Nango's backend SDK with `npm i @nangohq/node`. Then run:

        ```typescript theme={null}
        import { Nango } from '@nangohq/node';

        const nango = new Nango({ secretKey: '<NANGO-SECRET-KEY>' });

        const res = await nango.get({
            endpoint: '/conversations.list',
            params: { limit: 10 },
            providerConfigKey: '<INTEGRATION-ID>',
            connectionId: '<CONNECTION-ID>'
        });

        console.log(res.data);
        ```
      </Tab>
    </Tabs>

    Or fetch credentials with the [Node SDK](/reference/sdks/node#get-a-connection-with-credentials) or [API](/reference/api/connection/get).

    ✅ You're connected! Check the [Logs](https://app.nango.dev/dev/logs) tab in Nango to inspect requests.
  </Step>

  <Step title="Implement Nango in your app">
    Follow our [Auth implementation guide](/guides/primitives/auth) to integrate Nango in your app.

    To obtain your own production credentials, follow the setup guide linked below.
  </Step>
</Steps>

## 📚 Slack Integration Guides

Nango maintained guides for common use cases.

* [How to register your own Slack OAuth app](/api-integrations/slack/how-to-register-your-own-slack-api-oauth-app)\
  Register an OAuth app with Slack and obtain credentials to connect it to Nango

* [How to setup webhooks with Slack on Nango](/api-integrations/slack/webhooks)\
  Set up Slack Events API webhooks to receive real-time workspace events

* [Slack user access tokens in Nango](/api-integrations/slack/slack-user-access-tokens)\
  How to get, and use, Slack user access tokens with Nango

Official docs: [Slack API docs](https://api.slack.com/web)

## 🧩 Pre-built syncs & actions for Slack

Enable them in your dashboard. Extend and customize to fit your needs.

### Channels

| Function name | Description                                                                                | Type                                           | Source code                                                                                                  |
| ------------- | ------------------------------------------------------------------------------------------ | ---------------------------------------------- | ------------------------------------------------------------------------------------------------------------ |
| `channels`    | Sync conversations allowed by granted scopes - public/private channels, DMs, and group DMs | [Sync](/guides/functions/syncs/sync-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/slack/syncs/channels.ts) |

### Messages

| Function name       | Description                                                                                                                                                                       | Type                                           | Source code                                                                                                           |
| ------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------- | --------------------------------------------------------------------------------------------------------------------- |
| `messages-received` | Sync messages, thread replies, and reactions for conversations the bot can access; fully backfill new channels, then resync the last 10 days using channelsLastSyncDate metadata. | [Sync](/guides/functions/syncs/sync-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/slack/syncs/messages-received.ts) |

### Users

| Function name | Description                                                                           | Type                                           | Source code                                                                                               |
| ------------- | ------------------------------------------------------------------------------------- | ---------------------------------------------- | --------------------------------------------------------------------------------------------------------- |
| `users`       | Sync all workspace users including deactivated accounts with email and profile fields | [Sync](/guides/functions/syncs/sync-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/slack/syncs/users.ts) |

### Others

| Function name   | Description                                        | Type                                           | Source code                                                                                                       |
| --------------- | -------------------------------------------------- | ---------------------------------------------- | ----------------------------------------------------------------------------------------------------------------- |
| `conversations` | Sync Slack conversations including channel members | [Sync](/guides/functions/syncs/sync-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/slack/syncs/conversations.ts) |

***
