From 15ac2fdb074e04c3b033b4b420a1d435502f129b 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 21:34:40 +0300 Subject: [PATCH] =?UTF-8?q?=D0=94=D0=BE=D0=B1=D0=B0=D0=B2=D0=BB=D0=B5?= =?UTF-8?q?=D0=BD=D0=B8=D0=B5=20=D0=B8=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=D1=88=D0=B8=D0=B1=D0=BA=D0=B8?= =?UTF-8?q?=20=D1=80=D0=B0=D0=B1=D0=BE=D1=82=D1=8B=20=D0=BA=D0=B0=D1=80?= =?UTF-8?q?=D0=BC=D1=8B?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../{karma_tracker.py => 0_karma_tracker.py} | 6 ++++ src/modules/karma_commands.py | 29 ++++++++++--------- 2 files changed, 21 insertions(+), 14 deletions(-) rename src/modules/{karma_tracker.py => 0_karma_tracker.py} (90%) diff --git a/src/modules/karma_tracker.py b/src/modules/0_karma_tracker.py similarity index 90% rename from src/modules/karma_tracker.py rename to src/modules/0_karma_tracker.py index a237766..aa2def9 100644 --- a/src/modules/karma_tracker.py +++ b/src/modules/0_karma_tracker.py @@ -4,6 +4,7 @@ import logging from database import db from thank_words import contains_thank_word +from bad_words import contains_bad_word logger = logging.getLogger(__name__) @@ -28,6 +29,11 @@ def register_handlers(bot: AsyncTeleBot): if not contains_thank_word(message.text): return + # Проверяем, что в сообщении нет мата (не начисляем карму за мат) + if contains_bad_word(message.text): + logger.info(f"Пользователь {message.from_user.id} написал благодарность с матом - карма не начислена") + return + from_user = message.from_user to_user = message.reply_to_message.from_user chat_id = message.chat.id diff --git a/src/modules/karma_commands.py b/src/modules/karma_commands.py index 0299860..2fdb3a6 100644 --- a/src/modules/karma_commands.py +++ b/src/modules/karma_commands.py @@ -6,6 +6,15 @@ from database import db logger = logging.getLogger(__name__) +async def _delete_message_delayed(bot: AsyncTeleBot, chat_id: int, message_id: int, delay: int): + """Удаляет сообщение с задержкой""" + import asyncio + try: + await asyncio.sleep(delay) + await bot.delete_message(chat_id, message_id) + except Exception as e: + logger.error(f"Не удалось удалить сообщение {message_id}: {e}") + def register_handlers(bot: AsyncTeleBot): """Регистрирует обработчики команд для системы кармы""" @@ -84,14 +93,10 @@ def register_handlers(bot: AsyncTeleBot): sent_message = await bot.reply_to(message, response) - # Удаляем команду и ответ через 10 секунд + # Удаляем команду через 20 секунд и ответ через 60 секунд import asyncio - await asyncio.sleep(10) - try: - await bot.delete_message(chat_id, message.message_id) - await bot.delete_message(chat_id, sent_message.message_id) - except Exception as e: - logger.error(f"Не удалось удалить сообщения: {e}") + asyncio.create_task(_delete_message_delayed(bot, chat_id, message.message_id, 20)) + asyncio.create_task(_delete_message_delayed(bot, chat_id, sent_message.message_id, 60)) except Exception as e: logger.error(f"Ошибка при обработке команды /karma: {e}", exc_info=True) @@ -139,14 +144,10 @@ def register_handlers(bot: AsyncTeleBot): sent_message = await bot.reply_to(message, response, parse_mode='HTML') - # Удаляем команду и ответ через 30 секунд + # Удаляем команду через 20 секунд и ответ через 60 секунд import asyncio - await asyncio.sleep(30) - try: - await bot.delete_message(chat_id, message.message_id) - await bot.delete_message(chat_id, sent_message.message_id) - except Exception as e: - logger.error(f"Не удалось удалить сообщения: {e}") + asyncio.create_task(_delete_message_delayed(bot, chat_id, message.message_id, 20)) + asyncio.create_task(_delete_message_delayed(bot, chat_id, sent_message.message_id, 60)) except Exception as e: logger.error(f"Ошибка при обработке команды /top: {e}", exc_info=True)