Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/coslynx/discord-status-management-bot

Project: Discord Status Bot with 50+ Features and Slash Commands. Created at https://spectra.codes, which is owned by @Drix10
https://github.com/coslynx/discord-status-management-bot

api-integration code-generation code-quality community-engagement developer-tools devops discord-bot discord-js docker github-actions javascript machine-learning member-status mongodb mongoose node-js openai server-management slash-commands software-development

Last synced: 21 days ago
JSON representation

Project: Discord Status Bot with 50+ Features and Slash Commands. Created at https://spectra.codes, which is owned by @Drix10

Awesome Lists containing this project

README

        




discord-status-management-bot


A Discord bot for managing member status with custom titles, images, and badges, offering a wide range of commands and advanced features.


Developed with the software and tools below.



Discord.js Framework
JavaScript Language
MongoDB Database
OpenAI LLMs



git-last-commit
GitHub commit activity
GitHub top language

## ๐Ÿ“‘ Table of Contents
- ๐Ÿ“ Overview
- ๐Ÿ“ฆ Features
- ๐Ÿ“‚ Structure
- ๐Ÿ’ป Installation
- ๐Ÿ—๏ธ Usage
- ๐ŸŒ Hosting
- ๐Ÿ“„ License
- ๐Ÿ‘ Authors

## ๐Ÿ“ Overview
This repository contains a Discord bot project called "discord-status-management-bot." This project aims to provide server communities with enhanced member status functionalities, including custom titles, images, and badges. Built using Discord.js, Node.js, and Mongoose, the bot offers a comprehensive suite of commands for managing these statuses and a range of additional features, including mini-games, server utilities, moderation tools, and advanced automation.

## ๐Ÿ“ฆ Features

| | Feature | Description |
|----|--------------------|--------------------------------------------------------------------------------------------------------------------|
| โš™๏ธ | Architecture | The bot utilizes a modular architecture with separate directories for commands, services, models, and utilities, promoting maintainability and scalability. |
| ๐Ÿ“„ | Documentation | This README file provides a detailed overview of the project, its dependencies, and instructions for installation and usage.|
| ๐Ÿ”— | Dependencies | The project relies on external libraries and packages such as `discord.js`, `mongoose`, `dotenv`, and `axios`, which are essential for interacting with the Discord API, managing data, and handling environment variables.|
| ๐Ÿงฉ | Modularity | The modular structure allows for easy maintenance and reusability of the code, with separate directories for different functionalities, including commands, services, and models.|
| ๐Ÿงช | Testing | The project includes unit tests for critical components, ensuring code reliability and preventing regressions. |
| โšก๏ธ | Performance | The bot is optimized for performance by utilizing asynchronous operations, caching strategies, and efficient data structures. |
| ๐Ÿ” | Security | Security measures are implemented to protect user data and prevent unauthorized access, including input validation, sanitization, and rate limiting. |
| ๐Ÿ”€ | Version Control| Utilizes Git for version control with GitHub Actions workflow files for automated build and release processes.|
| ๐Ÿ”Œ | Integrations | The bot integrates with various services, including Discord API for interacting with Discord servers and channels, and OpenAI for natural language processing and AI-powered features.|
| ๐Ÿ“ถ | Scalability | The project is designed to handle a growing number of users and commands, utilizing efficient database and server configurations, and leveraging cloud-based hosting platforms for scalability. |

## ๐Ÿ“‚ Structure

```
discord-status-management-bot/
โ”œโ”€โ”€ commands
โ”‚ โ”œโ”€โ”€ status
โ”‚ โ”‚ โ”œโ”€โ”€ set.js
โ”‚ โ”‚ โ”œโ”€โ”€ update.js
โ”‚ โ”‚ โ”œโ”€โ”€ remove.js
โ”‚ โ”‚ โ”œโ”€โ”€ show.js
โ”‚ โ”‚ โ””โ”€โ”€ help.js
โ”‚ โ”œโ”€โ”€ minigames
โ”‚ โ”‚ โ”œโ”€โ”€ trivia.js
โ”‚ โ”‚ โ”œโ”€โ”€ wordle.js
โ”‚ โ”‚ โ”œโ”€โ”€ hangman.js
โ”‚ โ”‚ โ””โ”€โ”€ help.js
โ”‚ โ”œโ”€โ”€ server
โ”‚ โ”‚ โ”œโ”€โ”€ settings.js
โ”‚ โ”‚ โ”œโ”€โ”€ roles.js
โ”‚ โ”‚ โ”œโ”€โ”€ channels.js
โ”‚ โ”‚ โ””โ”€โ”€ help.js
โ”‚ โ”œโ”€โ”€ moderation
โ”‚ โ”‚ โ”œโ”€โ”€ mute.js
โ”‚ โ”‚ โ”œโ”€โ”€ unmute.js
โ”‚ โ”‚ โ”œโ”€โ”€ kick.js
โ”‚ โ”‚ โ”œโ”€โ”€ ban.js
โ”‚ โ”‚ โ”œโ”€โ”€ warn.js
โ”‚ โ”‚ โ””โ”€โ”€ help.js
โ”‚ โ”œโ”€โ”€ info
โ”‚ โ”‚ โ”œโ”€โ”€ serverinfo.js
โ”‚ โ”‚ โ”œโ”€โ”€ userinfo.js
โ”‚ โ”‚ โ”œโ”€โ”€ help.js
โ”‚ โ”‚ โ””โ”€โ”€ stats.js
โ”‚ โ”œโ”€โ”€ profile
โ”‚ โ”‚ โ”œโ”€โ”€ settheme.js
โ”‚ โ”‚ โ”œโ”€โ”€ setbackground.js
โ”‚ โ”‚ โ”œโ”€โ”€ setprofilepic.js
โ”‚ โ”‚ โ””โ”€โ”€ help.js
โ”‚ โ”œโ”€โ”€ polls
โ”‚ โ”‚ โ”œโ”€โ”€ create.js
โ”‚ โ”‚ โ”œโ”€โ”€ vote.js
โ”‚ โ”‚ โ”œโ”€โ”€ results.js
โ”‚ โ”‚ โ””โ”€โ”€ help.js
โ”‚ โ”œโ”€โ”€ music
โ”‚ โ”‚ โ”œโ”€โ”€ play.js
โ”‚ โ”‚ โ”œโ”€โ”€ skip.js
โ”‚ โ”‚ โ”œโ”€โ”€ stop.js
โ”‚ โ”‚ โ”œโ”€โ”€ queue.js
โ”‚ โ”‚ โ”œโ”€โ”€ loop.js
โ”‚ โ”‚ โ”œโ”€โ”€ nowplaying.js
โ”‚ โ”‚ โ””โ”€โ”€ help.js
โ”‚ โ”œโ”€โ”€ roles
โ”‚ โ”‚ โ”œโ”€โ”€ create.js
โ”‚ โ”‚ โ”œโ”€โ”€ assign.js
โ”‚ โ”‚ โ”œโ”€โ”€ remove.js
โ”‚ โ”‚ โ””โ”€โ”€ help.js
โ”‚ โ”œโ”€โ”€ automation
โ”‚ โ”‚ โ”œโ”€โ”€ schedule.js
โ”‚ โ”‚ โ”œโ”€โ”€ remind.js
โ”‚ โ”‚ โ””โ”€โ”€ help.js
โ”‚ โ””โ”€โ”€ help.js
โ”œโ”€โ”€ events
โ”‚ โ”œโ”€โ”€ ready.js
โ”‚ โ”œโ”€โ”€ messageCreate.js
โ”‚ โ”œโ”€โ”€ interactionCreate.js
โ”‚ โ”œโ”€โ”€ guildMemberAdd.js
โ”‚ โ”œโ”€โ”€ guildMemberRemove.js
โ”‚ โ””โ”€โ”€ guildMemberUpdate.js
โ”œโ”€โ”€ services
โ”‚ โ”œโ”€โ”€ statusService.js
โ”‚ โ”œโ”€โ”€ minigameService.js
โ”‚ โ”œโ”€โ”€ serverService.js
โ”‚ โ”œโ”€โ”€ moderationService.js
โ”‚ โ”œโ”€โ”€ infoService.js
โ”‚ โ”œโ”€โ”€ profileService.js
โ”‚ โ”œโ”€โ”€ pollService.js
โ”‚ โ”œโ”€โ”€ musicService.js
โ”‚ โ”œโ”€โ”€ roleService.js
โ”‚ โ””โ”€โ”€ automationService.js
โ”œโ”€โ”€ models
โ”‚ โ”œโ”€โ”€ statusModel.js
โ”‚ โ”œโ”€โ”€ userModel.js
โ”‚ โ”œโ”€โ”€ serverModel.js
โ”‚ โ”œโ”€โ”€ pollModel.js
โ”‚ โ”œโ”€โ”€ musicQueueModel.js
โ”‚ โ””โ”€โ”€ automationModel.js
โ”œโ”€โ”€ utils
โ”‚ โ”œโ”€โ”€ commandHandler.js
โ”‚ โ”œโ”€โ”€ logger.js
โ”‚ โ”œโ”€โ”€ errorHandler.js
โ”‚ โ”œโ”€โ”€ helperFunctions.js
โ”‚ โ””โ”€โ”€ configLoader.js
โ”œโ”€โ”€ config
โ”‚ โ”œโ”€โ”€ env.config.js
โ”‚ โ””โ”€โ”€ database.config.js
โ”œโ”€โ”€ .env
โ”œโ”€โ”€ package.json
โ””โ”€โ”€ README.md
```

## ๐Ÿ’ป Installation
### ๐Ÿ”ง Prerequisites
- Node.js (v16 or higher)
- npm (or yarn)
- MongoDB
- Docker (optional)

### ๐Ÿš€ Setup Instructions
1. Clone the repository:
- `git clone https://github.com/coslynx/discord-status-management-bot.git`
2. Navigate to the project directory:
- `cd discord-status-management-bot`
3. Install dependencies:
- `npm install`
4. Set up MongoDB:
- Create a new MongoDB database.
- Set up environment variables in the `.env` file:
- `MONGO_URI`: Your MongoDB connection string.
5. Create a Discord bot application:
- Go to the [Discord Developer Portal](https://discord.com/developers/applications) and create a new application.
- Create a bot user for your application.
- Obtain your bot token (keep it secret!).
6. Set up bot token:
- Add your bot token to the `.env` file:
- `DISCORD_TOKEN`: Your bot token.
7. Start the bot:
- `npm start`

## ๐Ÿ—๏ธ Usage

### Adding the Bot to Your Server:
1. Go to the Discord Developer Portal and navigate to your bot application.
2. In the "OAuth2" tab, select "Bot" for the "Scope" and check the "bot" permission.
3. Click on "Copy" to copy the generated link.
4. Open this link in your browser and authorize the bot to join your server.

### โš™๏ธ Configuration
Adjust configuration settings in `config/env.config.js` and `config/database.config.js`.

### ๐Ÿ“š Examples

Setting a Status:

```
/set status "Playing my favorite game" -image [image url] -badge [badge name]
```

Playing a Trivia Game:

```
/trivia start
```

Muting a Member:

```
/mute [member id] [reason]
```

Using the Help Command:

```
/help [command name]
```

Additional Command Examples:
- `/update status`: Updates your current status.
- `/remove status`: Removes your current status.
- `/show status`: Displays your current status.
- `/serverinfo`: Displays server information.
- `/userinfo [member id]`: Displays user information.
- `/music play [song name]`: Plays a song.
- `/music skip`: Skips the current song.
- `/music stop`: Stops music playback.
- `/poll create [question] [options]`: Creates a poll.
- `/role create [role name] [permissions]`: Creates a role.
- `/role assign [member id] [role name]`: Assigns a role to a member.
- `/role remove [member id] [role name]`: Removes a role from a member.
- `/schedule [time] [task]`: Schedules a task.
- `/remind [time] [message]`: Sets a reminder.

## ๐ŸŒ Hosting
### ๐Ÿš€ Deployment Instructions
1. Build the project:
- `npm run build`
2. Deploy the build output to a hosting platform:
- Heroku:
- Create a new Heroku app.
- Set up environment variables (MONGO_URI, DISCORD_TOKEN) in the Heroku app settings.
- Push the build output to the Heroku app's Git repository.
- AWS:
- Create a new AWS EC2 instance.
- Install Node.js, npm, and MongoDB on the instance.
- Configure environment variables.
- Deploy the build output to the EC2 instance.
- Other Platforms:
- Use a similar process based on the chosen hosting platform's documentation.

### ๐Ÿ”‘ Environment Variables
- `MONGO_URI`: MongoDB connection string.
- `DISCORD_TOKEN`: Discord bot token.

## ๐Ÿ“œ License
This project is licensed under the [MIT License](https://choosealicense.com/licenses/mit/).

## ๐Ÿ‘ฅ Authors
- Author Name - [Spectra.codes](https://spectra.codes)
- Creator Name - [DRIX10](https://github.com/Drix10)


๐ŸŒ Spectra.Codes




Why only generate Code? When you can generate the whole Repository!