add command /profile

This commit is contained in:
vrubelroman 2025-11-21 23:16:35 +03:00
parent 56c1048bcc
commit 965b8775b7
3 changed files with 81 additions and 85 deletions

View file

@ -1179,6 +1179,70 @@ class LichessBot:
error_msg = "Не удалось установить язык" if lang == 'ru' else "❌ Failed to set language"
await query.edit_message_text(error_msg)
async def profile(self, update: Update, context: ContextTypes.DEFAULT_TYPE):
"""Show list of players to view their profiles"""
user_id = update.effective_user.id
gamers = self.db.get_user_gamers(user_id)
lang = self.get_user_language_from_update(update)
if not gamers:
await update.message.reply_text(t('no_gamers', lang))
return
# Create keyboard with player buttons
keyboard = []
for gamer in gamers:
username = gamer['username']
keyboard.append([
InlineKeyboardButton(
username,
callback_data=f"profile_{gamer['id']}"
)
])
reply_markup = InlineKeyboardMarkup(keyboard)
await update.message.reply_text(
t('select_player_profile', lang),
reply_markup=reply_markup,
parse_mode='HTML'
)
async def handle_profile_selection(self, update: Update, context: ContextTypes.DEFAULT_TYPE):
"""Handle profile selection callback - send profile link"""
query = update.callback_query
await query.answer()
user_id = query.from_user.id
gamer_id = int(query.data.split('_')[1])
# Get gamer info
gamers = self.db.get_user_gamers(user_id)
selected_gamer = next((g for g in gamers if g['id'] == gamer_id), None)
if not selected_gamer:
lang = self.db.get_user_language(user_id)
await query.edit_message_text(t('gamer_not_found', lang))
return
username = selected_gamer['username']
profile_url = f"https://lichess.org/@/{username}"
lang = self.db.get_user_language(user_id)
# Send profile link
await query.message.reply_text(
f"🔗 <a href=\"{profile_url}\">{profile_url}</a>",
parse_mode='HTML'
)
# Edit original message to show confirmation
await query.edit_message_text(
t('profile_link_sent', lang),
parse_mode='HTML'
)
async def start_periodic_task(self, gamer: Dict[str, Any], user_id: int, period_minutes: int):
"""Start periodic task for a gamer"""
task_key = f"{gamer['id']}_{user_id}"
@ -1414,10 +1478,12 @@ class LichessBot:
application.add_handler(CommandHandler("support", self.support))
application.add_handler(CommandHandler("setperiod", self.setperiod))
application.add_handler(CommandHandler("set_lang", self.set_lang))
application.add_handler(CommandHandler("profile", self.profile))
application.add_handler(CommandHandler("test_admin_notify", self.test_admin_notify))
# Callback handlers (order matters - more specific patterns first)
application.add_handler(CallbackQueryHandler(self.handle_language_selection, pattern="^lang_"))
application.add_handler(CallbackQueryHandler(self.handle_profile_selection, pattern="^profile_"))
application.add_handler(CallbackQueryHandler(self.select_gamer_for_period, pattern="^select_gamer_period_"))
application.add_handler(CallbackQueryHandler(self.select_gamer, pattern="^select_"))
application.add_handler(CallbackQueryHandler(self.handle_delete_gamer, pattern="^delete_"))

View file

@ -37,6 +37,7 @@ TRANSLATIONS = {
"/lastYear_or_1000games - Statistics for the last year or last 1000 rated games (whichever comes first)\n"
"/setperiod - Set up periodic notifications for the active player\n"
"(active player changes in the /getgamers menu)\n"
"/profile - View Lichess profile links for tracked players\n"
"/set_lang - Select bot language (English / Russian)\n"
"/support - Contact the developer for support and feedback"
),
@ -123,6 +124,10 @@ TRANSLATIONS = {
'select_language': "🌐 <b>Select language / Выберите язык:</b>",
'language_set_en': "✅ Language set to English",
'language_set_ru': "✅ Язык установлен: Русский",
# Profile command
'select_player_profile': "👤 <b>Select player:</b>",
'profile_link_sent': "✅ Profile link sent",
},
'ru': {
# Start command
@ -151,11 +156,12 @@ TRANSLATIONS = {
"/today - Статистика за сегодня\n"
"/yesterday - Статистика за вчера\n"
"/week - Статистика за неделю\n"
"/lastYear_or_1000games - Статистика за последний год или последние 1000 рейтинговых игр (что наступит раньше)\n"
"/setperiod - Настроить периодические уведомления для активного игрока\n"
"(активный игрок меняется в меню /getgamers)\n"
"/set_lang - Выбрать язык бота\n"
"/support - Связаться с разработчиком для поддержки и обратной связи"
"/lastYear_or_1000games - Статистика за последний год или последние 1000 рейтинговых игр (что наступит раньше)\n"
"/setperiod - Настроить периодические уведомления для активного игрока\n"
"(активный игрок меняется в меню /getgamers)\n"
"/profile - Просмотр ссылок на профили Lichess отслеживаемых игроков\n"
"/set_lang - Выбрать язык бота\n"
"/support - Связаться с разработчиком для поддержки и обратной связи"
),
# Add gamer commands
@ -240,6 +246,10 @@ TRANSLATIONS = {
'select_language': "🌐 <b>Выберите язык / Select language:</b>",
'language_set_en': "✅ Language set to English",
'language_set_ru': "✅ Язык установлен: Русский",
# Profile command
'select_player_profile': "👤 <b>Выберите игрока:</b>",
'profile_link_sent': "✅ Ссылка на профиль отправлена",
}
}

View file

@ -1,80 +0,0 @@
#!/usr/bin/env python3
"""
Скрипт для тестирования запросов к Lichess API для пользователя kostik2811
"""
import asyncio
import sys
import os
# Добавляем пути к модулям
sys.path.insert(0, os.path.join(os.path.dirname(__file__), 'LichessWebServices'))
from lichess_client import LichessClient
from stats_service import StatsService
import logging
# Настройка логирования
logging.basicConfig(
level=logging.INFO,
format='%(asctime)s - %(name)s - %(levelname)s - %(message)s'
)
logger = logging.getLogger(__name__)
async def test_kostik2811():
"""Тестирование запросов для kostik2811"""
username = "kostik2811"
logger.info(f"🔍 Тестирование запросов для пользователя: {username}")
# Тест 1: Прямой запрос к Lichess API
logger.info("\n" + "="*50)
logger.info("ТЕСТ 1: Прямой запрос к Lichess API")
logger.info("="*50)
lichess_client = LichessClient()
try:
activity_data = await lichess_client.get_user_activity(username)
if activity_data:
logger.info(f"✅ Получены данные активности: {len(activity_data)} записей")
for i, activity in enumerate(activity_data[:3]): # Показываем первые 3
logger.info(f" Активность {i+1}: {activity.get('interval', 'N/A')}")
else:
logger.warning(f"⚠️ Данные активности не получены (None или пусто)")
except Exception as e:
logger.error(f"❌ Ошибка при запросе к Lichess API: {e}")
import traceback
logger.error(traceback.format_exc())
finally:
await lichess_client.close()
# Тест 2: Запрос через StatsService
logger.info("\n" + "="*50)
logger.info("ТЕСТ 2: Запрос через StatsService.get_today_stats")
logger.info("="*50)
lichess_client2 = LichessClient()
stats_service = StatsService(lichess_client2)
try:
result = await stats_service.get_today_stats(username)
logger.info(f"✅ Результат StatsService: message={result.message}")
if result.data:
logger.info(f" Данные: username={result.data.username}")
logger.info(f" Задачи: {result.data.tasks}")
logger.info(f" Игры: {result.data.games}")
else:
logger.warning(f"⚠️ Нет данных в результате")
except Exception as e:
logger.error(f"❌ Ошибка в StatsService: {e}")
import traceback
logger.error(traceback.format_exc())
finally:
await lichess_client2.close()
logger.info("\n" + "="*50)
logger.info("Тестирование завершено")
logger.info("="*50)
if __name__ == "__main__":
asyncio.run(test_kostik2811())