93 lines
3.3 KiB
Markdown
93 lines
3.3 KiB
Markdown
<h1 align="center">HoloBot Discord</h1>
|
|
|
|
<p align="center">Small Discord bot made on Py-Cord</p>
|
|
|
|
<p align="center">
|
|
<a href="https://git.end-play.xyz/HoloUA/Discord/src/branch/master/LICENSE"><img alt="License: GPL" src="https://img.shields.io/badge/License-GPL-blue"></a>
|
|
<a href="https://git.end-play.xyz/HoloUA/Discord"><img alt="Code style: black" src="https://img.shields.io/badge/code%20style-black-000000.svg"></a>
|
|
</p>
|
|
|
|
## Installation from release
|
|
|
|
1. Install MongoDB using the [official installation manual](https://www.mongodb.com/docs/manual/installation)
|
|
2. Install Python 3.11+
|
|
3. Download the [latest release](https://git.end-play.xyz/HoloUA/Discord/releases/latest)'s archive
|
|
4. Extract the archive
|
|
5. Navigate to the extracted folder and subfolder `Discord` in it
|
|
6. Create a virtual environment:
|
|
`python -m venv .venv` or `virtualenv .venv`
|
|
7. Activate the virtual environment:
|
|
Windows: `.venv\Scripts\activate.bat`
|
|
Linux/macOS: `.venv/bin/activate`
|
|
8. Install the dependencies:
|
|
`python -m pip install -r requirements.txt`
|
|
9. Run the bot with `python main.py` after completing the [configuration](#Configuration)
|
|
|
|
## Installation with Git
|
|
|
|
1. Install MongoDB using the [official installation manual](https://www.mongodb.com/docs/manual/installation)
|
|
2. Install Python 3.11+
|
|
3. Clone the repository:
|
|
`git clone https://git.end-play.xyz/HoloUA/Discord.git`
|
|
4. `cd Discord`
|
|
5. Create a virtual environment:
|
|
`python -m venv .venv` or `virtualenv .venv`
|
|
6. Activate the virtual environment:
|
|
Windows: `.venv\Scripts\activate.bat`
|
|
Linux/macOS: `.venv/bin/activate`
|
|
7. Install the dependencies:
|
|
`python -m pip install -r requirements.txt`
|
|
8. Run the bot with `python main.py` after completing the [configuration](#Configuration)
|
|
|
|
## Upgrading with Git
|
|
|
|
1. Go to the bot's directory
|
|
2. `git pull`
|
|
3. Activate the virtual environment:
|
|
Windows: `.venv\Scripts\activate.bat`
|
|
Linux/macOS: `.venv/bin/activate`
|
|
4. Update the dependencies:
|
|
`python -m pip install -r requirements.txt`
|
|
5. First start after the upgrade must initiate the migration:
|
|
`python main.py --migrate`
|
|
6. Now the bot is up to date and the next run will not require `--migrate` anymore
|
|
|
|
## Configuration
|
|
|
|
There's a file `config_example.json` which contains default configuration
|
|
and should be used as a base config.
|
|
|
|
Copy this file to `config.json` and open it with any text editor of your liking.
|
|
|
|
Modify the newly created configuration file to fit your needs.
|
|
|
|
Mandatory keys to modify:
|
|
|
|
- guild
|
|
- bot.owner
|
|
- bot.bot_token
|
|
- database.*
|
|
- categories.*
|
|
- channels.*
|
|
- roles.*
|
|
|
|
After all of that you're good to go! Happy using :)
|
|
|
|
## Docker [Experimental]
|
|
|
|
As an experiment, Docker deployment option has been added.
|
|
|
|
### Building the image
|
|
|
|
1. `git clone https://git.end-play.xyz/HoloUA/Discord.git`
|
|
2. `cd Discord`
|
|
3. `docker build -t holoua-discord .`
|
|
|
|
### Starting the bot
|
|
|
|
1. Install MongoDB using the [official installation manual](https://www.mongodb.com/docs/manual/installation)
|
|
2. Download
|
|
the [configuration example file](https://git.end-play.xyz/HoloUA/Discord/src/branch/main/config_example.json) and
|
|
store it somewhere you would like your bot to access it
|
|
3. Complete the [configuration](#Configuration) step for this file
|
|
4. `docker run -d -v /path/to/config.json:/app/config.json holoua-discord` |