A feature-rich and expertly crafted Discord censoring bot that provides dual-mode content filtering via term-based pattern matching and regular expressions, customizable blacklists and whitelists, global and blacklist-level exceptions, customizable DM messaging, and a time- and occurrence-based punishment system. This bot feature set surpasses a popular paid Discord censoring service in form and function. Content Filter Bot supports long Nitro-length messages, allows users to edit and delete their censored messages, provides detailed insight into censors in user DMs and system logging, lets users request terms to get removed from the blacklists, and so much more.
This bot requires SQLite with WAL2 support, which is available in the WAL2 branch of SQLite. This requires a custom compilation of SQLite and has been tested with:
- Version: 3.48.0
- Commit: 1adf875
By default, the standard SQLite distribution will not work as this bot specifically uses WAL2 mode for enhanced performance and reliability. You are free of course to modify this source code to use another mode, such as WAL or DELETE, in which case it will then function as expected. However, note that WAL2 mode was tested and verified so the database has high availability during times of heavy utilization of the censorship system. WAL2 provides you a consolidated, performant, portable database solution.
-
View Server Configuration
-
Blacklist and Whitelist Customization
-
Add your first blacklist and optionally whitelist from a variety of sources.
-
You can add them either with the edit functions
/edit_blacklist
and/edit_whitelist
or/import_blacklist
and/import_whitelist
. In the case of/edit_blacklist
and/edit_whitelist
, specify the name in the optional name field and then fill in the blank modal form field. In the case of/import_blacklist
and/import_whitelist
, provide a .json, .txt, or .csv file with a list of the terms and optionally specify the name of that list in leiu of using the file name. Note that whenever a list is longer than 4000 characters when separated by line endings with one term per line, that list will automatically be split into multiple lists. This is so it can be edited in the edit functions due to Discord limiting modal forms to 4000 characters in length. -
Here are several blacklist sources to get you started. Note you may need to extract and format the terms yourself from some of these sources if you want to import their terms in bulk. NotePad++ is well-suited for this task.
-
Create, modify, and delete any number of your own blacklists and whitelists with no limits.
-
Terms in a blacklist or whitelist can be made up of exact terms, URL-only terms, and regular expressions. Prefix your regular expressions with
re:
and the system automatically detects them as regular expressions. You can also usere:
to do exact matches and not run the special spacing, reversed, and special character checks for a term. Prefix your URL terms withurl:
and the system will apply them exclusively to URLs. URL terms can be exact terms or regular expressions. A URL is defined as a link beginning withhttp://
,https://
,discord.gg/
, ordiscord.com/invite/
. Leave the name parameter blank when executing the blacklist edit command to explore the current set of blacklists. Specify a new or current list by the blacklist name parameter. The same approach applies to whitelists as well. -
Sometimes, speed is of the essence in busy discussions. Quick commands come in handy for such occasions. Add a single term to either a blacklist or whitelist.
-
Our sophisticated obfuscation detection deters the most hardened trolls. Reversed spellings, fancy Unicode characters, Zalgo text, and randomly inserted spaces and special characters are all properly detected. Thanks to clever pattern matching which detects word boundaries, complex patterns are found while partial matches are ignored. For example, if
mean
were added to a blacklist, the hypothetical messageyou are m̂̃e..a n̈
would have a match withm̂̃e..a n̈
butthis is a meaningful discussion
would not have a match withmeaningful
. -
Support also includes URLs and emojis. Adding an emoji will block it not only in messages, thread titles, and (optionally) profile names, but reactions also. URLs are also supported and can be used to great effect to prevent link and invite spam.
-
Close attention was paid to be fully Markdown-aware so surrounding formatting is respected.
-
-
Reposted Bot Messages
-
Our unique filtering handles new and edited messages, new and edited thread titles, and added message reactions. Performance was a top priority during the design and optimization phase. Instant replacement was a central design goal, and real-world performance is instantaneous. To achieve this goal, settings and wordlists, while also stored persistently, are pre-processed and cached into memory for best-in-class low latency of data retrieval and message processing.
-
Best of all, every reposted message looks exactly as your user had posted it.
-
Each user's profile image and display name is depicted in the upper left of their censored messages identical to that user's real post.
-
There is exclusive support for editing and deleting on all censored posts. The same rigorously tested filtering system blocks and advises users here as well. Moderators are also empowered to edit and delete censored messages on users' behalf as well.
-
There is exclusive support for Nitro-length posts of up to 4000 characters. This means there is no truncation cutting off half of the lengthy message your users may have spent lengthy periods to enter. The full text no matter how long it is will always come through while respecting your censoring settings.
-
-
Advanced Exceptions System
-
No two servers are alike and many servers have multilingual channels, NSFW channels, or areas or members where you do not want filtering happening at all or at least not with every blacklist.
-
To cater to a variety of needs, we offer two levels of granularity: blacklist-specific exceptions and global exceptions.
-
With exceptions, add or remove any given number of roles, channels (channels include threads and forum posts), and categories to any given number of blacklists and vice versa.
-
Once exempted from a blacklist, that role, channel, or category ignores that single blacklist of blocked terms. This is perfect for multilingual communities as well as communities which require a tiered or hybrid approach.
-
Global exceptions offer a simpler, broader approach. They cover all blacklists. Select any roles, channels, and categories. Once applied, they are exempt from all blacklists.
-
You can combine both of these exception levels to suit the unique needs of your Discord server community.
-
-
Automated Punishments
-
Sometimes, users may try to circumvent or overwhelm the system. This is where the bot's automated mute punishment is helpful. This is how you configure it:
- First, specify a mute role.
- Then select the threshold of violations over a given number of minutes.
- Finally, configure the mute duration over a given number of hours.
-
Once configured, the bot begins tracking. If the bot ever goes down, the SQLite database persistently stores when a mute punishment had started. In this way, the bot knows exactly when it should end, so the bot always removes the mute role once a member's mute has expired.
-
-
Display Name Filtering
-
Configure display names to be filtered. Anytime a user joins or updates their profile, the bot will always be one step ahead.
-
Regular and global role exclusions apply here. If there is a role group whose profile name you want left unfiltered, select it in either exceptions level. It will then not get filtered whenever you do enable this optional filtering.
-
The automated punishment system also applies here. Whenever someone keeps trying to use an inappropriate profile name in the chat, they will likewise receive a punishment according to your punishment configuration.
-
-
Comprehensive Logging
-
Everything is transparent between you and your users in the DMs and the logs. Both you in your logs and your users in their DMs can see a breakdown of the violated blacklists and associated terms, together with the full message with text both obscured and censored.
-
Users are immediately notified via DM when they are muted by the bot. They are advised of the duration of their mute in relative time, and the exact date and time can also be seen easily by hovering over the time field.
-
When applying a punishment lift, the acting staff member is noted along with an optional reason. This action and its reason are then recorded both in your configured log channel and the server audit logs. See the time when the lift took place in relative time units from the present, and also hover to see the exact date and time.
-
Gather a detailed history of violations from the log channel. Observe when punishments are applied and whenever they are lifted either automatically by the bot or manually by a staff member via the lift punishment command.
-
-
DM Message Customization
- Python 3.8+
- discord.py 2.3+
- Custom-compiled SQLite with WAL2 support (v3.48.0/1adf875)
- Additional dependencies listed in requirements.txt
- Clone the repository:
git clone https://github.com/yourusername/discord-content-filter.git
cd discord-content-filter
- Install required packages:
pip install -r requirements.txt
-
Install custom SQLite with WAL2:
- Clone SQLite WAL2 branch
- Compile following SQLite documentation
- Verify WAL2 support is available
-
Configure the bot:
- Add a .env file with BOT_TOKEN defined as your bot token
-
Run the bot:
python content_filter.py
/view_configuration
- View the current bot configuration/set_moderator_role
- Set the moderator role/set_term_approver_role
- Set term approver role/set_log_channel
- Set logging channel/set_dm_notification
- Configure DM notifications/set_punishment
- Configure punishment settings/set_replacement_string
- Configure replacement string/toggle_display_name_filter
- Toggle name filtering
/import_blacklist
- Import blacklists from file/edit_blacklist
- Create/edit blacklists/quick_add_blacklist
- Quick add terms/delete_blacklist
- Remove blacklists/list_blacklists
- View all blacklists
/import_whitelist
- Import whitelists from file/edit_whitelist
- Create/edit whitelists/quick_add_whitelist
- Quick add terms/delete_whitelist
- Remove whitelists/list_whitelists
- View all whitelists
/add_global_category_exception
- Add global category exceptions/remove_global_category_exception
- Remove global category exceptions/add_global_channel_exception
- Add global channel exceptions/remove_global_channel_exception
- Remove global channel exceptions/add_global_role_exception
- Add global role exceptions/remove_global_role_exception
- Remove global role exceptions/list_global_exceptions
- View all global exceptions/add_category_exception
- Add category exceptions/add_channel_exception
- Add channel exceptions/add_role_exception
- Add role exceptions/remove_category_exception
- Remove category exceptions/remove_channel_exception
- Remove channel exceptions/remove_role_exception
- Remove role exceptions/list_exceptions
- View all exceptions
/scan_last_messages
- Scan recent messages/lift_punishment
- Remove punishments/view_term_request_history
- View and manage term requests
/request_term_removal
- Request removal of a term from blacklists- Context menu -
Edit Censored Message
- Edit a censored message - Context menu -
Delete Censored Message
- Delete a censored message
The bot uses a JSON-based configuration system with the following main components:
{
"blacklists": {},
"whitelists": {},
"exceptions": {
"categories": {},
"channels": {},
"roles": {}
},
"global_exceptions": {
"categories": [],
"channels": [],
"roles": []
},
"punishments": {
"max_violations": 10,
"time_window": {
"days": 0,
"seconds": 3600,
"microseconds": 0
},
"punishment_role": 123456789012345678,
"punishment_duration": {
"days": 0,
"seconds": 3600,
"microseconds": 0
},
"dm_notification": "Your content was modified because of inappropriate content or a false positive. Note that you can always edit and delete your censored messages from the context menu under *Apps→Edit Censored Message* and *Apps→Delete Censored Message*. If you believe this censor to be in error, please report the erroneous term(s) with the slash command `/request_term_removal`. We greatly appreciate users who report false positives that should be whitelisted.\n\n Note that if you repeatedly try to circumvent a censor including false positives, after {max_violations} attempt(s) in {time_window}, you will be automatically muted for the period of {punishment_duration}. Outside of the system's automated punishment, moderators will never manually punish a user for a false positive. Thank you for your understanding.",
"replacement_string": "***"
}
To help make this bot even better, follow these five simple steps to contribute.
- Fork the repository
- Create a feature branch
- Commit your changes
- Push to the branch
- Create a Pull Request
This project is licensed under the MIT License - see the LICENSE file for details.
For support, please open an issue on GitHub.
If you found this bot at all helpful, in lieu of donating to the bot's development, please consider donating to the Humanitarian Services of The Church of Jesus Christ of Latter-day Saints.