TeamSpeak server query bot. This bot is mainly an example project using the TSBot framework.
Collection of helpful debugging commands:
eval <eval str>
: Evaluates given python expression.exec <exec str>
: Executes given python expression. Persists any side-effects.quit
: Closes the bot.send <query>
: Sends a raw query to the teamspeak server and return the response data.spam <#lines> <text to be spammed>
: Spams the current ctx of the message.nickname <nickname>
: Changes the bot nickname. If no nickname provided, defaults to the login name.
You probably don't want anyone running these commands, so they are locked behind checks. You can configure the bot to check for specific uids or server groups that have the permission to run these commands.
Checks periodically for clients that haven't been active for given amount of time.
If such clients are found, move them to specified AFK channel.
If the bot doesn't find AFK channel, it will try to create one. You can white/blacklist channels where clients can be moved from. If you have Jail plugin enabled, You might want to add your jail channel to the blacklist.
Kicks out any clients with configured nickname.
You can configure a list of banned nicknames or provide a function that return a boolean telling the bot if a given nickname is allowed.
By default, the bot will only kick the default TeamSpeak nickname: TeamSpeakUser
Comes with handful of fun commands:
coinflip
: Flips a coin, responding with heads or tails.roll <size=6>
: Rolls a given sided die.
Greets new clients (clients with guest
server group) with a configurable message.
Jails a client for a given amount of time.
Time can be provided as a number of seconds or <int>h<int>m<int>s
meaning number of hours, minutes, and seconds respectively with out the <>
(no need to provide all of them)
jail <nickname> <time>
: Jail misbehaving client.free <nickname>
: Free jailed client. Don't use in pity.
Command to tell some good/bad jokes about programming:
joke
Tells a programming related joke
Pokes client with a message after given amount of time.
Time parsing works the same as in jail command.
notify <time> <message>
: Pokes you after given time with the provided message.
- Python 3.12
You should always use virtual envs.
pip install teamspeak-bot
The bot will look for a configuration module on startup.
You can pass a path to a config file with -c / --config
command line argument.
The config module must include CONFIG
variable.
from teamspeak_bot import BotConfig
# BotConfig is a type safe way for you to configure
# your bot instance. If you have misconfigured your bot,
# your IDE will yell at you.
CONFIG = BotConfig(
username="USERNAME",
password="PASSWORD",
address="ADDRESS",
plugins={},
logging={}
)
NOTE: You will need provide configuration file.
teamspeak-bot
# -- OR --
python -m teamspeak_bot
-c, --config
: Path to a configuration file. Defaults toconfig.py
-l, --logfile
: Path to a log file. Defaults tolog.txt
-v, --verbose
: Level of verbosity.-h, --help
: Prints out the help message.
Plugin config key: admin
Key | Type | Explanation |
---|---|---|
enabled | bool |
If the plugin is enabled |
allowed_uids | tuple[str, ...] |
UIDs allowed to run admin commands. |
allowed_server_groups | tuple[str, ...] |
Server groups allowed to run admin commands. |
strict_server_group_checking | bool |
By default if Admin in allowed_server_groups, any server group with the word Admin is allowed to run admin commands. This flag turns on strict matching. |
Plugin config key: afk_mover
Key | Type | Explanation |
---|---|---|
enabled | bool |
If the plugin is enabled |
afk_channel | str |
Name of the AFK channel. doesn't match strictly |
idle_time | float |
AFK grace period in seconds |
channel_whitelist | tuple[str, ...] |
Channel names where clients will be moved. |
channel_blacklist | tuple[str, ...] |
Channel names where clients wont be moved. |
Plugin config key: banned_names
banned_names
and/or is_banned_name
has to be defined if this plugin is enabled.
Key | Type | Explanation |
---|---|---|
enabled | bool |
If the plugin is enabled |
banned_names | tuple[str, ...] |
Blacklisted names |
is_banned_name | Callable[[str], bool] |
Function that determines if a name is banned |
message | str |
Kick message |
check_period | float |
How often bot checks for banned names in the client list in seconds |
Plugin config key: error_events
Key | Type | Explanation |
---|---|---|
enabled | bool |
If the plugin is enabled |
invalid_invocation_message | str |
Message when command is invoked wrongly |
permission_error_message | str |
Message when an invoker doesn't have proper permissions to run the command |
permission_error_log_message | str |
Message logged when an invoker doesn't have proper permissions to run the command |
command_error_message | str |
Message when a command handler encounters user error |
Plugin config key: fun
Key | Type | Explanation |
---|---|---|
enabled | bool |
If the plugin is enabled |
Plugin config key: greeter
Key | Type | Explanation |
---|---|---|
enabled | bool |
If the plugin is enabled |
message | str |
Message to new user joining the server |
Plugin config key: jail
Key | Type | Explanation |
---|---|---|
enabled | bool |
If the plugin is enabled |
can_jail_uids | tuple[str, ...] |
UIDs allowed to jail clients. |
can_jail_server_groups | tuple[str, ...] |
Server groups allowed to jail clients. |
strict_server_group_checking | bool |
Match server groups strictly |
jail_channel | str |
Name of the jail channel. |
inmate_server_group_name | str |
Name of the server group given to jailed clients. |
Plugin config key: jokes
Key | Type | Explanation |
---|---|---|
enabled | bool |
If the plugin is enabled |
Plugin config key: notify
Key | Type | Explanation |
---|---|---|
enabled | bool |
If the plugin is enabled |
max_delay | int |
The max notify time in seconds |