We know there's a lot to learn and read about all the integration points of the Slack platform. So, here's a few quick tips.
Anything else on your mind? Let us know by leaving us feedback!
You can provision sandbox environments by joining the Slack Developer Program. Once you're ready to deploy your app, distributing the app will allow you to install it in other workspaces.
Start by building a Slack app to contain all of your work — by default, it can only be installed on your own workspace. Follow the UI instructions to add features — most require that you provide a HTTP server Slack can reach.
For information about developer sandboxes for automations, go here.
Of course we want Slack to be fully functional for users and developers at all times. Here are some tips in the unfortunate event you're having trouble and need to determine the cause of a Slack-related issue.
When possible, we report current status promptly on status.slack.com with any service disruption advisories, but you can also use the following methods:
https://slack.com/api/api.test
API method. A HTTP 200 application/json
response of {"ok":true}
indicates at least part of the Slack Web API is available.https://slack.com/api/auth.test
using a bot, user, or legacy token. Using this method exercises the authorization and API layer further than api.test
and may grant you the serenity of greater confidence in Slack availability.rtm.connect
to generate a WebSocket URL using a token with the proper permissions, then open the socket using a tool like this browser-based WebSocket client for Google Chrome.Still unsure if Slack is down? Contact our enthusiastic support team.
Check if there is an app for a third-party service in the Slack App Directory. If all else fails, you'll need to code one for yourself.
You can also add connector functions to your automation workflows. A growing library of third-party services are available.
When working with Slack apps or Web API, you'll often need to send access tokens, also known as bearer tokens, along with inbound requests within the authorization header. When creating an app for the first time, you'll be given your own user and bot token while going through the app creation process. In order to obtain other users' tokens you'll need to send users through the OAuth 2.0 authentication flow. When you're working with Slack apps, you'll be awarded access tokens after a user approves your application.
Your incoming webhooks URLs are unique to your integration or application and do not require token-based authentication. Slash command response URLs also already encode your integration or application's identity.
Use the signing secret to compute a signature, and verify that the signature on the request matches. This process is strongly preferred over the use of deprecated verification tokens.
You can also use Mutual TLS. Mutual TLS verifies the identity of Slack in a TLS-terminating server, before a request reaches your application code.
When you configure Outgoing webhooks, Slash commands and Message buttons, you specify a URL for Slack to send requests when qualifying conditions are met. Slack also provides you a token related to that integration.
Slack sends that URL a JSON payload containing a token
field. Compare that field to values you've received from Slack. Refer to validating slash commands for more information.
Authorization codes must be exchanged for an access token within 10 minutes by calling oauth.access as part of the authorization flow. Otherwise, the authorization code will expire and you will need to ask the user to go through OAuth again.
Use the apps.uninstall
method to uninstall an app completely, revoking all tokens. If you want to dispose of a single OAuth access token, use auth.revoke
; it works with tokens from Sign in with Slack as well as from Add to Slack.
For legacy classic Slack apps, revoking the last token associated between your application and a workspace effectively uninstalls the app for that workspace.
Members and administrators can remove your app through their workspace administration interface.
Though it's somewhat of a nuclear option, you also have the ability to revoke all tokens from your developer dashboard by selecting your application and clicking the Revoke all tokens button found there.
To reset your client secret, go to your developer dashboard, select the application you are concerned about, and click the Change secret button.
Don't forget to use your new secret when exchanging authorization codes for access tokens while authorizing users and workspaces with OAuth 2.0.
Building a non-workflow Slack app? Start here. Building a workflow for automation? Start here.
What's the difference? Check out this video for a quick introduction to the new workflow-based Slack Platform:
When you install Slack App that contains a bot user, you're awarded a bot user token. This token is used for performing certain actions directly as the bot user, such as posting a message or uploading a file. You can only call Web API methods based on the scopes you've negotiated. A quick way to call an API method is to head to its page here and find the tester tab. Here's an example for the chat.postMessage
method.
Typically, if Slack cannot reach your slash command URL it's because it's inaccessible, does not have a valid and verifiable SSL certificate, or our request is timing out for some reason.
Slack invokes slash command URLs from its servers rather than from a Slack client app like Slack for Mac. This means that the URL we're trying to reach must be accessible to Slack's servers.
To determine whether your certificate is valid, consider using this tool provided by SSL Labs.
Keep track of the validation tokens and team IDs Slack gives you when commands are created and teams approve your app. Always validate that the token
field in an incoming slash command request has been issued to you by Slack, and scope your data for that workspace.
You won't be able to override any of these fields when using an incoming webhook attached to a Slack app. Instead, those values will be provided from your Slack app configuration and any configuration provided by the team.
No, SSL certificates must be signed by a reputable certificate authority.
You may want to consider using one of the following low-cost providers:
Yes, the Web API accepts both application/x-www-form-urlencoded
POSTs as well as application/json
.
Refer to POST bodies for more information.
Please see our Rate limiting guide for specific information on rate limits.
Please see our Working with files guide for specific information on working with files.
There are currently no methods to directly look up channels by name. Use conversations.list
to retrieve a list of channels. The list includes each channel's name
and id
fields.
Many developers keep the list of channels in memory for swifter lookups. Poll the method occasionally to refresh your inventory or keep keep it updated with the Events API.
You can use similar instructions to the question above, or you can use the conversations.info
method to obtain a specific channel's information, including its name
.
Channel IDs remain the same even when names are changed.
As of September 2018, channel IDs remain static even when a channel is converted between public and private.
Use the Conversations API to safely work with channels that have transitioned between public and private.
Use conversations.history
and a token with the channels:history
scope to retrieve a specific message in a public channel. Learn more about this approach.
If your app's subscriptions are disabled due to exceeding Events API failure limits, manually re-enable them by visiting your application's settings. If your app is part of the directory, use your Live App Settings instead of your development app.
Choose the Events API if:
Choose Socket Mode if:
Finally, choose the Real Time Messaging API only if:
user_typing
events is important for your app or bot user's sense of self and agency.The answer depends on whether you're using the Events API with or without the RTM API:
active
while connected to a WebSocket.Therefore, the presence of the bot depends on whether you are using the RTM API (the bot is online when it's connected through the WebSocket), or it's always online when you turn this setting on. Refer to bot presence for more information.
Socket Mode allows you to use the Events API and interactive features of the platform — without exposing a static HTTP endpoint to receive payloads. Instead, you use the WebSocket Protocol and generate a URL at runtime.
The Real Time Messaging (RTM) API is another way of connecting your application to Slack. For most applications that can't use a static HTTP endpoint, Socket Mode is preferred over RTM.
For most applications, Socket Mode is a better way to communicate with Slack.
The first step is making a typical HTTP request to the rtm.connect
method. Within that response, you'll find a url
field beginning with the URI protocol wss://
. Then, use a Websocket client to open a long-lived connection to that time-sensitive URL. While the connection is open, you'll be streamed events associated with the workspace you're connecting on behalf of and can in turn send messages.
Typical HTTP client libraries and tools do not support connecting to WebSockets directly. You will need to find a client library for your preferred programming environment.
Please see the following guide: App Directory review guide.
If you need to update your approved app to request new OAuth scopes, or to include new features, find your application's settings page at https://api.slack.com/apps. Any changes you make here will not affect the published app.
Once you're ready to apply these changes to the published app, resubmit it for review
If you've submitted your app to the directory but need to make changes to how your app or bot is described, to the integration types packed into your app, or to request additional permissions, you'll need your app to be reviewed again.
Use the beta application corresponding to your submitted Slack app to make modifications to any of these features, such as:
Your client secret and signing secret may be regenerated as needed, without requesting further review.
No, only submit your app to the directory if you want your app to be discoverable and installable from the App Directory. If you don't submit your app, we won't display it there, but it will be installable by any workspace you give the authorization URL to.
rtm.connect
to initiate your WebSocket connection instead of rtm.start
. rtm.connect
returns just the data you need to open your connection.rtm.start
, use the no_latest
parameter to remove the latest
field from each channel object.channels.list
, use the exclude_members
parameter to trim long membership lists from each channel object.team_id
, not workspace_id
? Our bad. We used to overuse the term team which could mean two different things — the people you talk to, as well as the Slack workspace, the place you do work!
Now we use workspace for all the Slack workspaces; however our API remains the same as before. Wherever you see some objects containing team_id
, it really is an ID for the workspace! In the API world, we use the two terms interchangeably.
There are some community-authored open source tools that provide an IRC-like experience on top of Slack APIs. Although they are not directly supported or built by Slack, you can leverage these resources to build your own tools:
We have a quickstart that will guide you through the process! Check it out!
Building your own gateway for personal use is an undertaking.
The part of the gateway that reads from Slack should either connect to the RTM API over a WebSocket or listen for events using the Events API. Use the Web API to post messages and perform channel operations. The XMPP or IRC part of the gateway is its own adventure to explore.
Choose the token type that works best for you. Bot user tokens work well if your user is a bot but poorly if your user is you. Properly scoped user tokens work best, as they model your own relationship to Slack. The client
scope is useful but overly broad and not suitable for an app distributed on the App Directory. Using your user token to post as yourself when posting messages with chat.postMessage
is best.
Apps operating as a gateway should never distribute their API keys, secrets, or tokens. Refer to these open source CLI apps for some inspiration.
While you cannot add a single workflow to multiple channels, you can download a workflow file and then import it into Slack and update the channel in which it triggers in. To download a workflow file, within the Workflow Builder, click on the three dots beside the workflow you would like to download and click "Download workflow file".
No, at the moment it isn't possible to have conditionals within a Workflow.
The best way to to reset the Outlook Calendar app is to start fresh by removing and re-adding your Outlook Calendar authorization. Here are the steps to do that: