Warnings Discord Bot is a Discord bot written in Go that monitors messages for specific keywords or regular expressions and responds with warning messages. It can also send a welcome warning message to new members. It is designed to help maintain a respectful and safe chat environment within your Discord server. This bot was developed to overcome specific limitations in Discord Automod, such as the absence of an account age filter and the lack of a warning message options for 'Block Custom Words'. Further information can be found in the related community discussion here and the feature request here.
- Real-time Chat Monitoring: Actively scans all chat messages for specified keywords or regular expressions, ensuring no inappropriate content slips through the cracks.
- Automated Warning Messages: Automatically issues customized warning messages when a message matches the specified keywords or conditions, helping to maintain a respectful and safe chat environment.
- Welcome Warning Message: Sends a customizable warning message to new members when they join the server.
- Flexible Configuration: Allows you to easily specify the keywords, regular expressions, and conditions to monitor for, as well as the corresponding warning messages, giving you full control over the bot's behaviour.
Before you can run the bot, make sure you have the following:
- Go installed on your system.
- A Discord bot token obtained by creating a Discord application and bot.
- Clone this repository to your local machine.
- Modify the config.json file to include the keywords you want to monitor and the warning messages you want to send in response to keyword matches.
- Setup a discord application (see this guide). Ensure that the message content and guild members intents are enabled. Also, ensure that the
Send Messages
andRead Message History
permissions are requested on the URL Generator step. - Install the Golang dependencies using
go get
. - Build the bot using
go build
- Rename the
.env.template
file to.env
and insert the required environmental variables. - Run the bot using
./warnings-discord-bot
.
The Warnings Discord Bot can be run using the Docker image available on Docker Hub. To pull and run the bot from Docker Hub, use the following command:
docker run --name warnings-discord-bot rickstaa/warnings-discord-bot:latest
Please ensure you have a .env
file in the current working directory containing the required environmental variables. You can find an example of this file here or add the DISCORD_BOT_TOKEN
as an environmental variable to the docker run
command.
Note
This repository also contains a DockerFile and docker-compose.yml file. These files can be used to build and run the bot locally. To do this, clone this repository and run docker compose up
in the repository's root directory.
The bot's behaviour can be customized through the config.json file. This JSON file contains several fields that define the bot's keyword and regular expression monitoring, response behaviour, and join warning message.
Here's a breakdown of the fields:
-
join_warning_message: A string that defines the message the bot will send to a user when they join the server. If this field is empty, no message will be sent.
-
alert_rules: An array of objects, each representing a unique alert rule. An alert rule defines conditions that, when met, trigger a bot warning. Each object has the following properties:
- keywords: An array of strings for the bot to monitor. Used only if no regex is provided.
- regex_patterns: An array of regular expressions for the bot to monitor. Overrides keywords if provided.
- warning_message: A string that defines the warning message the bot will send when a chat message matches the keywords or regular expressions.
- external_link_required: A boolean value. If set to
true
, the bot will only issue a warning if the message contains both the specified keywords or regular expressions and an external link. - excluded_roles: An array of strings. If specified, the bot will not issue a warning if the message author has at least one of the roles in this list.
- required_roles: An array of strings. If specified, the bot will only issue a warning if the message author has at least one of the roles in this list.
- omit_members_older_than_days: An integer value. If set to a positive number, the bot will not issue a warning if the message author has been a member of the community for more days than the specified value. If set to 0 or a negative number, this rule is ignored.
Please note that all keyword and regular expression comparisons performed by the bot are case-insensitive.
Important
Remember to escape backslashes when writing regular expressions in the JSON configuration file. For example, \b(word)\b
should be written as \\b(word)\\b
.
We welcome contributions 🚀! Please see our Contributing Guide for more details.
This project is licensed under the MIT License.