Bot Framework v4 echo bot using Slack Adapter sample.
This bot has been created using Bot Framework, it shows how to create a simple echo bot that connects with Slack to respond messages.
- .NET Core SDK version 3.1
- ngrok or equivalent tunnelling solution
- Access to a Slack workspace with sufficient permissions to login to create / manage applications at https://api.slack.com/apps. If you do not have access to a Slack environment you can create a workspace for free at https://www.slack.com
-
Clone the repository
git clone https://github.com/Microsoft/BotBuilder-Samples.git
-
Log into Slack and then go to create a Slack application channel.
-
Click the 'Create new app' button.
-
Enter an App Name and select a Development Slack Team. If you are not already a member of a Development Slack Team, create or join one.
-
Click Create App. Slack will create your app and generate a Client ID and Client Secret.
Once your app has been created, you need to collect some information that will be needed by your bot to connect to Slack.
-
Note the 'Verification Token' and the 'Signing Secret' from the Basic Information tab and keep them for later when we configure our bot settings.
-
Navigate to the Install App page under the 'Settings' menu and follow the instructions to install your app into a Slack team.
Here you need to add at least one permission scope. Click the 'permission scope' link, scroll down to the Scopes section and click on the 'Add an Oauth Scope' button under Bot Token Scopes. Select thechat:write
scope.
Once installed, copy the 'Bot User OAuth Access Token' and, again, keep this for later when we configure out bot settings.
Add the 3 settings shown below to your appsettings.json
file in your bot project, populating each one with the values gathered earlier when creating your Slack app.
"SlackVerificationToken": "",
"SlackBotToken": "",
"SlackClientSigningSecret": ""
Now that you have created a Slack app and wired up the adapter in your bot project, the final step is to point the Slack app to the correct endpoint on your bot and subscribe your app to ensure your bot receives messages. To do this your bot must be running, so that Slack can verify the URL to the endpoint is valid.
Run the bot from a terminal or from Visual Studio:
A) From a terminal, navigate to samples/csharp_dotnetcore/60.slack-adapter
# run the bot
dotnet run
B) Or from Visual Studio
- Launch Visual Studio
- File -> Open -> Project/Solution
- Navigate to
samples/csharp_dotnetcore/60.slack-adapter
folder - Select
SlackAdapterBot.csproj
file - Press F5 to run the project
Next, you can use a tool such as Ngrok (which you will likely already have installed if you have used the Bot Framework emulator previously) to tunnel through to your bot running locally and provide you with a publicly accessible URL for this.
Use the following command in a terminal window.
ngrok.exe http 3978 -host-header="localhost:3978"
Navigate back to the Slack api dashboard and select your app. You now need to configure 2 URLs for your app and subscribe to the appropriate events.
-
In the Oauth & Permissions tab, the 'Redirect URL' should be your bots url, plus the 'api/slack' endpoint you specified in your newly created controller. e.g. https://xxxxx.ngrok.io/api/slack
-
In the Event Subscriptions tab, fill in the 'Request URL' with the same URL you used in step 1.
-
Enable events using the toggle at the top of the page.
-
Expand the 'Subscribe to bot events' section and use the 'Add Bot User Event' button to subscribe to 'im_created' and 'message.im'.
Your Slack app is now configured and you can now login to the Slack workspace you installed your app into and you will see it listed under the 'Apps' section of the left hand menu.
Select your app and try:
- Sending a message, which you should see echoed back to you in the IM window.
- Sending an attachment.
- Sending a message containing a URL (link sharing).
- Sending the command "/test" which will prompt the sample bot to return a Slack interactive message.
To learn more about deploying a bot to Azure, see Deploy your bot to Azure for a complete list of deployment instructions.