Skip to content

A Slack bot that simplifies end-of-day debriefs for teaching staff at Le Wagon, allowing them to focus on capturing meaningful content rather than needless admin. Built with JavaScript using the Bolt framework by Slack. Currently in live testing with 3 London batches.

Notifications You must be signed in to change notification settings

rahulkeerthi/DebriefBot

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

71 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

What is DebriefBot?

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.

Demo Video (v1.0.0)

How does it work?

Setting Up

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.

Using DebriefBot

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!).

Common Errors

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.

Bot Default Settings

Some default settings are hardcoded into DebriefBot, specifically around timings for debrief age and relevance.

Timings

  • 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

Response Size Limits

  • 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

Development Roadmap

Core Functionality

  • 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).

User Experience / Flow

  • 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

Admin

  • Home app or specific slash command for batch owners to review debriefs from the past week for a particular channel (or channels)

About

A Slack bot that simplifies end-of-day debriefs for teaching staff at Le Wagon, allowing them to focus on capturing meaningful content rather than needless admin. Built with JavaScript using the Bolt framework by Slack. Currently in live testing with 3 London batches.

Topics

Resources

Stars

Watchers

Forks