Возможность запуска пустышки
This commit is contained in:
6
BotLibrary/__init__.py
Normal file
6
BotLibrary/__init__.py
Normal file
@@ -0,0 +1,6 @@
|
||||
# ProjectsFiles/__init__.py
|
||||
# Инициализация пакета ProjectsFiles, для настройки переменных проекта
|
||||
|
||||
# Экспортирование модулей во внешние слои проекта
|
||||
from .bots import *
|
||||
from .logs import *
|
||||
112
BotLibrary/bots.py
Normal file
112
BotLibrary/bots.py
Normal file
@@ -0,0 +1,112 @@
|
||||
# BotLibrary/library/bots.py
|
||||
# Создание и настройка бота в одном файле
|
||||
|
||||
from aiogram import Dispatcher, Bot, F
|
||||
from aiogram.enums import ParseMode
|
||||
from aiogram.client.default import DefaultBotProperties
|
||||
from aiogram.utils.keyboard import InlineKeyboardBuilder
|
||||
from apscheduler.schedulers.asyncio import AsyncIOScheduler
|
||||
from ProjectsFiles import *
|
||||
|
||||
# Создание экземпляра диспатчера, строителей кнопок
|
||||
dp = Dispatcher()
|
||||
ikb = InlineKeyboardBuilder()
|
||||
|
||||
|
||||
# Настройка параметров диспатчера
|
||||
dp["started_at"] = None
|
||||
dp["started_at_msk"] = None
|
||||
dp["is_active"] = True # Флаг активности бота
|
||||
dp["logs"] = []
|
||||
dp["users"] = {}
|
||||
dp["sessions"] = {}
|
||||
dp["task_queue"] = []
|
||||
dp["configs"] = {"max_connections": 100, "retry_interval": 5, "time_format": None}
|
||||
dp["metrics"] = {"messages_received": 0, "messages_sent": 0, "errors": 0}
|
||||
dp["modules"] = {}
|
||||
dp["state"] = {}
|
||||
dp["scheduler"] = []
|
||||
dp["handlers"] = {"on_message": [], "on_error": []}
|
||||
dp["storage"] = {}
|
||||
dp["database"] = None
|
||||
|
||||
|
||||
# Объявление экземпляров и переменных
|
||||
bot_properties = DefaultBotProperties(
|
||||
parse_mode=ParseMode.HTML, # Устанавливаем формат HTML для всех сообщений
|
||||
disable_notification=True, # Отключаем уведомления при отправке сообщений
|
||||
protect_content=True, # Защищаем содержимое сообщений от копирования
|
||||
allow_sending_without_reply=True, # Разрешаем отправлять сообщения без ответа на другое сообщение
|
||||
link_preview_is_disabled=True, # Отключаем предварительный просмотр ссылок
|
||||
show_caption_above_media=False, # Показываем подпись выше медиа
|
||||
)
|
||||
bot = Bot(token=bot_token, default=bot_properties) # Объявление бота
|
||||
scheduler = AsyncIOScheduler(timezone=None) # Создание планировщика
|
||||
F_Media = F.photo | F.files | F.video | F.animation | F.voice | F.video_note # Фильтр-медиа
|
||||
F_All = F.text | F.photo | F.files | F.video | F.animation | F.voice | F.video_note # Фильтр на все
|
||||
|
||||
|
||||
# Класс для хранения данных о боте (некоторые переменные даны как шаблон)
|
||||
class BotInfo:
|
||||
# Статические переменные для хранения данных
|
||||
id = None
|
||||
first_name = None
|
||||
last_name = None
|
||||
username = None
|
||||
description = None
|
||||
short_description = None
|
||||
can_join_groups = None
|
||||
can_read_all_group_messages = None
|
||||
language_code = BotVar.language
|
||||
prefix = BotVar.prefix
|
||||
is_premium = None
|
||||
added_to_attachment_menu = None
|
||||
supports_inline_queries = None
|
||||
can_connect_to_business = None
|
||||
has_main_web_app = None
|
||||
|
||||
# Метод для обновления данных
|
||||
@classmethod
|
||||
def update(cls, bot_info):
|
||||
cls.id = bot_info.id
|
||||
cls.first_name = bot_info.first_name
|
||||
cls.last_name = bot_info.last_name
|
||||
cls.username = bot_info.username
|
||||
cls.description = getattr(bot_info, 'description', '')
|
||||
cls.short_description = getattr(bot_info, 'description', '')
|
||||
cls.language_code = bot_info.language_code
|
||||
cls.is_premium = bot_info.is_premium
|
||||
cls.added_to_attachment_menu = bot_info.added_to_attachment_menu
|
||||
cls.supports_inline_queries = bot_info.supports_inline_queries
|
||||
cls.can_connect_to_business = bot_info.can_connect_to_business
|
||||
cls.has_main_web_app = bot_info.has_main_web_app
|
||||
cls.can_join_groups = getattr(bot_info, 'can_join_groups', None)
|
||||
cls.can_read_all_group_messages = getattr(bot_info, 'can_read_all_group_messages', None)
|
||||
|
||||
|
||||
# Функция получения данных о боте
|
||||
async def bot_get_info():
|
||||
# Получение информации о боте
|
||||
bot_info_data = await bot.get_me()
|
||||
|
||||
# Обновляем данные о боте в BotInfo
|
||||
BotInfo.update(bot_info_data)
|
||||
|
||||
# Возвращаем обновленные данные
|
||||
return {
|
||||
'bot_info': bot_info_data,
|
||||
'id': bot_info_data.id,
|
||||
'first_name': bot_info_data.first_name,
|
||||
'last_name': bot_info_data.last_name,
|
||||
'username': bot_info_data.username,
|
||||
'description': getattr(bot_info_data, 'description', ''),
|
||||
'short_description': getattr(bot_info_data, 'description', ''),
|
||||
'language_code': bot_info_data.language_code,
|
||||
'prefix': BotVar.prefix,
|
||||
'is_premium': bot_info_data.is_premium,
|
||||
'added_to_attachment_menu': bot_info_data.added_to_attachment_menu,
|
||||
'supports_inline_queries': bot_info_data.supports_inline_queries,
|
||||
'can_connect_to_business': bot_info_data.can_connect_to_business,
|
||||
'has_main_web_app': bot_info_data.has_main_web_app,
|
||||
'can_join_groups': getattr(bot_info_data, 'can_join_groups', None),
|
||||
}
|
||||
54
BotLibrary/logs.py
Normal file
54
BotLibrary/logs.py
Normal file
@@ -0,0 +1,54 @@
|
||||
# BotLibrary/logs.py
|
||||
# Создание логгеров и их шаблон для проекта
|
||||
|
||||
import sys
|
||||
from loguru import logger
|
||||
from ProjectsFiles.configs.config import BotLogs
|
||||
|
||||
|
||||
# Создание обычного логгера + логгер в файл
|
||||
async def setup_logger():
|
||||
logger.remove() # Удаляем все логгеры
|
||||
|
||||
if BotLogs.permission:
|
||||
logger.add(sys.stderr,
|
||||
colorize=True,
|
||||
format=BotLogs.info_text,
|
||||
level="INFO",
|
||||
filter=lambda record: record["level"].name == "INFO")
|
||||
logger.add(sys.stderr,
|
||||
colorize=True,
|
||||
format=BotLogs.error_text,
|
||||
level="ERROR",
|
||||
filter=lambda record: record["level"].name == "ERROR")
|
||||
|
||||
if BotLogs.permission:
|
||||
"""logger.add(ProjectPath.log_file,
|
||||
rotation=BotLogs.max_size,
|
||||
format=BotLogs.info_text,
|
||||
backtrace=True,
|
||||
diagnose=True,
|
||||
level="INFO",
|
||||
filter=lambda record: record["level"].name == "INFO")
|
||||
logger.add(ProjectPath.log_error_file,
|
||||
rotation=BotLogs.max_size,
|
||||
format=BotLogs.error_text,
|
||||
backtrace=True,
|
||||
diagnose=True,
|
||||
level="ERROR",
|
||||
filter=lambda record: record["level"].name == "ERROR")"""
|
||||
|
||||
|
||||
# Создание функции логирования на обычные сообщения
|
||||
async def common_msg_logginger(message,
|
||||
name : str = "Пользователь",
|
||||
message_type : str = "Медиа",
|
||||
log_type : str = "Message"):
|
||||
if BotLogs.permission_msg:
|
||||
# Проверка на наличие текста и его типа
|
||||
if message.text is None:
|
||||
logger.bind(log_type=log_type, user=f"@{message.from_user.username}").info(
|
||||
f"Получено сообщение из ({name}) : {message_type}")
|
||||
else:
|
||||
logger.bind(log_type=log_type, user=f"@{message.from_user.username}").info(
|
||||
f"Получено сообщение из ({name}) : {message.text}")
|
||||
Reference in New Issue
Block a user