Slack
This guide will give you some basic concepts of developing a Slack bot. For more detail, check official docs.
Requirements
-
Slack App with following features:
- Event Subscriptions
- Permissions
- Bots
First, create an app on Slack API site. Then setup its features:
-
Event Subscriptions:
- Subscribe to
message.channels
event, so your bot can receive message events. - Setup webhook URL after your bot server is up.
- Subscribe to
-
Permissions:
- Add bot scope to your app
- Copy Bot User OAuth Access Token (access token) for later use.
-
Bots:
- Setup your bot's display name.
Build Your First Slack Bot
Check out your app's access token Slack API then fill them in slack-hello-world example:
const { SlackBot } = require('bottender');
const bot = new SlackBot({
accessToken: '__FILL_YOUR_TOKEN_HERE__',
});
Then run your server and try it out by invite the Bot User to a channel and talk to him/her/it!
Events
There are many types of events your bot may receive from Slack, but it's up to you whether to subscribe to each of them. In Bottender, you can access them via context.event
. For more information, check SlackEvent Reference and official docs.
For the message related events, Bottender supports some helpers:
- isMessage
- isChannelsMessage
- isGroupsMessage
- isImMessage
- isMpimMessage
- isText
- message
- text
For example:
bot.onEvent(async context => {
if (context.event.isChannelsMessage) {
await context.sendText('Hello, this is a channels message!');
} else if (context.event.isGroupsMessage) {
await context.sendText('Hello, this is a groups message!');
} else if (context.event.isText && context.event.text === 'How are you?') {
await context.sendText('I am fine.');
} else {
await context.sendText('I do not understand.');
}
});
Slack Specific
Message Format
In Bottender, you can use function context.sendText()
to send messages. You can format messages with Slack message formatting. For more information, check SlackContext Reference and official docs.
Channel
You can invite your bot account into a channel. By doing so, the events will create channel sessions. Send method context.sendText()
will send to the channel. You can still get the sender's profile with context.session.user
.
You can access the channel and team members in context.session.channel
and context.session.team
.
Get User Info from ID
If you want to get user info from user ID, you can find it with session.team
info. For example, getting a user's name can be:
function getNameFromId(id, session) {
return session.team.members.find(member => member.id === id).name;
}
References
- official docs: official docs of Slack API.
- messaging-api-slack
- slack-hello-world example.