An example of some of the things you can do with a Slack app written with the help of SlackNet. It uses SlackNet's SlackSocketModeClient
to connect to Slack as easily as possible.
This project makes use of Microsoft.Extensions.DependencyInjection
and SlackNet.Extensions.DependencyInjection
for configuring SlackNet.
This is the same DI container that ASP.NET Core uses, so configuring SlackNet in a web site will look almost identical.
Check out the other example projects to see how to configure SlackNet with other containers, or without any container.
- Create an app on the Slack developer website. Follow the prompts, selecting the "from scratch" option, rather than the app manifest option.
- Request the bot token scopes required by the demo:
users:read
channels:read
groups:read
im:read
mpim:read
for getting user & conversation info.chat:write
for posting messages.files:read
for uploading files.
- Install the app to your workspace and copy the bot user OAuth token from your app's OAuth & Permissions page into the demo's appsettings.json file for the value of the
ApiToken
. - Enable socket mode for your app. You'll be required to generate an app-level token - copy this into appsettings.json for the value of the
AppLevelToken
. - Enable the home tab for your app.
- Enable events and subscribe to the following bot events:
app_home_opened
for showing app home tab.message.channels
message.groups
message.im
message.mpim
for receiving messages.
- Add your app to any channels/groups etc. you want it to respond to.
- Optionally configure the slash command and workflow step (see below).
- Run the demo.
- App Home - Tells you what you can do with the demo when you open the app's home view in Slack.
- Ping - A simple event handler that says pong when you say ping.
- Counter - Displays an interactive message that updates itself.
- Modal View - Opens a modal view with a range of different inputs.
The echo demo handles a /echo
slash command and sends back the text after the command name.
Follow Slack's Creating a Slash Command instructions to create the slash command in your app, and make sure the command is set to /echo
, to match up with the demo code.
After this is configured and the demo is running, you should be able to type /echo test
into Slack and receive a message saying "test".
The workflow demo allows you to set up a workflow step that sends a predefined message to a user in Slack.
Workflows are only available to paid Slack workspaces.
- Create a workflow step. You can name the step anything you like, but make sure to use the value of the
StepCallbackId
field in the WorkflowDemo class as the Callback ID when you create the step. - Reinstall your app to your workspace.
- Set up a workflow in Slack, choose a trigger, then add and configure your new workflow step.
When the workflow is triggered while the demo is running, it should send your message to the specified user.