Добавление исправление ошибки работы кармы

This commit is contained in:
2025-10-18 21:34:40 +03:00
parent a16b5322af
commit 15ac2fdb07
2 changed files with 21 additions and 14 deletions

View File

@@ -4,6 +4,7 @@ import logging
from database import db from database import db
from thank_words import contains_thank_word from thank_words import contains_thank_word
from bad_words import contains_bad_word
logger = logging.getLogger(__name__) logger = logging.getLogger(__name__)
@@ -28,6 +29,11 @@ def register_handlers(bot: AsyncTeleBot):
if not contains_thank_word(message.text): if not contains_thank_word(message.text):
return return
# Проверяем, что в сообщении нет мата (не начисляем карму за мат)
if contains_bad_word(message.text):
logger.info(f"Пользователь {message.from_user.id} написал благодарность с матом - карма не начислена")
return
from_user = message.from_user from_user = message.from_user
to_user = message.reply_to_message.from_user to_user = message.reply_to_message.from_user
chat_id = message.chat.id chat_id = message.chat.id

View File

@@ -6,6 +6,15 @@ from database import db
logger = logging.getLogger(__name__) 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): def register_handlers(bot: AsyncTeleBot):
"""Регистрирует обработчики команд для системы кармы""" """Регистрирует обработчики команд для системы кармы"""
@@ -84,14 +93,10 @@ def register_handlers(bot: AsyncTeleBot):
sent_message = await bot.reply_to(message, response) sent_message = await bot.reply_to(message, response)
# Удаляем команду и ответ через 10 секунд # Удаляем команду через 20 секунд и ответ через 60 секунд
import asyncio import asyncio
await asyncio.sleep(10) asyncio.create_task(_delete_message_delayed(bot, chat_id, message.message_id, 20))
try: asyncio.create_task(_delete_message_delayed(bot, chat_id, sent_message.message_id, 60))
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}")
except Exception as e: except Exception as e:
logger.error(f"Ошибка при обработке команды /karma: {e}", exc_info=True) 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') sent_message = await bot.reply_to(message, response, parse_mode='HTML')
# Удаляем команду и ответ через 30 секунд # Удаляем команду через 20 секунд и ответ через 60 секунд
import asyncio import asyncio
await asyncio.sleep(30) asyncio.create_task(_delete_message_delayed(bot, chat_id, message.message_id, 20))
try: asyncio.create_task(_delete_message_delayed(bot, chat_id, sent_message.message_id, 60))
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}")
except Exception as e: except Exception as e:
logger.error(f"Ошибка при обработке команды /top: {e}", exc_info=True) logger.error(f"Ошибка при обработке команды /top: {e}", exc_info=True)