0.7 Теперь появился логгер на старты

This commit is contained in:
Verum
2025-02-24 04:02:12 +07:00
parent f48d439a7b
commit 589b915206
17 changed files with 332 additions and 169 deletions

View File

@@ -1,5 +0,0 @@
# BotCode/routers/commands/cmd_class/__init__.py
# Инициализация модуля cmd_class, для пользовательских классов команд
# Экспортирование модулей во внешние слои проекта
from .user_cmd_class import *

View File

@@ -1,54 +0,0 @@
# BotCode/routers/commands/user_cmd_class.py
# Класс-шаблон для создания новых команд
from aiogram import Router, types
from aiogram.filters import Command
from BotLibrary import *
# Класс-шаблон для команд
class CommandHandler:
def __init__(self, name: str, keywords : list,
description: str = "Описание команды", text_msg : str = "Сообщение",
keyboard = None, prefix = BotVar.prefix, callbackdata = None,
ignore_case : bool = True, activate_keywoards : bool = True,
activate_commands : bool = True, activate_callback : bool = True,
):
"""
Универсальный обработчик команд для бота.
:param name: Имя команды (например, "help").
:param description: Описание команды.
:param keywords: Список ключевых слов, которые активируют команду.
:param text_msg: Текст сообщения, который отправляется пользователю.
:param keyboard: Клавиатура, если требуется.
"""
self.router = Router(name=f"{name}_router")
self.name = name
self.log_type = name.capitalize()
self.description = description
self.keywords = keywords
self.callbackdata = callbackdata
self.text_msg = text_msg
self.keyboard = keyboard
# Привязываем хэндлер к роутеру
if activate_commands:
self.router.message(Command(*keywords, prefix=prefix, ignore_case=ignore_case))(self.handler)
if activate_keywoards:
self.router.message(F.text.lower().in_(keywords))(self.handler)
if activate_callback:
self.router.message(F.text.lower().in_(callbackdata))(self.handler)
async def handler(self, message: types.Message):
"""Основной хэндлер команды."""
try:
Logs.info(log_type=self.name.capitalize(), user=username(message), text=f"использовал(а) команду /{self.name}")
await message.reply(
text=self.text_msg,
reply_markup=self.keyboard() if self.keyboard else None,
)
# Проверка на ошибку
except Exception as e:
Logs.error(log_type=self.name.capitalize(), user=username(message), text=f"Ошибка команды: {e}")

View File

@@ -1,12 +1,13 @@
# BotCode/routers/commands/user_cmd/help_cmd.py
# Работа с командой /help, для вывода помощи пользователю
from ..cmd_class.user_cmd_class import CommandHandler
from BotLibrary.samples.user_cmd_class import CommandHandler
# Создание команды /help с нужными параметрами
help_cmd = CommandHandler(
name="help",
description="Получить помощь",
keywords=["help", "info", "помощь", "инфо", "информация", "рудз", "штащ", "byaj", "gjvjom", "byajhvfwbz"],
callbackdata="keywords",
text_msg="Привет! Это команда помощи. Тут ты можешь узнать, как пользоваться ботом.",
)

View File

@@ -1,7 +1,7 @@
# BotCode/routers/commands/user_cmd/start_cmd.py
# # Работа с командой /start, для запуска бота
from ..cmd_class.user_cmd_class import CommandHandler
from BotLibrary.samples.user_cmd_class import CommandHandler
from BotCode.keyboards import get_start_kb
# Создание команды /start с нужными параметрами
@@ -10,6 +10,8 @@ start_cmd = CommandHandler(
description="Добро пожаловать!",
keywords=["start", "старт", "запуск", "пуск", "on", "вкл", "с", "s", "ы",
"ыефке", "cnfhn", "pfgecr", "gecr", "щт", "drk", "restart", "куыефке"],
callbackdata="keywords",
text_msg="Старт!",
keyboard=get_start_kb,
chat_action=True
)