Skip to content

A Slack Bot to prevent people from being added to channels that they don't want to be in.

Notifications You must be signed in to change notification settings

klairecodes/kevlar

Folders and files

NameName
Last commit message
Last commit date
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Kevlar

Kevlar is a Slack bot that prevents a user from being added to a channel on an opt-in basis.

How it works

When the Kevlar bot is added to a channel, it listens to two events: messages and users joining a channel.

When a message event happens, it checks the message for if any users were mentioned via @<user>, and query's each user's Kevlar custom field. If any user has their field set to true, Kevlar deletes the message and notifies the channel with a message that it did so with the specific user(s) that had Kevlar enabled.

When a user joins the channel, whether through being mentioned or being added, Kevlar query's that user's Kevlar custom field. If it is set to true, Kevlar leaves the was added to #<channel> by <user>. message alone, removes the user from the channel, and notifies the channel with a message that it did so.

Requirements

For local development (Linux):

  • Python version >= python 3.11.6.
  • A Python virtual environment.
  • The contents of requirements.txt installed.

For containerized development:

  • Docker or Podman.

Slack

  • A Slack workspace.
    • A Custom Field on a profile with the label "Kevlar" in the About Me section .
      • Follow Slack's Administrator Docs for how to get to the admin page.
      • At the configure profile page, scroll to the bottom for the "About me" section. Click +Add data element.
        • Label: Kevlar
        • Placeholder text: (optional)
        • Shows up in search: off
        • Data Source: Selectable options
          • Selectable Options: false, true
        • Click Save Changes.
      • Click Publish Changes.
  • A Slack Bot.
    • Following Slack's Getting started with Bolt for Python guide is advisable.
    • Socket Mode enabled.
      • This can be done at https://app.slack.com/app-settings/<your-workspace-id>/<your-app-id>/socket-mode.
    • Events enabled.
      • Two Slack event Subscriptions (this adds their required scopes automatically).
        • This page is found at https://api.slack.com/apps/<your-app-id>/event-subscriptions?.
        • Click Subscribe to bot events and add the following:
          • member_joined_channel
          • message.channels
          • message.groups
          • message.im
          • message.mpim
    • App, User and Bot token Scopes.
      • A Slack app token (starts with xapp-) with the following OAuth Scopes:
        • channels:history
        • channels:read
        • channels:write
        • chat:write
        • groups:read
        • groups:write
        • im:write
        • mpim:read
        • mpim:write
        • users.profile:read
      • A User token (starts with xoxp-, typically longer than nonuser) with the following OAuth Scopes:
        • channels:history
        • channels:manage
        • channels:read
        • chat:write
        • groups_history
        • groups:read
        • groups_write
        • im:history
        • im:write
        • mpim:history
        • mpim:read
        • mpim:write
        • users.profile:read
        • users:read
      • A Bot token (starts with xoxb-, typically longer than nonuser) with the following OAuth Scopes:
        • chat:write.customize
      • If any of these are missing, Kevlar will complain in stdout and tell you which scope was required for the failed API call.
      • If any of these are redundant (not the minimum required) please let me know by creating an Issue!
  • A user service account with administrator privileges. This will be the account the bot acts as, and should have permission to delete other users' messages.

Development

Locally (Linux, Bash/Zsh)

From the project's root:

  1. Create a Python virtual environment
python3 -m venv .venv
  1. Activate your virtual environment
source ./.venv/bin/activate
  1. Install dependencies
pip install -r requirements.txt
  1. Create a Slack app with the requirements mentioned above under Slack.
  2. Set the following environment variables to the tokens you created in your Slack Application:
export SLACK_APP_TOKEN=<your-app-token>
export SLACK_USER_TOKEN=<your-user-token>
export SLACK_BOT_TOKEN=<your-bot-token>

These can be found under OAuth&Permissions -> OAuth Tokens for Your Workspace in the Slack Admin portal.

  1. Run with
python3 app.py

You should see ⚡️ Bolt app is running! if setup was successful.

  1. Add your bot to the Slack channels/conversations that you would like it to be active in.
  2. Set a User's About me -> Kevlar field to different values for testing.
    • Note: This field is only visible in web and desktop profile settings as of writing. This is accessed by clicking your profile at the bottom-left of the page.

Docker/Podman (recommended)

These commands assume you have Docker or Podman installed. Anywhere podman is mentioned, docker can be substituted.

  1. Build the container
podman build -t kevlar .
  1. Set the following environment variables to the tokens you created in your Slack Application:
export SLACK_APP_TOKEN=<your-app-token>
export SLACK_USER_TOKEN=<your-user-token>
export SLACK_BOT_TOKEN=<your-bot-token>

These can be found under OAuth&Permissions -> OAuth Tokens for Your Workspace in the Slack Admin portal.

  1. Run the container with environment variables specified:
podman run -e SLACK_APP_TOKEN=$SLACK_APP_TOKEN -e SLACK_USER_TOKEN=$SLACK_USER_TOKEN -e SLACK_BOT_TOKEN=$SLACK_BOT_TOKEN kevlar:latest

Deployment

OKD (4.13.0-0.okd-2023-10-28-065448)

Steps for the Web UI:
In the Developer view:

  1. Create a new Project with a title of your choice.
  2. Create an app within the project
    1. Click +Add
    2. Select Import from Git
    3. Provide a link to this Git repository, or your fork.
      • It should detect the Dockerfile, leave this as-is.
    4. Resource type: Deployment
    5. Target port: 3000.
      • Check Create a route
    6. Click Create
  3. Create a ConfigMap
    1. Name it something like "slack-env"
    2. Add three key/value pairs
      • Key: SLACK_APP_TOKEN
        • Value: <your-app-token>
      • Key: SLACK_USER_TOKEN
        • Value: <your-user-token>
      • Key: SLACK_BOT_TOKEN
        • Value: <your-bot-token>
    3. Click Save
  4. Add the ConfigMap to your Deployment
    1. Navigate to Project -> Deployment -> Environment
    2. In All values from existing ConfigMap or Secrets (envFrom), specify the name of the ConfigMap you created in the dropdown.
    3. Click Save
  5. Redeploy your application

Your bot should now be running!

Kubernetes

Steps are similar to the OKD deployment, except manually done via yaml and ignoring OKD features.

About

A Slack Bot to prevent people from being added to channels that they don't want to be in.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published