Guava
Dead simple Discord music bot
Invite Guava
Overview
Guava is a Discord music bot with support for multiple different music and video streaming platforms. Guava is a part of >200 Discord servers and currently supports these services:
- Spotify (Links)
- SoundCloud
- Bandcamp
- Deezer
- Twitch Streams
- Vimeo
Getting started is easy, simply invite Guava to your server and run /help
to see what all Guava has to offer.
Want to self-host?
Guava is built on Python and requires a Lavalink node running release v4
or higher with the LavaSrc plugin. If you would like to configure Guava and run it on your own, follow the steps below.
NOTE: For information on each configuration variable, look at the Configuration section of this page.
P.S. Some information on starting your own lavalink node can be found here
Docker
To run Guava in Docker, use the provided docker-compose.yaml file as a template for the container.
In addition to the Guava container, you must also create a Lavalink node however you choose (bare metal or docker)
Bare metal
To run Guava on bare metal, follow the steps below.
NOTE: On first run you will likely get a critical warning in your console, don't worry, this is expected. It will automatically create a config.ini
file for you in the root of the directory with all of the necessary configuration options.
- Install Python and Pip
- Clone this repository
- Install the requirements with
pip install -r requirements.txt
- Run the
code/bot.py
file - Input information into the newly created config.ini file.
- Re-run the
code/bot.py
file.
Configuration
Field | Description | Requirement |
---|---|---|
TOKEN | The token for your bot. Create a bot at discord.com/developers | REQUIRED |
BOT_COLOR | HEX CODE : Color that will be used for the color of message embeds |
REQUIRED |
BOT_INVITE_LINK | URL : Discord Invite link for your bot (shown on the help command) |
REQUIRED |
FEEDBACK_CHANNEL_ID | CHANNEL ID : Discord channel for feedback messages to be sent to |
OPTIONAL |
BUG_CHANNEL_ID | CHANNEL ID : Discord channel for bug messages to be sent to |
OPTIONAL |
SPOTIFY_CLIENT_ID | Client ID from Spotify Developer account | REQUIRED |
SPOTIFY_CLIENT_SECRET | Client Secret from Spotify Developer account | REQUIRED |
OPENAI_API_KEY | API Key from OpenAI for autoplay recommendations | REQUIRED |
HOST | Host address for your Lavalink node | REQUIRED |
PORT | Port for your Lavalink node | REQUIRED |
PASSWORD | Password to authenticate into the Lavalink node | REQUIRED |
Lavalink Information
As previously state, a Lavalink node running at least v4
with the LavaSrc plugin is required. Due to the plugin requirement, it is unlikely that you will be able to use a free/public Lavalink node.
For instructions on setting up a Lavalink node on bare metal, look here, and for instructions on the LavaSrc plugin, look here.
P.S. Only the Deezer/SoundCloud sources/search providers are needed.
It is also highly recommended to setup IPv6 rotation in order to avoid blocks and other issues. There are helpful guides for this both here and here.
An example of my personal application.yml
file can be found here.
If you have any questions, feel free to email at contact@pkrm.dev. Thank you for checking out Guava, and happy coding.