DebriefBot is a friendly helper for teaching teams, simplifying the daily end-of-day TA debriefs. By getting rid of needless copy-pasting and focusing data capture for note-takers, TAs can effectively debrief while Teachers can easily update the day's debrief with additional input later on.
DebriefBot has been added to the Le Wagon workspace so is available as a Bot that can be invited to any channel (via the GUI or /invite @DebriefBot
). In practice, DebriefBot should be invited to the private batch teacher channels (#batch-476-teachers) only.
Once in the channel, the bot responds to the "slash command" /debrief
with a required argument. If you don't provide one, it will give you an example.
Currently there are 2 available arguments:
**/debrief #batch-476-london**
: To create a new debrief, pass the batch name as an argument. Typing # will trigger the Slack channel mention interface so you can easily select recent batches or search for one with autocomplete. Hit enter/send and a modal box will pop up with fields to fill in.
These are plain text inputs (except the students selector field) so user and channel mentions do not work as of now. Non-slack emojis (😁) and the plain-text format of Slack emojis (:smile:
or :drop_the_mic:
) will show up in the resulting message correctly.
**/debrief update**
: Anyone can then update the most recent debrief with this command, assuming not too much time has passed (18h) since the original was posted. This will pop up the same modal as before, with any existing comments or student usernames already filled in. After submitting, the original debrief is updated, along with its new timestamp and the username of whoever last updated it (you!).
Any issues using the commands above are fed back to the user (using messages only they can see). The two most common "error" messages:
- "No recent (last 24h) debrief available. Please start a new one with "/debrief #batch-123-city": You can't update a debrief if one hasn't been made in the last day! Create a new one instead with
**/debrief #batch-123-city**
- "There's already a debrief for today, use "/debrief update" instead": The opposite problem, there's already a debrief in the past 18h so you can only update it. Debriefs "expire" after 18h so you can create a new one after that much time has passed since it was first made.
If you're fairly sure you shouldn't be seeing these errors, let me know at @Rahul
on Slack or at rahulkeerthi2@gmail.com.
Some default settings are hardcoded into DebriefBot, specifically around timings for debrief age and relevance.
- New Debriefs: When trying to create a new debrief, the bot checks if one has been created in the last 12 hours. If there has been one, it responds with
There's already a debrief for today, use "/debrief update" instead
- Updating Debriefs: When trying to update a debrief, the bot checks the conversation history in the last 24 hours to find the last debrief. If it cannot find one, it responds with
No recent (last 24h) debrief available. Please start a new one with "/debrief #batch-123-city
- Edge Cases:
- Left Modal Open: If the user started a debrief update but didn't submit it, if more than 18 hours has passed since the original debrief was posted, it responds with
Last Debrief is older than 18 hours. Please start a new one with /debrief #batch-123-city
instead of allowing the update
- Left Modal Open: If the user started a debrief update but didn't submit it, if more than 18 hours has passed since the original debrief was posted, it responds with
- Slack limits fetch requests to a maximum of 100 messages and channels per request (you can time-box these requests but not choose sort order) which means that issues may occur if a user is in more than 100 (unarchived) public channels, or there are more than 100 messages between debriefs. Slack allows a form of pagination (i.e. fetch next hundred results) if we issue an identical request but providing a "cursor" parameter that is found in the original request response
- Ensure DebriefBot can only be invited to (or at least, used in) private channels (i.e. teacher channels)
- Better way to validate debrief "newness" than comparing message timestamp to arbitrary number of hours before now
- Allow conversation history lookback or conversation list call to account for conversations with more than 100 messages between debriefs, or users who are in more than 100 unarchived public channels. Alternatively, implement an active_batch_channel and/or batch_debrief_messages data store for this lookup that is regularly run in the background (need to check infosec and GDPR issues).
- Provide permalink to existing debrief in ephemeral message when trying to create a new debrief within 12h of the previous one
- Make sure timestamp on debrief is in batch/channel timezone (use Slack native time)
- "Live" display of user mentions and emojis in modal input boxes (only plain_text option available, which doesn't trigger a user/emoji lookup)
- Ability to converse with DebriefBot (it responds via DMs) to get more information on how to use it and what the slash commands do
- Home app or specific slash command for batch owners to review debriefs from the past week for a particular channel (or channels)