Cogs for the Red-DiscordBot-based Homelab Discord server bot.
- LabBot Cogs
- Table of Contents
- Contributors
- Cog Summaries
- Cog Documentation
- License
- Contributing
This is a joint project involving any of the Homelab Discord admins, moderators, and community members that would like to get involved.
A number of people have contributed to this project, both current and former members of the moderation team and members of the wider community.
A massive thank you to all who've helped with this project ❤️
- AutoReact: React to specific phrases with one or more emotes.
- AutoReply: Automatically replies to messages that match a trigger phrase.
- BanCount:
- BetterPing: Outputs the current channel topic as a message in the channel.
- Convert: Converts any unit to any another unit.
- Custom-msg: Allows moderators to send/edit messages from the bot.
- Enforcer: Allows you to enforce certain characteristics on a channel.
- Feed: This allows users to feed each other.
- Google: Send a google link to someone.
- guild_profiles: Create profiles to manage a guild's icon and banner.
- IsItReadOnlyFriday: Answers if it's read-only Friday (or December).
- Jail: Jails users in an isolated channel.
- LaTeX: Render a LaTeX statement.
- Letters: Outputs large emote letters/numbers from input text.
- Markov:
- Notes: Manage notes and warnings against users.
- onboarding_role: Apply a role to users who complete onboarding.
- Penis: Allows users to check the size of their penis.
- Phishingdetection:
- prometheus_exporter: Exposes a HTTP endpoint for exporting guild metrics in Prometheus format.
- Purge: This will purge users based on criteria.
- Quotes: Allows users to quote other users' messages in a quotes channel.
- Reactrole: Allows roles to be applied and removed using reactions.
- Report: Allows users to report issues.
- role_welcome: Sends a welcome message when a user is added to a role.
- Roleinfo: Displays info on a role
- Sentry: Send unhandled errors to sentry.
- Tags: Allow user-generated stored messages.
- Timeout: Manage users' timeout status.
- Topic: Outputs the current channel topic as a message in the channel.
- Verify: Allows users to verify themselves.
- xkcd: Allows users to look at xkcd comics.
This cog allows mods to add auto reactions to certain phrases.
[p]autoreact
This cog automatically responds to messages that match specific trigger phrases, set by admins.
[p]autoreact
This cog displays the number of users banned in the guild with a random selection from a list of messages.
[p]bancount
- Displays the total ban count using a randomly selected message.[p]bancount list
- Lists all the messages that can be used in the guild.[p]bancount add <message>
- Add a message to the guild list. Use$ban
to insert the ban count in the message.[p]bancount remove <message index>
- Deletes (by index, from the list command) the message from the guild list.
This cog is an upgraded version of the built-in ping command showing some latency information. It will override the built-in ping command when loaded, but reinstate it once when loaded.
It was inspired by Vexed01's AnotherPingCog, but it's slimmed down and not as snazzy.
[p]ping
Converts any unit to any another unit.
[p]convert
Allows moderators to send/edit messages from the bot.
[p]msg create
[p]msg edit
This cog allows you to enforce certain characteristics on a channel.
[p]enforcer
There are numerous attributes than can be used to restrict messages/content into a channel.
While some attributes are available in discord via role-based permissions, sometimes a bot may be better off enforcing content in a pinch.
[p]enforcer configure <channel> <attribute> [value]
Example:
[p]enforcer configure #channel enabled true
Attribute | Type | Description |
---|---|---|
enabled |
bool |
Whether to enable enforcements on a channel |
minchars |
int |
The minimum number of characters a message must contain to be allowed into the channel |
maxchars |
int |
The maximum number of characters a message may contain to be allowed into the channel |
notext |
bool |
The sent message must have no text, i.e. should be an image-only message |
requiremedia |
bool |
The sent message must contain an attached image |
nomedia |
bool |
The sent message must not contain an attached image |
minimumguildage |
int |
How old a server member must be part of the guild, in seconds, before they are able to contribute to the channel |
minimumdiscordage |
int |
How old a member's discord account must be, in seconds, before they are able to contribute to the channel |
An example enforcement would be a channel to show off server pictures. In which case, you could allow members to post a set of images with a description of their setup.
In which case, the following would be appropriate
[p]enforcer logchannel #admin-log
[p]enforcer configure #serverpics requiremedia true
[p]enforcer configure #serverpics minimumguildage 600
[p]enforcer configure #serverpics minchars 20
[p]enforcer configure #serverpics maxchars 300
[p]enforcer configure enabled true
This cog allows users to feed each other.
This cog allows users to send google links to each other.
[p]google <query>
This cog enables management of a guild's icon and banner with profiles. Profiles can be managed and applied at-will by admins or users with the "Manage Guild" permission.
Tip
Users must be moderators or higher or hold the manage_guild
permission to interact with this cog.
[p]guildprofile profile create <name> <icon> <banner>
- Creates a new guild profile with the specified asset IDs.[p]guildprofile profile list
- Lists all available guild profiles.[p]guildprofile profile info <name>
- Shows details of a specific profile.[p]guildprofile profile delete <name>
- Deletes a guild profile.[p]guildprofile profile update [icon] [banner]
- Updates the icon and/or banner asset IDs assigned to a profile.[p]guildprofile profile apply <name>
- Applies a profile to the guild.
[p]guildprofile asset create [name]
- Creates a new asset with the attached image.[p]guildprofile asset list
- Lists all available assets.[p]guildprofile asset info <ID>
- Shows details of a specific asset.[p]guildprofile asset delete <ID>
- Deletes an asset.[p]guildprofile asset delete_all_unused
- Deletes all assets that are not assigned to a profile.
This cog answers the question "Is It Read-Only Friday?". The user can optionally specify a UTC offset. Includes read-only December for the users with annual change freezes.
[p]isitreadonlyfriday [offset=0]
[p]isitreadonlydecember [offset=0]
Also availble as a slash command.
This cog allows users to be "jailed" in their own personal cell (channel). Also archives the channel to disk for future reference.
[p]jail setup <#category>
- Set the jail category where jail channels will be created in. (category is the channel category ID of the jail category)[p]jail <@user>
- Jail the specified user.[p]jail free <@user>
- Frees the specified user and cleans up the jail channel & role, archives the channel content.[p]jail archives
- Lists the archived jails with user, date, and jail UUID.[p]jail archives fetch <export uuid>
- Sends the specified jail channel archive as a file in the current channel (be careful running this in public channels)
This cog allows users to display complex mathematical information using LaTeX renderings.
[p]latex <latex statement>
This cog converts a string of letters/numbers into large emote letters ("regional indicators") or numbers.
-raw
flag can be used to output raw emote code.
[p]letters I would like this text as emotes 123
[p]letters -raw I would like this text as raw emote code 123
This cog generates messages based on markov chains generated per-user.
User messages will never be analysed unless the user explicitly opts in.
It must also be enabled per-channel: [p]markov channelenable
Modified version of CrunchBangDev's cog.
[p]markov generate
- Generate text based on user language models.[p]markov enable
- Allow the bot to model your messages and generate text.[p]markov disable
- Disallow the bot from model;ing your messages or generating text.[p]markov mode
- Set the tokenization mode for model building.[p]markov depth
- Set the modelling depth (the "n" in "ngrams").[p]markov show_user
- Show your current settings and models, or those of another user.[p]markov delete
- Delete a specific model from your profile.[p]markov reset
- Remove all language models from your profile.
[p]markov show_guild
- Show current guild settings.[p]markov channelenable
- Allow language modelling on messages in a given channel.[p]markov channeldisable
- Disallow language modelling on messages in a given channel.
[p]markov show_global [guild_id]
- Show global summary info or summary ofguild_id
.
Manage notes and warnings against users.
[p]notes
[p]warnings
Notes can be used for long-term storage information of problematic users or for future reference.
When listing the notes of a user, the warnings will be prioritised as they will be deemed more important.
It is possible to add notes to a user who has left or not yet joined. Notes are stored against a user's ID and do not require the user to be part of the server.
Deleting a note does not actually delete the note. It simply marks it in the datastore as deleted and does not show it in normal use. This can allow future recovery of notes (using the restore
subcommand) if a bad party is attempting to wipe existing notes.
Notes and warnings can be edited using the edit
subcommand.
Apply a role to users who complete onboarding.
When a user completes onboarding, this cog will add them to the configured role. If a log channel is configured, the cog will log such events to that channel.
On bot startup, the bot will process any missed onboarding events by looking for members in all guilds who meet the following criteria:
- Has completed onboarding.
- Does not have the onboarded role.
- Is not in the internal list of onboarded users.
If any such member is found, they will be granted the onboarding role.
[p]onboarding_role status
- Status of the cog.[p]onboarding_role role <role name or ID>
- Set the role to be granted to users once they complete onboarding.[p]onboarding_role logchannel <text channel name or ID>
- Set the channel to which onboarding events should be logged.[p]onboarding_role process [dry_run]
- Manually process onboarding for all eligible members in the current guild. This checks all members and assigns the onboarding role to those who have completed onboarding but don't have the role yet. UseTrue
fordry_run
to see what would happen without making changes.
This cog allows users to check the size of their penis.
[p]penis <user>
This cog automatically deletes any messages containing suspected phishing/scam links. This information is sourced from phish.sinking.yachts
This cog will purge users that hold no roles as a way to combat accounts being created and left in an un-verified state.
[p]purge
-
[p]purge schedule "0 */6 * * *"
- It is possible to run the purge on a schedule. By default, it is disabled, but configured for0 */6 * * *
which is a crontab for every 6 hours. E.g. will run at00:00
,06:00
,12:00
and18:00
every day. -
[p]purge minage 5
It will attempt to prune users that hold no roles, that have been part of the server for at least<minage>
days (default to 5).<minage>
can be altered to fit your server's requirements to ensure that people that joined but never verified, are not clogging up mention lists and to keep activity ratios high.
By default, purge's schedule is disabled and must be enabled to prune unverified users.
-
[p]purge simulate
- It's possible to do a simulated purge by running[p]purge simulate
. This will retrieve the list of users it would prune, had it run as normal. This allows moderators to test out configuration without performing any permanent actions. -
[p]purge exclude @Sneezey#2695
- If a user does not hold any roles for any reason, but you wish to exclude them from the purge, it is possible to add this user to theexclude
list. This action can also be undone with theinclude
subcommand. -
[p]purge status
- To check how many users have been purged any other configuration items, the status command allows you to see the values in an easy-to-see embed.
This cog will allow members to add quotes to the quotes channel easily.
[p]quote
Allows roles to be applied and removed using reactions.
[p]reactrole
This cog will allow members to send a report into a channel where it can be reviewed and actioned upon by moderators.
The report
and emergency
commands have cooldowns defined; if a user attempts to use one of these commands more than once within a 30 second period, they will be rate limited and receive a message informing them of this.
When a user triggers the emergency command, the bot will mention all online/idle users in the log channel with the user's report. The following conditions apply:
- If no users in the log channel are online/idle, the cog will fall back to mentioning all non-bot users.
- No number of users greather than the value of the
maxmentions
setting will be mentioned. The order of mentions is not guaranteed, so who is/isn't mentioned under this condition may be unpredictable.
[p]reports confirmation <true|false>
- Sets whether the bot will DM users a confirmation/copy of their report. Confirmations are always provided when the slash command is used.[p]reports logchannel #admin-log
- Set the channel to which reports will be sent.⚠️ The cog will not function without this.[p]reports maxmentions <number>
- Set the maximum number of users to mention in emergency reports (1-100, default: 20).[p]reports status
- Output the cog's configuration status.
[p]report <message>
- Sends a report with the given message.[p]emergency <message>
- Sends a high-priority report with the given message, mentioning (@'ing) users in the configuredlogchannel
who are in either an online or idle state.
Tip
The report
and emergency
commands are also implemented as slash commands.
Sends a welcome message when a user is added to a role.
The following template placeholders can be used in the welcome message:
{user}
: User mention (@user
){role}
: Role name (plaintext, not mentioned){guild}
: Guild name
The specific logic used to decide when to welcome a user can be adjusted with the always_welcome
(default: true
) and reset_on_leave
(default: true
) settings.
Scenario | always_welcome |
reset_on_leave |
User welcomed |
---|---|---|---|
User receives role for the first time | Any | Any | ✅ |
User receives role again | true |
Any | ✅ |
User receives role again | false |
Any | ❌ |
User receives role again after rejoining the guild | true |
Any | ✅ |
User receives role again after rejoining the guild | false |
false |
❌ |
User receives role again after rejoining the guild | false |
true |
✅ |
[p]rolewelcome status
- Print the current cog status.[p]rolewelcome channel <text channel>
- Set the text channel to send the welcome message to.[p]rolewelcome role <role>
- Set the role to be watched for new users.[p]rolewelcome always_welcome
- Toggle whether users receive a welcome message every time they are assigned the role. See more info in[p]help rolewelcome always_welcome
.[p]rolewelcome reset_on_leave
- Toggle whether a user's welcome status is reset when they leave the guild. See more info in[p]help rolewelcome reset_on_leave
.[p]rolewelcome clear_welcomed_users
- Clear the list of welcomed users.[p]rolewelcome backfill_welcomed_users <role>
- Backfill the list of welcomed users with all members of a role.[p]rolewelcome message <message>
- Set the welcome message, optionally including any of the noted template placeholders above.[p]rolewelcome test
- Test the welcome message in the current channel.
Allows you to view info on a role
[p]roleinfo <role>
Send unhandled errors and performance metrics to sentry.
Configure Sentry DSN using [p]set api sentry dsn,https://fooo@bar.baz/9
, then load the Cog [p]load sentry
.
[p]sentry get_log_level
- Get the current log level.[p]sentry set_log_level
- Set the desired log level, must be one oferror
,warning
,info
ordebug
. Does not require a reload.[p]sentry get_env
- Returns the currently configured Sentry environment.[p]sentry set_env
- Set the currently configured Sentry environment. Requires a reload of the cog.[p]sentry test
- Raise a test exception to test the Sentry connection.
Allow user-generated stored messages to be triggered upon configurable tags. Aliases can also be created to make accessing information even quicker. Users can transfer tag ownership between themselves and even claim ownership of abandoned tags. Ever use of a tag or alias is tracked. Same with ownership transfers of any kind. Statistics and searching have not yet been implemented.
[p]tag <tag>
- Triggers the specified tag.[p]tag search <query>
- Searches for a tag or alias.[p]tag create <tag> <content>
- Creates the specified tag which will reply with the provided content when triggered.[p]tag stats [user]
- Provides general stats about the tag system, or if a user is provided, about that user.[p]tag info <tag>
- Provides info about the tag such as its creator, date of creation, etc.[p]tag edit <tag> <content>
- Updates the content of the specified tag.[p]tag delete <tag>
- Deletes the specified tag.[p]tag claim <tag>
- Allows the runner to claim ownership of the tag if the current owner is not in the guild.[p]tag transfer <tag> <user>
- Transfers ownership of the specified tag to the specified user.[p]tag list [user]
- Lists all tags and aliases, or just those for the specified user.[p]tag alias create <alias> <tag>
- Creates the specified alias to the specified tag.[p]tag alias delete <alias>
- Deletes the specified alias.- (struck commands are disabled, pending feature review.)
This cog exposes a HTTP endpoint for exporting guild metrics in Prometheus format.
[p]prom_export set_port <port>
- Set the port the HTTP server should listen on[p]prom_export set_address <address>
- Sets the bind address (IP) of the HTTP server[p]prom_export set_poll_interval <interval>
- Set the metrics poll interval (seconds)[p]prom_export config
- Show the current running config
Note
Timeout in this case does not refer to Discord's timeout feature.
This cog manages a moderation feature in the Homelab Discord server that was named timeout before Discord introduced their own timeout feature.
Manage the timeout status of users.
Run the command to add a user to timeout, run it again to remove them.
Append a reason if you wish: [p]timeout @someUser said a bad thing
- If the user is not in timeout, they are added.
- If they are in timeout, they are removed.
- All of the member's roles will be stripped when they are added to timeout, and re-added when they are removed.
- Additionally, the member will be disconnected from any voice channels they were connected to.
[p]timeout <user> [reason]
- Add/remove a user from timeout, optionally specifying a reason.[p]timeoutset list
- Print the current configuration.[p]timeoutset role <role name>
- Set the timeout role.[p]timeoutset report <bool>
- Set whether timeout reports should be logged or not.[p]timeoutset logchannel <channel>
- Set the log channel.
Shows the current channel topic as a message in the channel.
Channel topics are notoriously hard for users to see. It's in a not so obvious place in the desktop UI and it's not possible to see in the mobile UI unless you are looking at the memberlist. Topic allows users to easily view the current channel topic or use it to remind other users in the channel what the topic currently is.
[p]topic
- Prints the current channel topic. Output message format:#channel: topic
/topic
- Same as above but implemented as a discord slash command.
This cog will allow users to prove they're not a bot by having to read rules and complete an action. They will then be given the verified role if they can complete this.
[p]verify block <user>
- Add the specified user to the verification blocklist.[p]verify channel <channel>
- Set the channel in which the cog listens for verification attemps.[p]verify logchannel <channel>
- Set the channel in which the cog logs verification attemps.[p]verify message <message>
- Set the verification string (e.g.I agree to the rules
.[p]verify role <role>
- Set the role to which users are added upon successful verification.
Further configuration options can be seen with [p]verify help
This cog allows users to look at xkcd comics
[p]xkcd <comicnumber>
All code in this repository is licensed under the GNU General Public License version 3.
Copyright (c) 2018-2023 tigattack, contributors and original authors.
You can create a Red bot instance by running the create_dev_bot.sh
script in this repo:
./create_dev_bot.sh
If you're using VSCode, this repository also includes launch configs for the bot, allowing you to run your dev bot with a debugger attached.
Your code must be passed by our lint & type checkers to be merged:
pip install -r requirements-dev.txt -r requirements.txt
pre-commit install
pre-commit run --all-files
If you use VSCode you can use the pre-commit-vscode extension to auto generate tasks for the pre-commit hooks
When suggesting changes, please open an issue so it can be reviewed by the team who can then suggest how and if the idea is to be implemented.
When submitting changes, please create a pull request targeting the main branch.