Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ar4ikov/rouneford
Дискорд-Бот с поддержкой создания и подключения плагинов с удобной системой настройки
https://github.com/ar4ikov/rouneford
api bot discord discord-api discord-bot plugins python
Last synced: 3 months ago
JSON representation
Дискорд-Бот с поддержкой создания и подключения плагинов с удобной системой настройки
- Host: GitHub
- URL: https://github.com/ar4ikov/rouneford
- Owner: Ar4ikov
- License: mit
- Created: 2019-02-18T15:58:50.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2021-10-19T16:44:32.000Z (about 3 years ago)
- Last Synced: 2024-10-04T17:42:23.473Z (3 months ago)
- Topics: api, bot, discord, discord-api, discord-bot, plugins, python
- Language: Python
- Homepage:
- Size: 1.49 MB
- Stars: 11
- Watchers: 5
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
- License: LICENSE
Awesome Lists containing this project
README
### Технические шоколадки!
> С момента релиза данного продукта у `discord.py` изменился некоторый функционал, который конфликтуает с актуальной версией продукта, из-за чего запуск продукта может
> сопровождаться некорректным поведением (или отсутствием признаков жизни). Постараюсь исправить ситуацию в ближайшие сроки, но не претендую на столь высокую срочность.
---# RounefordBot
А зачем? А нафига? Да просто так!
Коротко о боте:
---
- Открытость и свободно редактируемый код, понятный и удобный для разработки
- Поддержка сторонних плагинов
- Реализация на официальном API - discord.py (https://discordpy.readthedocs.io)
- Простота в настройке и дополнении
- Удобный функционал засчёт добавления кастомных функций
- Стартовые плагины для полноценной функциональности бота на сервере, включая стриминг аудио## 1. Установка
- #### Установка на устройство
Установка производится путём клонирования репозитория на ваше устройство
```console
root@Ar4kov:~$ git clone https://github.com/Ar4ikov/Rouneford/ Rounedford
```- #### Установка дополнений
Для работы бота необходимо иметь в наличии библиотеки: `discord.py`, `youtube-dl`, `ffmpeg` и `asyncio` (Стандартную, если таковой не
имелось изначально)```console
root@Ar4ikov:~$ pip install discord.py[voice]
root@Ar4ikov:~$ pip install youtube-dl
root@Ar4ikov:~$ pip install asyncio
root@Ar4ikov:~$ pip install ffmpeg
```## 2. Настройка и запуск бота
- #### Получение токена бота
Больше информации о получении Access-token бота вы можете получить [`тут`](https://github.com/reactiflux/discord-irc/wiki/Creating-a-discord-bot-%26-getting-a-token)
- #### Настройка `bot.py`
```python
from core.core import RounefordBotbot = RounefordBot(access_token="Ваш-Bot-Token")
bot.run()```
## 3. Создание собственных плагинов
### Список стандартных плагинов будет пополняться.
- #### Создание директории
Необходимо создать директорию плагина в папке `plugins`, которая должна выглядеть следующим образом:
```console
├── __init__.py
├── plugin.py
└── немного файлов здесь
```В файле `__init__.py` необходимо импортировать ваш основной класс плагина
```python
from plugins.TestPlugin.test_plugin import Plugin
```- #### Инициализация класса
Класс может иметь абсолютно любое название, однако должен содержать следующие свойства ниже и быть унаследован от класса
`core.api.BotPlugin````python
from core.api import BotPlugin
from discord.ext.commands import Bot as Clientclass Plugin(BotPlugin):
def __init__(self, client: Client):
super().__init__(client)self.plugin_name = "Test Plugin" # Имя плагина
self.author = "https://github.com/Ar4ikov/" # Автор
self.version = "1.0.1" # Версия
self.plugin_id = "test_plugin" # Id плагина
self.description = """Simple plugin""" # Описание
self.tasks = ["task_1"] # Имена фоновых задач
self.commands = {} # Описание команд плагина вида {"command": "how works"}
```- #### Определение фоновых задач
```python
from asyncio import sleepasync def background_task_1(self):
"""Имя фоновой задачи выглядит следующим образом:
- background_{name}
где:
- {name} - Имя задачи из `self.tasks`"""
while True:
await sleep(1)
print(self.plugin_name, "Готов к труду и обороне!")```
- #### Определение команд
```python
async def cmd_kek(self, channel, member, *args, **kwargs):
await self.send_message(channel, "Вас только что 'кекнули'!")
```- #### Логирование
```python
from core.objects import Logger
logger = Logger("my_logs")
logger.log(self, "info")# self - сам класс плагина, в котором происходит логирование
# Клиент содержит в себе экзлемпляр класса Logger, но вы можете создать свой логгер (как это сделано выше)
self.client.logging.log(self, "Запущен новый процесс")
self.client.logging.log(self, "{} >> [}".format(member.name, " ".join(args)))
```- #### Запуск плагина
```python
from discord import Member # Не несёт смысловой нагрузки, исключительно в косметических целяхasync def run(self):
super().run()
@self.client.listen()
async def on_member_join(member: Member):
print(member.name, "зашёл на сервер!")
```