Slack Connector

For a general introduction to our Slack Connector, please refer to RheinInsights Atlassian Confluence Server and Data Center Connector.

Slack Configuration

Crawl User

The connector uses a

  1. bot token or

  2. user token

to authenticate against Slack.

If you configure a bot token for the connector, the bot needs to be added to all channels, which you like to crawl. This gives you a broader flexibility when it comes to private channels. However, it will not by default all public channels. A user token in contrast will allow to crawl all channels the owning user sees to be crawled, optionally including archived channels.

In order to acquire such a user token, please follow the steps below:

  1. Open Slack API: Applications | Slack

  2. Click on “Create a new app”

  3. Choose from Scratch

  4. Add an app name and choose your workspace, which you would like to crawl

  5. Open OAuth & Permissions

    1. On this page browse to scopes and either for Bot Token Scopes or User Token Scopes click on Add an Oauth Scope

    2. Assign the following permissions:

      1. channels:history

      2. channels:read

      3. files:read

      4. remote_files:read

      5. team:read

      6. users:read

      7. users:read.email

      8. groups:read

      9. groups:history

    3. Scroll up and click on Install to <Tenant Id>

    4. Take a note of the User or Bot OAuth Token. This will be used to authenticate the connector against Slack.

Content Source Configuration

The content source configuration of the connector comprises the following mandatory configuration fields.

  1. Token: please add the User or Bot OAuth Token from Step 5.d above.

  2. Root URL: please add your tenant url as https://<tenant>.slack.com
    This will be used for mandatory calculations in the course of the crawl.

  3. Rate limit describes the number of requests per second against the Slack APIs. If this value is chosen as too large, it may cause rate limiting. Please also refer to the Slack API guidelines.

  4. Excluded channels: here you can provide Java regular expressions or channel names to exclude channels from crawling.

  5. Included channels: here you can provide Java regular expressions or channel names to describe channels which should be solely crawled.

  6. The general settings are described at General Crawl Settings and you can leave these with its default values.

After entering the configuration parameters, click on validate. This validates the content crawl configuration directly against the content source. If there are issues when connecting, the validator will indicate these on the page. Otherwise, you can save the configuration and continue with Content Transformation configuration.

Limitations for Incremental Crawls and Recommended Crawl Schedules

Slack does not offer a complete change log. Even though the connector can efficiently detect new messages and attachments, it does not get notified if Slack messages were removed or deleted or updates in threads take place.

Therefore, we recommend to configure incremental crawls to run every 15-30 minutes, principal scans to run twice a day, as well as a weekly full scan to keep the search index in synchronization with the Slack instance. For more information see Crawl Scheduling .