Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Chetan3010/EarthX
EarthX is a feature-rich Discord music bot built with discord.js v14+, discord-player v6+, and MongoDB. Elevate your server's audio experience with a wide array of music commands, robust performance, intelligent chat management, and comprehensive logging!
https://github.com/Chetan3010/EarthX
discord-bot discord-music-bot
Last synced: 18 days ago
JSON representation
EarthX is a feature-rich Discord music bot built with discord.js v14+, discord-player v6+, and MongoDB. Elevate your server's audio experience with a wide array of music commands, robust performance, intelligent chat management, and comprehensive logging!
- Host: GitHub
- URL: https://github.com/Chetan3010/EarthX
- Owner: Chetan3010
- Created: 2024-06-10T15:37:54.000Z (9 months ago)
- Default Branch: main
- Last Pushed: 2025-01-20T04:20:25.000Z (about 1 month ago)
- Last Synced: 2025-01-22T03:11:22.966Z (about 1 month ago)
- Topics: discord-bot, discord-music-bot
- Language: JavaScript
- Homepage:
- Size: 2.31 MB
- Stars: 26
- Watchers: 1
- Forks: 2
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# ๐ต EarthX Discord Music Bot ( ๐ v2 is on the way...)
data:image/s3,"s3://crabby-images/a368b/a368b0b79f89981534e77af2271089b983067d0c" alt="EarthX Banner"
EarthX is a feature-rich Discord music bot built with discord.js v14+, discord-player v6+, and MongoDB. Elevate your server's audio experience with a wide array of music commands, robust performance, intelligent chat management, and comprehensive logging!
## ๐ Table of Contents
- [โจ Features](#-features)
- [๐ฎ Commands](#-commands)
- [๐งน Auto-Cleanup](#-auto-cleanup)
- [๐ Logging](#-logging)
- [๐ผ๏ธ Screenshots](#๏ธ-screenshots)
- [๐ Getting Started](#-getting-started)
- [๐ ๏ธ Technologies Used](#๏ธ-technologies-used)
- [๐ฎ Future Plans](#-future-plans)## โจ Features
- ๐ถ Advanced music playback with high-quality audio
- ๐ฌ Slash commands with autocomplete for ease of use
- ๐ผ๏ธ Beautiful embed responses for a sleek user interface
- ๐พ MongoDB integration for persistent guild music settings
- ๐ Built on the latest discord.js and discord-player versions
- ๐งน Automatic message cleanup for a clutter-free chat experience
- ๐ Comprehensive logging system for easy monitoring and debugging
- ๐ง Easily extendable for future feature additions
- ๐จ๏ธ Prefix will be available soon...
- ๐ better error handling soon...
## ๐ฎ CommandsEarthX offers a variety of music-related commands to enhance your Discord server's audio experience:
- `/play` - Start playing a song or playlist
- `/pause-resume` - Pause/resume the current track
- `/skip` - Skip to the next song in the queue
- `/queue` - View the current music queue
- `/nowplaying` - Display information about the current track
- `/shuffle` - Randomize the order of songs in the queue
- `/247` - Stays on voice channel 24/7
- `/save` - Send you the current track into dm
- `/autoplay` - Plays similar songs on empty queue...and many more!
## ๐งน Auto-Cleanup
EarthX keeps your music channel clean and organized with its intelligent auto-cleanup feature:
- ๐ซ Automatically removes outdated music status messages
- ๐ต Cleans up "Now Playing" messages when a song ends
- ๐ Removes queue messages that are no longer relevant
- ๐ Deletes pause/resume notifications after a short time
- ๐ฌ Keeps the chat focused on the current music experienceThis feature ensures that your music channel remains clutter-free and easy to navigate, enhancing the overall user experience.
## ๐ Logging
EarthX comes with a powerful logging system that provides detailed insights into the bot's operations:
- ๐ Logs all commands executed by users
- ๐ต Tracks music playback events (play, pause, skip, etc.)
- ๐ Records error messages for easy debugging
- ๐ Offers insights into bot performance and usage statisticsThe logging system outputs clean, well-formatted logs to the console, making it easy for bot administrators to monitor activity and troubleshoot issues.
data:image/s3,"s3://crabby-images/f2ea1/f2ea149c5903656e77df276d69916e693bcb26f6" alt="Logging Screenshot"
## ๐ผ๏ธ Screenshots
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
## ๐ Getting Started
To add EarthX to your Discord server:
1. [Click here to invite EarthX to your server](https://discord.com/api/oauth2/authorize?client_id=YOUR_CLIENT_ID&permissions=YOUR_PERMISSIONS&scope=bot%20applications.commands)(available soon)
2. Grant the necessary permissions
3. Use `/help` to view available commandsFor developers looking to host their own instance:
1. Clone the repository:
```bash
git clone https://github.com/Chetan3010/EarthX.git
```
2. Install dependencies:
```bash
npm install
```
3. Install FFmpeg:
- **For Windows**: Download the FFmpeg build from [FFmpeg's official site](https://ffmpeg.org/download.html), extract it, and add the `bin` folder to your system's PATH.
- **For macOS**: Use Homebrew to install FFmpeg:
```bash
brew install ffmpeg
```
- **For Linux**: Use your package manager to install FFmpeg. For example, on Ubuntu:
```bash
sudo apt update
sudo apt install ffmpeg
```
4. Set up your `.example.env` file with your secrets and rename it to `.env`.#### Prerequisite
- Discord bot/client token
- Discord bot/client id
- Spotify Client Id
- Spotify Client Secret
- MongoDB Connection String
- Discord bot owner/developer discord user id
- Community guild id
- Community guild channel id5. Start the bot:
```bash
npm start
```##### Note :-
Emojis in the embed will not work unless your bot has access to them. You have two options:
1. Upload all emojis to the Discord Developer Portal's bot emojis API. Replace markdown with `config/emojis.js` respective emojis.
2. Alternatively, you can upload the emojis to a server and replace the IDs in the `config/emojis.js` file with the corresponding emoji IDs. Ensure that your bot is in the same server as the emojis you are using.Checkout emojis folder to get all your emojis.
## ๐ ๏ธ Technologies Used
- [discord.js](https://discord.js.org/) v14 - A powerful JavaScript library for interacting with the Discord API
- [discord-player](https://discord-player.js.org/) v6 - A robust framework for creating music bots
- [MongoDB](https://www.mongodb.com/) - A flexible NoSQL database for storing guild settings
- [Node.js](https://nodejs.org/) - JavaScript runtime built on Chrome's V8 JavaScript engine## ๐ฎ Future Plans
I'm working to improve EarthX and expand its capabilities. Here's what's on the horizon:
- ๐ก๏ธ Moderation commands for server management
- ๐ Fun and utility commands to entertain and assist users
- ๐ค Some AI stuff---
Made with โค๏ธ by Chetan Kale