Queue Bot was designed to manage Slack-based help queues. Built with Python 2.7 and Slack's Real Time Messaging API.
The bot tracks which users are currently enqueued with a queue data structure built on top of a linked list. Each node in the linked list represents a user in the queue, and it contains that user's handle, formatted according to Slack's rules for @username posting.
You can get Queue Bot running in two stages: Slack setup and environment setup.
First, integrate a bot with Slack so that you can get an API token for it. To integrate a custom bot with your Slack team, do the following:
Log into the Slack team where you want to integrate a Queue Bot, and go to "Manage Apps" from the left-hand menu. This should bring you to the browser admin interface for your channel.
Click the "Browse" button.
Use the search bar to find the Bots app. Select it.
Click the "Add Configuration" button and follow the setup's only prompt: pick a username for your bot.
You should be sent to a page where you can customize your bot settings and view your API token. Yours should be something other than a blurry blob.
Make any customizations you want to make, save your integration, and head back to Slack. Keep the bot integration page open.
Go to the channel where you want your bot to be able to post. In my code, the channel is called "help," but you can call it whatever you want.
Invite your bot to that channel with the username you gave it in the admin interface.
Finally, copy your API token from the bot integration page of your Slack admin interface, and open your terminal.
I assume you already have your preferred version of Python installed. As I said before, this project was built with Python 2.7, but the setup for Python 3 should be similar.
Download the files from this repo to a new directory (Clone it if you like. Heck, fork it and modify it.) and navigate into that directory.
Put your API key into your shell environment. I suggest adding it to a file called secrets.sh and adding this bit of bash code:
export BOT_API_TOKEN="a-really-long-thing-that-is-your-bot-token"
Now, you can export your variable into the environment like this:
source secrets.sh
Just be sure to add secrets.sh to your .gitignore file to keep your secrets off the Internet!
Fun fact: If you do accidentally push your Slack API token to GitHub, you'll receive a lovely email from Slack alerting you that your token was posted on the Internet and that they've disabled it. The email includes where the token was found and a link to how to issue a new one. Way to go, Slack!
Create a virtual environment:
virtualenv env
Activate your virtual environment:
source env/bin/activate
Install all requirements:
pip install -r requirements.txt
With your secrets sourced and your environment activated, run queue_bot.py
The terminal should appear to hang. But if you start typing messages in the channel you invited your bot to, you should see a dictionary print to stdout for each message you send.
If you're seeing message data appear in your terminal, you're ready to start up a user queue. I've currently implemented four commands.
The following list shows the text you'd type in your Slack channel for each command, followed by a brief description.
queue.open()
: Tell folks that your user queue is ready to be used. Set it to empty to start.queue.close()
: Empty all users from the queue and ask them to enqueue when it's open again.queue = []
(or several other variations; see queue_bot.py): Empty the queue and show an emoji in their place to celebrate.queue.enqueue(@username)
: Add the given user to the queue and display the queue's current contents.queue.dequeue()
: Remove the next user from the queue and display the queue's current contents.queue.remove(@username)
: Remove the given user from the queue, wherever they are positioned, and display the queue's current contents.queue.freeze()
: Don't allow other users to be added to the queue.queue.unfreeze()
: What's on the tin. Unfreeze the queue.queue.status()
: Get the current status of the queue.
Future features that I'd like to implement include:
[X] A
queue.freeze()
command to keep users in the queue but not allow more to be added.[ ] The ability for the queue to automatically close itself or freeze at a certain time, if it's known the queue needs to close then.
[ ] "Staff only" users: Get the user ids of particular users so that only they can use queue commands.
(Note to self: try using
sc.server.users.find('foo').id
to get particular users' ids for the staff list.)[ ] Allow users to be dequeued when the queue is frozen.
That's it! Hope you enjoy your new Slack-based user queue assistant.
I found these links helpful in building Queue Bot:
- Real Time Messaging API docs main page
- Formatting messages
- Regex 101 (for testing my user-grabbing regex)
- Slack's Python onboarding tutorial
- Source code for the slackclient Python module
- Docs for the slackclient module (Super helpful Python example code here!)