Skip to content

Elite Music is an open-source, feature-packed Discord music bot running on discord.js and discord-player. The bot is complete with large selection of commands, effects, optional features, autoplay, customisability and much more! πŸš€πŸ’ͺ

License

ThatGuyJacobee/Elite-Music

Repository files navigation

Elite Music 🎡

Elite Music is a feature-packed Discord Music Bot built on top of discord.js & using the latest discord-player package.

Loving this open-source project? Leaving a ⭐ on the repository would be much appreciated! ❀️

Features πŸ’‘

  • Wide range of commands.
  • Easy to setup, customise and edit.
  • Slash commands (djs v14).
  • Support for various streaming platforms.
  • Wide range of audio filters.
  • Docker Support.
  • Awesome playback UI.
  • Additional features including plex media server support.
  • And much more!

Elite Music was originally a part of my verified Discord bot... Elite Bot, but the music section had to be removed due to verification issues. Therefore, in a win situation, I decided to open-source the bot's music code in this repository. And even better, I decided to rewrite the entire bot to improve the code's feature set and overall quality.

Installation πŸ”Œ

Prerequisites πŸ›‚

In order for the bot to function correctly, there are a few prerequisites that you must have on your system.

  • NodeJS - For the bot to function, it must be running in a NodeJS environment running on v16.9.0 or higher. It is highly recommended that you download the LTS build which is available for your OS to remain on the latest stable version. Head over to the NodeJS Download website to download and install an appropriate version.

  • FFmpeg or Avconv - You will require either of these for transcoding. It is recommended to use FFmpeg. By default, the bot comes with the ffmpeg-static binaries as a dependency which allows the bot to work out of the box. Alternatively, you may decide to set your own ffmpeg binaries. In this case, head over to the FFmpeg Download website, select your OS and download the appropriate package. You can then place FFMPEG_PATH as a new option into your .ENV file stating the custom path to your custom FFmpeg binaries.

  • Discord Bot Account - You must register a bot on the Discord Developer site to access a token to run the bot. Head over to the Developer website and click on New Application button. Provide a name and press Create. Next on the left-hand menu, select the Bot section and press Add Bot alongside the confirmation. Finally, press Reset Token and finally copy the token and keep it safe. This is what you will have to place into your .ENV file for the bot to function.

Setup πŸ”§

The first step is to clone the repository or download it manually as a folder to host it directly. The Git option is recommended for more advanced users and for users who already have it installed.

Regular Installation

Basic download

Head over to the download page and download the .zip source code. Next, using a tool such as 7-Zip, extract the files from the .zip folder. You can now move on to the following steps.

Download using Git

An alternative way to download the repository is through the usage of Git. If you do not have Git installed, please use the basic download method. Git users can run the command git clone https://github.com/ThatGuyJacobee/Elite-Bot-Music/tree/main to automatically clone the repository to a new folder.

Continuing the Setup

Now that you have downloaded the repository, you can continue with the following steps.

  1. Open a new command/shell/terminal window within your new folder. You should be able to right-click and open the Windows terminal/command prompt if on Windows.
  2. Run the command npm install to download all of the module dependencies.
  3. Rename the file .env.example to simply .env. Once down, edit the .env file with the configuration options that you would like!
  4. Finally, run your bot using node . within a command/shell/terminal window. The bot should now become online and provide a success message if everything was configured correctly. πŸŽ‰
  5. (Optional) If you are editing the code, you can use npm run dev within your IDE to activate nodemon, which will automatically restart the bot on any change which is ideal for development.

Of course, you need to add your bot to your server now in order to use it. Follow this useful guide from the discord.js Guide which explains how to do this with great detail if you need help understanding how to do this.

Installation via Docker

Elite Music now has Docker image and Docker Compose support, allowing you to simply install and use the bot through Docker.

You can access the Docker Image via Docker Hub which provides the image and the instructions within the description. The instructions to either install via Docker Run or Docker Compose are also provided below. Once you have installed and configured your bot, you will need to add your bot to your server now in order to use it. Follow this useful guide from the discord.js Guide which explains how to do this with great detail if you need help understanding how to do this.

Docker Run Command

You should use the following command to download the image and run it:

docker run -d \
--name=elite-music \
--env-file /path/to/.env \
--restart unless-stopped \
thatguyjacobee/elitemusic:latest

Note: The --env-file path is relative to the directory you are running your docker run command from.

See the .env.sample file on the GitHub repository to view and copy over all of the environmental options into your target .env file for the bot.

Docker Compose

Use the following for your docker-compose.yml file:

version: '3'
services:
    elitemusic:
        container_name: 'elite-music'
        image: 'thatguyjacobee/elitemusic:latest'
        env_file: 
           - /path/to/.env
        restart: unless-stopped

Once again, see the .env.sample file on the GitHub repository to view and copy over all of the environmental options into your target .env file for the bot.

Optional Features βœ…

You may decide to want to enable additional optional features for your bot. Follow the appropriate sub-heading to learn how to set up and enable the selected feature!

If you are missing the relevant option in your environmental (.env) file, make sure to check the latest .env.sample file to ensure you are on the latest version.

Once you have followed the appropriate steps for the optional feature that you want to enable, you should start the bot and ensure that the configuration option returns as true when the configuration loads. If the feature still shows as disabled, this suggests that you have a configuration error. Follow the error logs that are provided in your console to resolve this. If you are still having trouble with your issue, feel free to create an issue on the repository or join the Support Discord server.

Plex Media Server playback

The Plex optional feature when enabled, allows you to stream music directly from your Plex Media Server through the /plex command. In order to enable the Plex feature, you must go into your .env file and set up the configuration to your own Plex Media Server.

  1. Firstly, set ENABLE_PLEX to true.
  2. Next, you must provide a direct URL to your Plex Media Center. The default port that Plex Media Server runs on is 32400. You can test that your PLEX_SERVER URL is correct, by pasting it into any web browser, and it should load successfully with a login page.
  3. Finally, you must place your plex authentication token into the PLEX_AUTHTOKEN field. You can do this by browsing the XML file for a library item. Please follow the official Plex Support article to access your token. Once you have access to it, place it into your .env file.

DJ Mode

Elite Music comes with a DJ Mode optional feature, which locks down the use of commands and interactions to members who have the specified DJ Role.

  1. Firstly, set ENABLE_DJMODE to true.
  2. Now create a role on your server which you wish to be used as the DJ Role. Copy the ID of the role and place it into the DJ_ROLE field.

Support πŸ†˜

Need help setting up the bot or experiencing some trouble? Feel free to head over to the Support Discord server and let me know!

Found a bug or issue with the latest build? Feel free to open an issue on this repository! I will respond as soon as possible.

Elite Bot - Verified Multi-Purpose Bot πŸ’ͺ

Looking for a multi-purpose Discord Bot for your server? Look no further, check out Elite Bot to fulfil all of your server needs including moderation, logging, external server status and much more!

Check the bot out via the dedicated documentation website or top.gg today! πŸš€

License πŸ“„

Apache Β© ThatGuyJacobee