From 383abb02357c697c66fdd041cb5bf5350c330afc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=95=D0=B2=D0=B3=D0=B5=D0=BD=D0=B8=D0=B9=20=D0=A5=D1=80?= =?UTF-8?q?=D0=B0=D0=BC=D0=BE=D0=B2?= Date: Sat, 18 Oct 2025 13:21:47 +0300 Subject: [PATCH] =?UTF-8?q?=D0=98=D1=81=D0=BF=D1=80=D0=B0=D0=B2=D0=BB?= =?UTF-8?q?=D0=B5=D0=BD=D0=B8=D0=B5=20=D0=BE=D0=B1=D1=80=D0=B0=D0=B1=D0=BE?= =?UTF-8?q?=D1=82=D0=BA=D0=B8=20=D0=BF=D1=80=D0=B0=D0=B2=20=D0=B0=D0=B4?= =?UTF-8?q?=D0=BC=D0=B8=D0=BD=D0=B8=D1=81=D1=82=D1=80=D0=B0=D1=82=D0=BE?= =?UTF-8?q?=D1=80=D0=B0=20=D0=98=D0=B7=D0=BC=D0=B5=D0=BD=D0=B5=D0=BD=D0=B8?= =?UTF-8?q?=D0=B5=20=D1=81=D0=BE=D0=BE=D0=B1=D1=89=D0=B5=D0=BD=D0=B8=D0=B9?= =?UTF-8?q?=20=D0=BE=20=D0=B1=D0=B0=D0=BD=D0=B0=D1=85?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/modules/auto_mute.py | 5 +++- src/modules/badwords_manager.py | 4 +-- src/modules/botdata.py | 49 +++++++++++++-------------------- 3 files changed, 25 insertions(+), 33 deletions(-) diff --git a/src/modules/auto_mute.py b/src/modules/auto_mute.py index f03c2a5..154688e 100644 --- a/src/modules/auto_mute.py +++ b/src/modules/auto_mute.py @@ -131,12 +131,15 @@ async def apply_mute(bot: AsyncTeleBot, message: Message, user_id: int, duration message_thread_id=message.message_thread_id, ) + # Формируем причину с полным текстом сообщения + reason_text = f"{words_info} (нарушение #{violations_count})\n\n📝 Текст сообщения:\n{message.text}" + # Отправляем сообщение-лог в админ-чат await action_reporter.log_action( action="АВТОМУТ", user_id=user_id, admin_id=None, # Автоматическое действие - reason=f"{words_info} (нарушение #{violations_count})", + reason=reason_text, duration=time_display, ) diff --git a/src/modules/badwords_manager.py b/src/modules/badwords_manager.py index 0cf4bc6..165682f 100644 --- a/src/modules/badwords_manager.py +++ b/src/modules/badwords_manager.py @@ -22,8 +22,8 @@ def register_handlers(bot: AsyncTeleBot): logger.info(f"Команда /badwords получена от пользователя {message.from_user.id}") - # Проверяем права администратора - admin_check = await check_admin_status(bot, message) + # Проверяем права администратора (без проверки прав на ограничение участников) + admin_check = await check_admin_status(bot, message, check_restrict_rights=False) if admin_check == 1: logger.info(f"Пользователь {message.from_user.id} не является администратором") return diff --git a/src/modules/botdata.py b/src/modules/botdata.py index 54df80d..0929968 100644 --- a/src/modules/botdata.py +++ b/src/modules/botdata.py @@ -4,16 +4,13 @@ import asyncio import logging import os -from utils import delete_messages +from utils import delete_messages, check_admin_status from config import COMMAND_MESSAGES, DATABASE_NAME, LOG_FILE_NAME # Получаем логгер для текущего модуля logger = logging.getLogger(__name__) -# Загружаем id администраторов из .env -ADMIN_IDS = [int(id_str.strip()) for id_str in os.getenv('ADMIN_IDS').split(',')] - # Регистрирует все обработчики команд def register_handlers(bot: AsyncTeleBot): @@ -23,36 +20,28 @@ def register_handlers(bot: AsyncTeleBot): try: - # Если id администратора совпадает - if message.from_user.id in ADMIN_IDS: + # Проверяем права администратора (без проверки прав на ограничение участников) + admin_check = await check_admin_status(bot, message, check_restrict_rights=False) + if admin_check == 1: + logger.info(f"Пользователь {message.from_user.id} не является администратором") + return - # Отправляем базу данных - await bot.send_document( - chat_id=message.chat.id, - document=open(DATABASE_NAME, 'rb') - ) + # Если проверка пройдена - # Отправляем файл с логами - await bot.send_document( - chat_id=message.chat.id, - document=open(LOG_FILE_NAME, 'rb') - ) + # Отправляем базу данных + await bot.send_document( + chat_id=message.chat.id, + document=open(DATABASE_NAME, 'rb') + ) - # Записываем действие в логи - logger.info(f"Администратор {message.from_user.id} запустил /botdata.") + # Отправляем файл с логами + await bot.send_document( + chat_id=message.chat.id, + document=open(LOG_FILE_NAME, 'rb') + ) - # Если id администратора не совпадает - else: - - # Отправляем предупреждение - await bot.send_message( - chat_id=message.chat.id, - text=COMMAND_MESSAGES['no_admin_rights'], - message_thread_id=message.message_thread_id, - ) - - # Записываем действие в логи - logger.info(f"Пользователь {message.from_user.id} запустил /botdata.") + # Записываем действие в логи + logger.info(f"Администратор {message.from_user.id} запустил /botdata.") except Exception as e: