mirror of
https://github.com/BEDOLAGA-DEV/remnawave-bedolaga-telegram-bot.git
synced 2026-01-20 03:40:26 +00:00
176 lines
6.8 KiB
Python
176 lines
6.8 KiB
Python
import logging
|
||
from aiogram import Bot, Dispatcher, types
|
||
from aiogram.fsm.storage.redis import RedisStorage
|
||
from aiogram.fsm.storage.memory import MemoryStorage
|
||
import redis.asyncio as redis
|
||
|
||
from app.config import settings
|
||
from app.middlewares.global_error import GlobalErrorMiddleware
|
||
from app.middlewares.auth import AuthMiddleware
|
||
from app.middlewares.logging import LoggingMiddleware
|
||
from app.middlewares.throttling import ThrottlingMiddleware
|
||
from app.middlewares.subscription_checker import SubscriptionStatusMiddleware
|
||
from app.middlewares.maintenance import MaintenanceMiddleware
|
||
from app.services.maintenance_service import maintenance_service
|
||
from app.utils.cache import cache
|
||
|
||
from app.handlers import (
|
||
start, menu, subscription, balance, promocode,
|
||
referral, support, server_status, common, tickets
|
||
)
|
||
from app.handlers.admin import (
|
||
main as admin_main,
|
||
users as admin_users,
|
||
subscriptions as admin_subscriptions,
|
||
promocodes as admin_promocodes,
|
||
messages as admin_messages,
|
||
monitoring as admin_monitoring,
|
||
referrals as admin_referrals,
|
||
rules as admin_rules,
|
||
remnawave as admin_remnawave,
|
||
statistics as admin_statistics,
|
||
servers as admin_servers,
|
||
maintenance as admin_maintenance,
|
||
promo_groups as admin_promo_groups,
|
||
campaigns as admin_campaigns,
|
||
user_messages as admin_user_messages,
|
||
updates as admin_updates,
|
||
backup as admin_backup,
|
||
system_logs as admin_system_logs,
|
||
welcome_text as admin_welcome_text,
|
||
tickets as admin_tickets,
|
||
reports as admin_reports,
|
||
bot_configuration as admin_bot_configuration,
|
||
)
|
||
from app.handlers.stars_payments import register_stars_handlers
|
||
|
||
from app.utils.message_patch import patch_message_methods
|
||
|
||
patch_message_methods()
|
||
|
||
logger = logging.getLogger(__name__)
|
||
|
||
|
||
async def debug_callback_handler(callback: types.CallbackQuery):
|
||
logger.info(f"🔍 DEBUG CALLBACK:")
|
||
logger.info(f" - Data: {callback.data}")
|
||
logger.info(f" - User: {callback.from_user.id}")
|
||
logger.info(f" - Username: {callback.from_user.username}")
|
||
|
||
|
||
async def setup_bot() -> tuple[Bot, Dispatcher]:
|
||
|
||
try:
|
||
await cache.connect()
|
||
logger.info("Кеш инициализирован")
|
||
except Exception as e:
|
||
logger.warning(f"Кеш не инициализирован: {e}")
|
||
|
||
from aiogram.client.default import DefaultBotProperties
|
||
from aiogram.enums import ParseMode
|
||
|
||
bot = Bot(
|
||
token=settings.BOT_TOKEN,
|
||
default=DefaultBotProperties(parse_mode=ParseMode.HTML)
|
||
)
|
||
|
||
maintenance_service.set_bot(bot)
|
||
logger.info("Бот установлен в maintenance_service")
|
||
|
||
try:
|
||
redis_client = redis.from_url(settings.REDIS_URL)
|
||
await redis_client.ping()
|
||
storage = RedisStorage(redis_client)
|
||
logger.info("Подключено к Redis для FSM storage")
|
||
except Exception as e:
|
||
logger.warning(f"Не удалось подключиться к Redis: {e}")
|
||
logger.info("Используется MemoryStorage для FSM")
|
||
storage = MemoryStorage()
|
||
|
||
|
||
dp = Dispatcher(storage=storage)
|
||
|
||
dp.message.middleware(GlobalErrorMiddleware())
|
||
dp.callback_query.middleware(GlobalErrorMiddleware())
|
||
dp.pre_checkout_query.middleware(GlobalErrorMiddleware())
|
||
dp.message.middleware(LoggingMiddleware())
|
||
dp.callback_query.middleware(LoggingMiddleware())
|
||
dp.message.middleware(MaintenanceMiddleware())
|
||
dp.callback_query.middleware(MaintenanceMiddleware())
|
||
dp.message.middleware(ThrottlingMiddleware())
|
||
dp.callback_query.middleware(ThrottlingMiddleware())
|
||
|
||
if settings.CHANNEL_IS_REQUIRED_SUB:
|
||
from app.middlewares.channel_checker import ChannelCheckerMiddleware
|
||
|
||
channel_checker_middleware = ChannelCheckerMiddleware()
|
||
dp.message.middleware(channel_checker_middleware)
|
||
dp.callback_query.middleware(channel_checker_middleware)
|
||
logger.info("🔒 Обязательная подписка включена - ChannelCheckerMiddleware активирован")
|
||
else:
|
||
logger.info("🔓 Обязательная подписка отключена - ChannelCheckerMiddleware не зарегистрирован")
|
||
dp.message.middleware(AuthMiddleware())
|
||
dp.callback_query.middleware(AuthMiddleware())
|
||
dp.pre_checkout_query.middleware(AuthMiddleware())
|
||
dp.message.middleware(SubscriptionStatusMiddleware())
|
||
dp.callback_query.middleware(SubscriptionStatusMiddleware())
|
||
start.register_handlers(dp)
|
||
menu.register_handlers(dp)
|
||
subscription.register_handlers(dp)
|
||
balance.register_handlers(dp)
|
||
promocode.register_handlers(dp)
|
||
referral.register_handlers(dp)
|
||
support.register_handlers(dp)
|
||
server_status.register_handlers(dp)
|
||
tickets.register_handlers(dp)
|
||
admin_main.register_handlers(dp)
|
||
admin_users.register_handlers(dp)
|
||
admin_subscriptions.register_handlers(dp)
|
||
admin_servers.register_handlers(dp)
|
||
admin_promocodes.register_handlers(dp)
|
||
admin_messages.register_handlers(dp)
|
||
admin_monitoring.register_handlers(dp)
|
||
admin_referrals.register_handlers(dp)
|
||
admin_rules.register_handlers(dp)
|
||
admin_remnawave.register_handlers(dp)
|
||
admin_statistics.register_handlers(dp)
|
||
admin_promo_groups.register_handlers(dp)
|
||
admin_campaigns.register_handlers(dp)
|
||
admin_maintenance.register_handlers(dp)
|
||
admin_user_messages.register_handlers(dp)
|
||
admin_updates.register_handlers(dp)
|
||
admin_backup.register_handlers(dp)
|
||
admin_system_logs.register_handlers(dp)
|
||
admin_welcome_text.register_welcome_text_handlers(dp)
|
||
admin_tickets.register_handlers(dp)
|
||
admin_reports.register_handlers(dp)
|
||
admin_bot_configuration.register_handlers(dp)
|
||
common.register_handlers(dp)
|
||
register_stars_handlers(dp)
|
||
logger.info("⭐ Зарегистрированы обработчики Telegram Stars платежей")
|
||
|
||
try:
|
||
await maintenance_service.start_monitoring()
|
||
logger.info("Мониторинг техработ запущен")
|
||
except Exception as e:
|
||
logger.error(f"Ошибка запуска мониторинга техработ: {e}")
|
||
|
||
logger.info("🛡️ GlobalErrorMiddleware активирован - бот защищен от устаревших callback queries")
|
||
logger.info("Бот успешно настроен")
|
||
|
||
return bot, dp
|
||
|
||
|
||
async def shutdown_bot():
|
||
try:
|
||
await maintenance_service.stop_monitoring()
|
||
logger.info("Мониторинг техработ остановлен")
|
||
except Exception as e:
|
||
logger.error(f"Ошибка остановки мониторинга: {e}")
|
||
|
||
try:
|
||
await cache.close()
|
||
logger.info("Соединения с кешем закрыты")
|
||
except Exception as e:
|
||
logger.error(f"Ошибка закрытия кеша: {e}")
|