Skip to content

πŸŽΆπŸ€– EvoMusic is a fork of the original EvoBot, a Discord Music Bot built with TypeScript, discord.js & uses Command Handler from discordjs.guide. This version includes enhancements and additional features to improve user experience and functionality (including Apple Music & Spotify support).

License

Notifications You must be signed in to change notification settings

bnfone/discord-bot-evomusic

Β 
Β 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

EvoMusic - A Discord Music Bot

This is a fork of the original EvoBot, a Discord Music Bot built with TypeScript, discord.js & uses Command Handler from discordjs.guide. This version includes enhancements and additional features to improve user experience and functionality.

Publish Docker Image

🌟 Quickstart & Support

Thank you for your support in helping us develop and maintain this bot. We greatly appreciate your understanding and contributions.

If you like this project, consider making a donation. Donate πŸ’–

You can still choose the amount you wish to donate; every contribution is welcome and appreciated. Thank you for your generosity!

⚠️ Known Issues & Alternative Solution

EvoMusic relies on several external dependencies to function correctly, and occasionally, these dependencies may cause issues that temporarily disrupt the bot's functionality. While we actively work to resolve these issues, we understand the inconvenience this may cause.

πŸ› οΈ Alternative Music Bot Solution

As an alternative, we recommend trying our lightweight music bot, Alastor. This bot streams music directly from public web-radio streams, ensuring reliable playback without the need for additional integrations.

You can find more details and usage instructions here: Alastor on GitHub.

Feel free to switch between EvoMusic and Alastor depending on your needs!

πŸ“‹ Requirements

  1. Discord Bot Token Guide
    1.1. Enable 'Message Content Intent' in Discord Developer Portal
  2. Spotify Client ID & Secret *-> can be requested at Spotify Developer Dashboard
  3. Node.js 16.11.0 or newer

πŸ› οΈ Getting Started

git clone https://github.com/bnfone/discord-bot-evomusic  # Clone the forked repository
cd discord-bot-evomusic
npm install

After installation finishes, follow the configuration instructions and then run npm run start to start the bot.

βš™οΈ Configuration

Copy or Rename config.json.example to config.json and fill out the values:

⚠️ Note: Never commit or share your token or api keys publicly ⚠️

{
  "TOKEN": "",  // Your Discord Bot Token
  "SPOTIFY_CLIENT_ID": "",   // Your Spotify Client ID
  "SPOTIFY_CLIENT_SECRET": "", // Your Spotify Client Secret
  "MAX_PLAYLIST_SIZE": 10,
  "PRUNING": false,
  "LOCALE": "en",
  "DEFAULT_VOLUME": 100,
  "STAY_TIME": 30
}

🐳 Docker Configuration

For those who would prefer to use our Docker container, you may provide values from config.json as environment variables.

docker run -e TOKEN=your_discord_bot_token -e SPOTIFY_CLIENT_ID=your_spotify_client_id -e SPOTIFY_CLIENT_SECRET=your_spotify_client_secret ghcr.io/bnfone/discord-bot-evomusic:latest -d

Docker Compose

version: '3.8'

services:
  discord_music_bot:
    image: ghcr.io/bnfone/discord-bot-evomusic:latest
    container_name: discord_music_bot
    environment:
      - TOKEN=your_discord_bot_token
      - SPOTIFY_CLIENT_ID=your_spotify_client_id
      - SPOTIFY_CLIENT_SECRET=your_spotify_client_secret
    restart: always

πŸ“ Features & Commands

  • 🎢 Play music from YouTube, Spotify, and Apple Music via URL
  • πŸ”Ž Play music using search queries
  • πŸ“ƒ Play YouTube, Spotify, and Apple Music playlists via URL
  • πŸ”Ž Search and select music to play
  • πŸŽ›οΈ Volume control, queue system, loop/repeat, shuffle, and more
  • 🎀 Display lyrics for the playing song
  • ⏸️ Pause, resume, skip, and stop music playback
  • πŸ“± Media Controls via Buttons
  • 🌍 Supports multiple locales

Preview

Note: For Spotify and Apple Music integration, the bot converts the provided links to YouTube links before playing, ensuring compatibility and a broader range of music availability. The Odesli.co API is used for that.

🌎 Locales

This fork supports additional locales. For a complete list, please refer to the original repository. If you want to contribute by adding new locales, please check the contributing section.

🀝 Contributing to This Fork

  1. Clone your fork: git clone https://github.com/bnfone/discord-bot-evomusic.git
  2. Create your feature branch: git checkout -b my-new-feature
  3. Commit your changes: cz OR npm run commit (Avoid using git commit directly)
  4. Push to the branch: git push origin my-new-feature
  5. Submit a pull request to the original repository and mention that it's for the forked version.

Note: This fork is maintained separately from the original EvoBot. For changes specific to this fork, ensure to target the correct repository when submitting pull requests or issues.

About

πŸŽΆπŸ€– EvoMusic is a fork of the original EvoBot, a Discord Music Bot built with TypeScript, discord.js & uses Command Handler from discordjs.guide. This version includes enhancements and additional features to improve user experience and functionality (including Apple Music & Spotify support).

Topics

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

 
 
 

Languages

  • TypeScript 97.6%
  • Python 1.4%
  • Dockerfile 1.0%