A Discord music bot written in Python with support for Youtube, SoundCloud, Spotify, Bandcamp, Twitter, and custom files.
- This is a personal project for a small server and may lack features you would expect from larger projects.
- This bot is in a pre-relase state and I would consider incomplete. Known problems are listed in Issues. If you are interested in this project feel free to submit an Issue or ask a question in the demo server.
- See TODO in Projects tab
- Discord - https://discord.com/developers
- Spotify (optional) - https://developer.spotify.com/dashboard/
- Client ID
- Client Secret
- Note: Limited to 50 playlist items without API
Obtained keys must be entered into config/config.py
- Installation of Python 3.7+
Install dependancies:
pip install -r requirements.txt
- Located in
/config
For Linux:
- ffmpeg
- libffi-dev
- libnacl-dev
- Download release if available, alternatively download repository zip
- Complete Prerequisites
- Start
run.py
in project root
Button play feature:
- Set emoji name in
config/config.py
to enable this feature - Emote must be in same server as bot
- Needs Manage Message permissions
Custom Cookies:
- Extract cookies.txt from you browser using your preferred method
- Overwrite the existing cookies.txt in /config/cookies/
- (Optional) Set a custom cookies.txt location by modifying COOKIE_PATH in config.py
After the bot has joined your server, use $help
to display help and command information.
$p [link/video title/key words/playlist-link/soundcloud link/spotify link/bandcamp link/twitter link]
- Plays the audio of supported website
- A link to the video (https://ww...)
- The title of a video ex. (Gennifer Flowers - Fever Dolls)
- A link to a YouTube playlist
- If a song is playing, it will be added to queue
$skip / $s
- Skips the current song and plays next in queue.
$q
- Show the list of songs in queue
$shuffle /$sh
- Shuffle the queue
$l / $loop
- Loop the current playing song, toggle on/off
$pause
- Pauses the current song.
$resume
- Resumes the paused song.
$prev
- Goes back one song and plays the last song again.
$np
- Shows more details about the current song.
$stop
- Stops the current song and clears the playqueue.
$c
- Connects the bot to the user's voice channel
$cc
- Switch the bot to the user's voice channel
$dc
- Disconnects the bot from the current voice channel
$history
- Shows you the titles of the X last played songs. Configurable in config.config.py
$version
- Show verison information
$reset / $rs
- Disconnect and reconnect to the voice channel
$ping
- Test bot connectivity
$addbot
- Displays information on how to add the bot to another server of yours.
This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.