forked from Muzifs/LGBot
Добавление исправление ошибки работы кармы
This commit is contained in:
@@ -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
|
@@ -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)
|
||||||
|
Reference in New Issue
Block a user