csgo-queue-bot
csgo-queue-bot copied to clipboard
A Discord bot to manage and setup CS:GO games
DEPRECATED: DEVELOPMENT CONTINUING HERE
data:image/s3,"s3://crabby-images/7a9e7/7a9e78c3b9cac03feb589a4e46bb2d69db1614f0" alt="10-Man Queues"
CS:GO Queue Bot
data:image/s3,"s3://crabby-images/a90bd/a90bd9202e88844263467628904f5ffad29b2475" alt="Discord Bots"
A Discord bot to manage and setup CS:GO games
This script uses the Discord Python API via a bot to manage queues of CS:GO players who want to play with other Discord server members. It is complete with a queueing system, team drafter, map drafter and a link to a unique PopFlash lobby.
Setup
-
First you must have a bot instance to run this script on. Follow Discord's tutorial here on how to set one up. Be sure to invite it to a server to use it.
- The permissions integer necessary is
17067072
.
- The permissions integer necessary is
-
(Optional) If you have a Discord Bot List token to use with top.gg then retrieve that from its editing menu.
-
Run
pip3 install -r requirements.txt
in the repository's root directory to get the necessary libraries.- Note that python-Levenshtein requires your system to have a C++ compiler (Visual Studio C++ compiler for Windows or g++ for Linux). This library may be replaced in the future to eliminate this requirement.
-
Add the
/qbot
path to yourPYTHONPATH
environment variable to be able to import it from anywhere. -
Using your bot's Discord token and Discord Bot List token, run the bot like so...
import qbot
DISCORD_TOKEN = 'XXXXXXXX'
qbot.run(discord_token=DISCORD_TOKEN)
Now you are ready to start using the CS:GO Queue Bot! Try out some of the commands to make sure it works.
Note that currently the mdraft
command depends on custom emojis to be used as buttons which are hardcoded here. As of right now you will need to make the emojis yourself and replace the emoji code in the map objects there.
Commands
q!help
- Display help menu
q!about
- Display basic info about this bot
q!join
- Join the queue
q!leave
- Leave the queue
q!view
- Display who is currently in the queue
q!remove <mention>
- Remove the mentioned user from the queue (must have server kick perms)
q!empty
- Empty the queue (must have server kick perms)
q!cap <integer>
- Set the capacity of the queue to the specified value (must have admin perms)
This command is only available when the generic argument is set to true
q!tdraft
- Start (or restart) a team draft from the last popped queue
q!mdraft
- Start (or restart) a map draft
q!setmp {+|-}<map name> ...
- Add or remove maps from the mdraft map pool (Must have admin perms)
q!popflash
- Link the server's designated PopFlash lobby
q!donate
- Link the bot's donation link
Contributions
Code Style
This project adheres to the PEP8 style guide with 120 character line limits.
Branches
Create a branch if you're working on an issue with the issue number and name like so: 100_Title-Separated-By-Dashes
.
Commit Messages
Phrase commits in the present tense, e.g. Fix bug
instead of Fixed bug
.