Skip to content

Project: Discord Study Bot: Notes, Books, & More. Created at https://spectra.codes, which is owned by @Drix10

Notifications You must be signed in to change notification settings

coslynx/discord-student-study-bot

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

30 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation


discord-student-study-bot

Discord Bot for Students: Streamline Study Resources and Enhance Collaboration

Developed with the software and tools below.

Framework - Discord.js Language - JavaScript Database - MySQL LLMs - OpenAI

git-last-commit GitHub commit activity GitHub top language

πŸ“‘ Table of Contents

  • πŸ“ Overview
  • πŸ“¦ Features
  • πŸ“‚ Structure
  • πŸ’» Installation
  • πŸ—οΈ Usage
  • 🌐 Hosting
  • πŸ“„ License
  • πŸ‘ Authors

πŸ“ Overview

The repository contains a project called "discord-student-study-bot" that provides a comprehensive solution for students to find and share study materials, collaborate in study groups, and access personalized learning resources, all within the familiar interface of Discord. The bot leverages JavaScript, Discord.js, MySQL, and OpenAI APIs to deliver a seamless and engaging learning experience.

πŸ“¦ Features

Feature Description
βš™οΈ Architecture The codebase follows a modular architectural pattern with separate directories for different functionalities, ensuring easier maintenance and scalability.
πŸ“„ Documentation The repository includes a README file that provides a detailed overview of the project, its dependencies, and usage instructions.
πŸ”— Dependencies The codebase relies on various external libraries and packages such as Discord.js, node-fetch, dotenv, mysql2, Prisma, bcrypt, jsonwebtoken, and googleapis.
🧩 Modularity The modular structure allows for easier maintenance and reusability of the code, with separate directories and files for commands, events, services, models, and utilities.
πŸ§ͺ Testing Implement unit tests using frameworks like Jest to ensure the reliability and robustness of the codebase.
⚑️ Performance The performance of the system can be optimized based on factors such as the browser and hardware being used. Consider implementing performance optimizations for better efficiency.
πŸ” Security Enhance security by implementing measures such as input validation, data encryption, and secure communication protocols.
πŸ”€ Version Control Utilizes Git for version control with GitHub Actions workflow files for automated build and release processes.
πŸ”Œ Integrations Interacts with Discord API, OpenAI API, Google Books API, and potentially other APIs like Cloudinary for file management.
πŸ“Ά Scalability Design the system to handle increased user load and data volume, utilizing caching strategies and cloud-based solutions for better scalability.

πŸ“‚ Structure

β”œβ”€β”€ commands
β”‚   β”œβ”€β”€ help.js
β”‚   β”œβ”€β”€ notes.js
β”‚   β”œβ”€β”€ books.js
β”‚   β”œβ”€β”€ resources.js
β”‚   β”œβ”€β”€ group.js
β”‚   └── study.js
β”œβ”€β”€ events
β”‚   β”œβ”€β”€ ready.js
β”‚   β”œβ”€β”€ message.js
β”‚   └── guildMemberAdd.js
β”œβ”€β”€ services
β”‚   β”œβ”€β”€ authenticationService.js
β”‚   β”œβ”€β”€ notesService.js
β”‚   β”œβ”€β”€ booksService.js
β”‚   β”œβ”€β”€ resourcesService.js
β”‚   β”œβ”€β”€ groupService.js
β”‚   β”œβ”€β”€ databaseService.js
β”‚   └── permissionService.js
β”œβ”€β”€ models
β”‚   β”œβ”€β”€ User.js
β”‚   β”œβ”€β”€ Note.js
β”‚   β”œβ”€β”€ Book.js
β”‚   β”œβ”€β”€ Resource.js
β”‚   β”œβ”€β”€ Group.js
β”‚   └── Server.js
β”œβ”€β”€ utils
β”‚   β”œβ”€β”€ commandHandler.js
β”‚   β”œβ”€β”€ logger.js
β”‚   └── errorHandler.js
β”œβ”€β”€ config
β”‚   β”œβ”€β”€ env.config.js
β”‚   └── database.config.js
β”œβ”€β”€ .env
β”œβ”€β”€ package.json
└── README.md

πŸ’» Installation

πŸ”§ Prerequisites

  • Node.js
  • npm
  • Docker

πŸš€ Setup Instructions

  1. Clone the repository:
  2. Navigate to the project directory:
    • 'cd discord-student-study-bot'
  3. Install dependencies:
    • 'npm install'

πŸ—οΈ Usage

πŸƒβ€β™‚οΈ Running the Project

  1. Start the development server:
    • 'npm start'
  2. Open your browser and navigate to http://localhost:3000.

βš™οΈ Configuration

Adjust configuration settings in 'config.js' or '.env'.

πŸ“š Examples

  • πŸ“ Example 1: Use the !study help command to view a list of available commands.
  • πŸ“ Example 2: Use !study notes add [title] [content] to add a new note.
  • πŸ“ Example 3: Use !study books search [book title] to find book information.

🌐 Hosting

πŸš€ Deployment Instructions

  1. Create a Heroku account:
  2. Install the Heroku CLI:
    • 'npm install -g heroku'
  3. Login to Heroku:
    • 'heroku login'
  4. Create a new Heroku app:
    • 'heroku create'
  5. Deploy the code:
    • 'git push heroku main'

πŸ”‘ Environment Variables

  • 'DISCORD_TOKEN': Your Discord bot token
  • 'DB_HOST': Database host
  • 'DB_USER': Database user
  • 'DB_PASS': Database password
  • 'OPENAI_API_KEY': Your OpenAI API key
  • 'GOOGLE_BOOKS_API_KEY': Your Google Books API key

πŸ“œ API Documentation

πŸ” Endpoints

  • POST /api/auth/register: Registers a new user.
  • POST /api/auth/login: Logs in an existing user.
  • GET /api/notes: Retrieves a list of notes for the authenticated user.
  • POST /api/notes: Creates a new note for the authenticated user.
  • PUT /api/notes/:id: Updates an existing note for the authenticated user.
  • DELETE /api/notes/:id: Deletes an existing note for the authenticated user.
  • GET /api/books/search: Searches for books based on a given query.
  • GET /api/books/:id: Retrieves details about a specific book.
  • GET /api/resources: Retrieves a list of resources.
  • POST /api/resources: Creates a new resource.
  • PUT /api/resources/:id: Updates an existing resource.
  • DELETE /api/resources/:id: Deletes an existing resource.
  • POST /api/groups: Creates a new study group.
  • GET /api/groups/:id/members: Retrieves members of a specific group.
  • POST /api/groups/:id/join: Joins a study group.
  • DELETE /api/groups/:id/leave: Leaves a study group.

πŸ”’ Authentication

Use JWT tokens for authentication.

πŸ“ Examples

πŸ“œ License

This project is licensed under the GNU AGPLv3.

πŸ‘₯ Authors

🌐 Spectra.Codes

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