Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tyom/botan
An arguably useful Slack bot
https://github.com/tyom/botan
bot botkit node slack
Last synced: about 1 month ago
JSON representation
An arguably useful Slack bot
- Host: GitHub
- URL: https://github.com/tyom/botan
- Owner: tyom
- License: mit
- Created: 2019-05-11T18:22:46.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2022-12-09T23:10:21.000Z (about 2 years ago)
- Last Synced: 2024-11-06T00:40:49.383Z (3 months ago)
- Topics: bot, botkit, node, slack
- Language: JavaScript
- Homepage: https://glitch.com/~iambotan
- Size: 1.24 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 13
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# Botan the Slack bot
A generic Slack bot built with [BotKit](https://botkit.ai).
## Configuration
First make sure `.env` file is configured.
### Distributable app
To run this bot as distributable app
(single app that can be installed to multiple teams) you'll need to set `SLACK_CLIENT_ID`
and `SLACK_CLIENT_SECRET`. `REDIRECT_URI` needs to be set to your apps URL (make sure the
path is `/install/auth`).When using this methods the app will need to store bot token and channel ID, for this
you'll need to set `JSONSTORE_URL` and `JSONSTORE_ENCRYPT_KEY`. The data will be stored
in a [jsonstore.io](https://www.jsonstore.io) collection and encrypted using the key.### Single instance
To run this bot as a single team instance you'll only need `SLACK_BOT_TOKEN` which can
be obtained by installing the app from app manager.Both methods require `SLACK_SIGNING_SECRET` which is used to verify that your app is
sending the requests.`ENCODE_URL` base64-encodes URLs sent to Memify service.
`AYLIEN_TEXT_API_KEY` needs to be set to use summary feature which is using
[Aylien Text Analysis API](https://aylien.com/text-api/sdks/). You can subscribe to
a generous free tier with [RapidAPI](https://rapidapi.com/aylien/api/text-analysis).`DEBUG=true` will log communication to console to help you understand what's being sent
from Slack to the bot.## Development
Check out the repo and run the app in dev mode:
```
yarn dev
```The app will run on `PORT` defined in `.env` file. To use this app in Slack you'll need
to expose it to the outside world via a tunnel. You can use localtunnel which is provided
with the app. Run `yarn tunnel`. Or [ngrok](https://ngrok.com) which I find more stable,
but the free version doesn't support custom subdomain aliases.Once the tunnel is set up, go to Slack app configuration and set request URL for different
features to point to the tunneled app. Make sure the path is set to `/api/messages`.The bot uses interactive components, slash commands and event subscriptions. Also subscribe
to Bot events, such as `app_mention`, `message.channels`, `message.groups` etc.## Deployment
This bot has been tested with [Glitch](https://glitch.com) which is a great service for small
projects like this. You can import from and export directly to GitHub repo and it automatically
restarts on changes. It's very easy to play with and devlop this app directly from Glitch.See [Botan's Glitch page](https://glitch.com/~iambotan).