2.0 Да я ебал это все рассписывать но тут типо новая система логгирования
This commit is contained in:
@@ -1,8 +1,6 @@
|
||||
# BotLibrary/loggers/__init__.py
|
||||
# Инициализация пакета loggers, для создания логеров
|
||||
# Инициализация под-пакета loggers, для настройки логеров
|
||||
|
||||
# Экспортирование модулей во внешние слои проекта
|
||||
from .logs import *
|
||||
from .msg_logger import *
|
||||
from .custom_loggers import *
|
||||
from .start_info_out import *
|
||||
|
||||
@@ -1,10 +1,17 @@
|
||||
# BotLibrary/loggers/custom_loggers.py
|
||||
# Кастомные логгеры для проекта, с более стандартизированным использованием
|
||||
|
||||
from time import sleep
|
||||
from colorama import Fore
|
||||
from loguru import logger
|
||||
from ..validators import username
|
||||
from aiogram.types import Message
|
||||
|
||||
from BotLibrary.system.bots import BotInfo
|
||||
from BotLibrary.validators.username import username
|
||||
from BotLibrary.analytics.type_msg import type_msg
|
||||
|
||||
from ProjectsFiles import BotLogs, Permissions, ProjectPath, BotVar, bot_owner
|
||||
|
||||
# Настройка экспорта из модуля
|
||||
__all__ = ("Logs",)
|
||||
|
||||
@@ -13,8 +20,10 @@ class Logs:
|
||||
"""Класс для логирования с разными уровнями через loguru."""
|
||||
|
||||
@staticmethod
|
||||
def start(text: str = "Логирование!", system: str = "PRIMO",
|
||||
log_type: str = "AEP", user: str = "@Console") -> None:
|
||||
def start(text: str = "Логирование!",
|
||||
system: str = "PRIMO",
|
||||
log_type: str = "AEP",
|
||||
user: str = "@Console") -> None:
|
||||
"""
|
||||
Логирует сообщение на уровне DEBUG.
|
||||
|
||||
@@ -22,12 +31,18 @@ class Logs:
|
||||
:param text: Сообщение для логирования.
|
||||
:param log_type: Тип лога (например, "Logs").
|
||||
:param user: Имя пользователя или источник вызова лога.
|
||||
|
||||
:return: Вывод сообщения об старте бота
|
||||
"""
|
||||
logger.bind(system=system, user=user, log_type=log_type).log("START", text)
|
||||
|
||||
|
||||
@staticmethod
|
||||
def debug(text: str = "Логирование!", system : str = "DEBUG",
|
||||
log_type: str = "Logs", user: str = "@Console", message: Message = None) -> None:
|
||||
def debug(text: str = "Логирование!",
|
||||
system: str = "DEBUG",
|
||||
log_type: str = "Logs",
|
||||
user: str = "@Console",
|
||||
message: Message = None) -> None:
|
||||
"""
|
||||
Логирует сообщение на уровне DEBUG.
|
||||
|
||||
@@ -36,14 +51,20 @@ class Logs:
|
||||
:param log_type: Тип лога (например, "Logs").
|
||||
:param user: Имя пользователя или источник вызова лога.
|
||||
:param message: Сообщение от пользователя, если необходимо извлечь имя.
|
||||
|
||||
:return: Вывод сообщения об дебаг-информации
|
||||
"""
|
||||
if message:
|
||||
user = username(message)
|
||||
logger.bind(system=system, log_type=log_type, user=user).debug(text)
|
||||
|
||||
|
||||
@staticmethod
|
||||
def info(text: str = "Логирование!", system : str = "PRIMO",
|
||||
log_type: str = "Logs", user: str = "@Console", message: Message = None) -> None:
|
||||
def info(text: str = "Логирование!",
|
||||
system: str = "PRIMO",
|
||||
log_type: str = "Logs",
|
||||
user: str = "@Console",
|
||||
message: Message = None) -> None:
|
||||
"""
|
||||
Логирует сообщение на уровне INFO.
|
||||
|
||||
@@ -52,14 +73,20 @@ class Logs:
|
||||
:param log_type: Тип лога (например, "Logs").
|
||||
:param user: Имя пользователя или источник вызова лога.
|
||||
:param message: Сообщение от пользователя, если необходимо извлечь имя.
|
||||
|
||||
:return: Вывод сообщения об некой информации
|
||||
"""
|
||||
if message:
|
||||
user = username(message)
|
||||
logger.bind(system=system, log_type=log_type, user=user).info(text)
|
||||
|
||||
|
||||
@staticmethod
|
||||
def warning(text: str = "Логирование!", system : str = "WARNING",
|
||||
log_type: str = "Logs", user: str = "@Console", message: Message = None) -> None:
|
||||
def warning(text: str = "Логирование!",
|
||||
system: str = "WARNING",
|
||||
log_type: str = "Logs",
|
||||
user: str = "@Console",
|
||||
message: Message = None) -> None:
|
||||
"""
|
||||
Логирует сообщение на уровне WARNING.
|
||||
|
||||
@@ -68,14 +95,20 @@ class Logs:
|
||||
:param log_type: Тип лога (например, "Logs").
|
||||
:param user: Имя пользователя или источник вызова лога.
|
||||
:param message: Сообщение от пользователя, если необходимо извлечь имя.
|
||||
|
||||
:return: Вывод сообщения об предупреждении
|
||||
"""
|
||||
if message:
|
||||
user = username(message)
|
||||
logger.bind(system=system, log_type=log_type, user=user).warning(text)
|
||||
|
||||
|
||||
@staticmethod
|
||||
def error(text: str = "Логирование!", system : str = "ERROR",
|
||||
log_type: str = "Logs", user: str = "@Console", message: Message = None) -> None:
|
||||
def error(text: str = "Логирование!",
|
||||
system: str = "ERROR",
|
||||
log_type: str = "Logs",
|
||||
user: str = "@Console",
|
||||
message: Message = None) -> None:
|
||||
"""
|
||||
Логирует сообщение на уровне ERROR.
|
||||
|
||||
@@ -84,7 +117,80 @@ class Logs:
|
||||
:param log_type: Тип лога (например, "Logs").
|
||||
:param user: Имя пользователя или источник вызова лога.
|
||||
:param message: Сообщение от пользователя, если необходимо извлечь имя.
|
||||
|
||||
:return: Вывод сообщения об ошибке
|
||||
"""
|
||||
if message:
|
||||
user = username(message)
|
||||
logger.bind(system=system, log_type=log_type, user=user).error(text)
|
||||
|
||||
|
||||
@staticmethod
|
||||
def msg(message: Message,
|
||||
log_type: str = "Message",
|
||||
permission: bool = BotLogs.permission) -> None:
|
||||
"""
|
||||
Логирует сообщение, если оно не обработано.
|
||||
|
||||
:param message: Сообщение от пользователя
|
||||
:param log_type: Тип лога (по умолчанию "Message")
|
||||
:param permission: Разрешение на логирование (config)
|
||||
|
||||
:return: Вывод сообщения об обычном сообщении пользователя
|
||||
"""
|
||||
# Получаем username или id пользователя
|
||||
user: str = f"@{message.from_user.username or message.from_user.id}"
|
||||
msg_type: str = type_msg(message)
|
||||
|
||||
# Логирование только если разрешено
|
||||
if permission:
|
||||
# Проверка на наличие текста и его типа
|
||||
if message.text is None and msg_type not in ("Новые участники чата", "Ушедший участник чата"):
|
||||
Logs.info(log_type=log_type, user=user, text=f"Получено сообщение из ({message.chat.id}) : {msg_type}")
|
||||
elif message.text is not None:
|
||||
Logs.info(log_type=log_type, user=user,
|
||||
text=f"Получено сообщение из ({message.chat.id}) : {message.text}")
|
||||
|
||||
|
||||
@staticmethod
|
||||
def console(stop_time: int = 1,
|
||||
console: bool = Permissions.start_info_console,
|
||||
file: bool = Permissions.start_info_to_file,
|
||||
path: str = ProjectPath.bot_info_log_file,) -> None:
|
||||
"""
|
||||
Собирает информацию о боте и выводит её в консоль, а также возвращает как строку.
|
||||
|
||||
:param stop_time: Количество времени в секундах, после которых выведется информация (1 сек)
|
||||
:param console: Разрешение на внесение информации в консоль (config)
|
||||
:param file: Разрешение на внесение информации в файл (config)
|
||||
:param path: Путь до файла для сохранения информации о боте (config)
|
||||
|
||||
:return: Информация о боте в виде строки.
|
||||
"""
|
||||
# Собираем данные о боте
|
||||
bot_name: str = f"Основное имя: {BotInfo.first_name}\n"
|
||||
bot_post_name: str = f"Владельцы бота: {bot_owner}\n"
|
||||
bot_username: str = f"Юзернейм: @{BotInfo.username}\n"
|
||||
bot_id: str = f"ID: {BotInfo.id}\n"
|
||||
bot_can_join_groups: str = f"Может ли вступать в группы: {BotInfo.can_join_groups}\n"
|
||||
bot_can_read_all_group_messages: str = f"Чтение всех сообщений: {BotInfo.can_read_all_group_messages}\n"
|
||||
bot_supports_inline_queries: str = f"Поддерживает инлайн-запросы: {BotInfo.supports_inline_queries}\n"
|
||||
bot_can_connect_to_business: str = f"Подключение к бизнес-аккаунтам: {BotInfo.can_connect_to_business}\n"
|
||||
bot_has_main_web_app: str = f"Основное веб-приложение: {BotInfo.has_main_web_app}\n"
|
||||
|
||||
# Формируем полный текст с выводом информации о боте
|
||||
bot_all_info: str = (f"{bot_name} {bot_post_name} {bot_username} {bot_id} "
|
||||
f"{bot_can_join_groups} {bot_can_read_all_group_messages} "
|
||||
f"{bot_supports_inline_queries} {bot_can_connect_to_business} "
|
||||
f"{bot_has_main_web_app}")
|
||||
|
||||
# Печатаем всю информацию в консоль с задержкой
|
||||
if console:
|
||||
sleep(stop_time)
|
||||
print(Fore.CYAN + bot_all_info)
|
||||
|
||||
# Печатаем всю информацию в файл
|
||||
if file:
|
||||
# Преобразуем словарь bot_all_info в строку и записываем в файл
|
||||
with open(path, 'w', encoding=BotVar.encod) as file:
|
||||
file.write(str(bot_all_info))
|
||||
|
||||
@@ -1,33 +1,45 @@
|
||||
# BotLibrary/system/logs.py
|
||||
# BotLibrary/loggers/logs.py
|
||||
# Создание логгеров и их шаблон для проекта
|
||||
|
||||
import sys
|
||||
from loguru import logger
|
||||
from ProjectsFiles import BotLogs, ProjectPath
|
||||
|
||||
# Настройка экспорта из модуля
|
||||
__all__ = ("setup_logger",)
|
||||
|
||||
# Создание обычного логгера + логгер в файл
|
||||
async def setup_logger() -> None:
|
||||
async def setup_logger(logging: bool = BotLogs.permission,
|
||||
to_file: bool = BotLogs.permission_to_file) -> None:
|
||||
"""
|
||||
Настройка логгеров для проекта, выводящих логи в консоль.
|
||||
Логгеры конфигурируются в зависимости от настроек в BotLogs.
|
||||
Настройка логгеров для проекта, выводящих логи в консоль и файлы.
|
||||
Логгеры конфигурируются в зависимости от настроек в конфигах проекта.
|
||||
|
||||
Если разрешено логирование, добавляются логи для уровней DEBUG, INFO, WARNING, ERROR.
|
||||
"""
|
||||
logger.remove() # Удаляем все логгеры
|
||||
И кастомные такие, как START, NEW_USER, LEAVE_USER
|
||||
|
||||
if BotLogs.permission and BotLogs.permission_to_file:
|
||||
:param logging: Разрешение на логирование в консоль (config)
|
||||
:param to_file: Разрешение на логирование в файл (config)
|
||||
|
||||
:return: Создание логеров под различные уровни
|
||||
"""
|
||||
logger.remove() # Удаляем все стандартные логгеры
|
||||
|
||||
|
||||
# Если есть разрешение, то он создает новые уровни
|
||||
if logging and BotLogs.permission_to_file:
|
||||
# Добавляем новый уровень START
|
||||
logger.level("START", no=25, color="white", icon="🔸")
|
||||
if BotLogs.permission and BotLogs.permission_new_user:
|
||||
if logging and BotLogs.permission_new_user:
|
||||
# Добавляем новый уровень NEW_USER
|
||||
logger.level("NEW_USER", no=4, color="white", icon="👋")
|
||||
if BotLogs.permission and BotLogs.permission_leave_user:
|
||||
if logging and BotLogs.permission_leave_user:
|
||||
# Добавляем новый уровень LEAVE_USER
|
||||
logger.level("LEAVE_USER", no=3, color="white", icon="🫰")
|
||||
|
||||
|
||||
# Настройка логирования в консоль для каждого уровня
|
||||
if BotLogs.permission:
|
||||
if logging:
|
||||
logger.add(sys.stderr,
|
||||
colorize=True,
|
||||
format=BotLogs.start_text,
|
||||
@@ -55,8 +67,9 @@ async def setup_logger() -> None:
|
||||
level="ERROR",
|
||||
filter=lambda record: record["level"].name == "ERROR")
|
||||
|
||||
|
||||
# Добавление логгера для записи в файл
|
||||
if BotLogs.permission_to_file:
|
||||
if to_file:
|
||||
logger.add(ProjectPath.start_log_file,
|
||||
rotation=BotLogs.max_size,
|
||||
format=BotLogs.start_text,
|
||||
|
||||
@@ -1,32 +0,0 @@
|
||||
# BotLibrary/loggers/msg_logger.py
|
||||
# Логгер для всех не обработанных сообщений
|
||||
|
||||
from ProjectsFiles import BotLogs
|
||||
from .custom_loggers import Logs
|
||||
from ..analytics.type_msg import types_message
|
||||
from aiogram.types import Message
|
||||
|
||||
# Настройка экспорта из модуля
|
||||
__all__ = ("logger_msg",)
|
||||
|
||||
# Создание функции логирования на обычные сообщения
|
||||
async def logger_msg(message: Message, log_type: str = "Message") -> None:
|
||||
"""
|
||||
Логирует сообщение, если оно не обработано.
|
||||
|
||||
:param message: Сообщение от пользователя.
|
||||
:param log_type: Тип лога (по умолчанию "Message").
|
||||
"""
|
||||
# Получаем username или id пользователя
|
||||
user: str = f"@{message.from_user.username or message.from_user.id}"
|
||||
msg_type = types_message(message)
|
||||
|
||||
# Логирование только если разрешено
|
||||
if BotLogs.permission:
|
||||
# Проверка на наличие текста и его типа
|
||||
if message.text is None and msg_type not in ("Новые участники чата", "Ушедший участник чата"):
|
||||
Logs.info(log_type=log_type, user=user, text=f"Получено сообщение из ({message.chat.id}) : {msg_type}")
|
||||
elif message.text is not None:
|
||||
Logs.info(log_type=log_type, user=user, text=f"Получено сообщение из ({message.chat.id}) : {message.text}")
|
||||
else:
|
||||
return
|
||||
@@ -1,48 +0,0 @@
|
||||
# BotLibrary/loggers/start_info_out.py
|
||||
# Вывод данных бота в консоль для начальной проверки
|
||||
|
||||
from time import sleep
|
||||
from colorama import Fore
|
||||
|
||||
from ProjectsFiles import Permissions, ProjectPath, BotVar, bot_owner
|
||||
from .custom_loggers import Logs
|
||||
from ..system import BotInfo
|
||||
|
||||
# Функция для получения информации о боте и выводе ее в консоль и файл
|
||||
def bot_info_out() -> str:
|
||||
"""
|
||||
Собирает информацию о боте и выводит её в консоль, а также возвращает как строку.
|
||||
|
||||
:return: Информация о боте в виде строки.
|
||||
"""
|
||||
try:
|
||||
# Собираем данные о боте
|
||||
bot_name: str = f"Основное имя: {BotInfo.first_name}\n"
|
||||
bot_post_name: str = f"Владельцы бота: {bot_owner}\n"
|
||||
bot_username: str = f"Юзернейм: @{BotInfo.username}\n"
|
||||
bot_id: str = f"ID: {BotInfo.id}\n"
|
||||
bot_can_join_groups: str = f"Может ли вступать в группы: {BotInfo.can_join_groups}\n"
|
||||
bot_can_read_all_group_messages: str = f"Чтение всех сообщений: {BotInfo.can_read_all_group_messages}\n"
|
||||
bot_supports_inline_queries: str = f"Поддерживает инлайн-запросы: {BotInfo.supports_inline_queries}\n"
|
||||
bot_can_connect_to_business: str = f"Подключение к бизнес-аккаунтам: {BotInfo.can_connect_to_business}\n"
|
||||
bot_has_main_web_app: str = f"Основное веб-приложение: {BotInfo.has_main_web_app}\n"
|
||||
|
||||
# Формируем полный текст с выводом информации о боте
|
||||
bot_all_info: str = (f"{bot_name} {bot_post_name} {bot_username} {bot_id} "
|
||||
f"{bot_can_join_groups} {bot_can_read_all_group_messages} "
|
||||
f"{bot_supports_inline_queries} {bot_can_connect_to_business} "
|
||||
f"{bot_has_main_web_app}")
|
||||
|
||||
# Печатаем все данные в консоль с задержкой в 1 секунду
|
||||
sleep(1)
|
||||
if Permissions.start_info_console:
|
||||
print(Fore.CYAN + bot_all_info)
|
||||
if Permissions.start_info_to_file:
|
||||
# Преобразуем словарь bot_all_info в строку и записываем в файл
|
||||
with open(ProjectPath.bot_info_log_file, 'w', encoding=BotVar.encod) as file:
|
||||
file.write(str(bot_all_info))
|
||||
|
||||
return bot_all_info
|
||||
|
||||
except Exception as e:
|
||||
Logs.error(log_type="SYS", user="Start_INFO", text=f"Ошибка при получении ID пользователя: {e}")
|
||||
Reference in New Issue
Block a user