| docs | ||
| LichessClientTG_bot | ||
| LichessWebServices | ||
| LichessWebView | ||
| .env | ||
| .gitattributes | ||
| .gitignore | ||
| about.md | ||
| docker-compose.yml | ||
| export_db.sh | ||
| git-pull-reset.sh | ||
| git-pull-safe.sh | ||
| import_db.sh | ||
| README.md | ||
| start.sh | ||
Lichess Statistics Ecosystem
Полнофункциональная система для отслеживания статистики игроков Lichess.org с Telegram ботом и веб-интерфейсом.
🎯 Описание проекта
Система состоит из трех взаимосвязанных компонентов:
- LichessWebServices - REST API для получения статистики игроков Lichess
- LichessClientTG_bot - Telegram бот для управления подписками и уведомлений
- LichessWebView - Веб-интерфейс для просмотра пользователей и их игроков
🏗️ Архитектура
┌─────────────────────────────────────────────────────────────┐
│ Telegram Users │
│ │
│ ┌────────────────────────────────────────────────────┐ │
│ │ LichessClientTG_bot │ │
│ │ (Управление подписками, уведомления) │ │
│ └────────┬───────────────────────────────────────────┘ │
│ │ │
│ ├──────────────────────┐ │
│ │ │ │
│ ┌────────▼──────────┐ ┌──────▼──────────────┐ │
│ │ LichessWebServices │ │ LichessWebView │ │
│ │ │ │ │ │
│ │ REST API для │ │ Веб-интерфейс │ │
│ │ получения │ │ для просмотра │ │
│ │ статистики │ │ пользователей │ │
│ └────────┬───────────┘ └────────────────────┘ │
│ │ │
└───────────┼──────────────────────────────────────────────┘
│
▼
┌───────────────┐
│ Lichess API │
└───────────────┘
🚀 Быстрый старт
Установка и запуск
# Клонируем репозиторий
git clone https://github.com/vrubelroman/LichessStatTgWeb.git
cd LichessStatTgWeb
# Запускаем все сервисы
./start.sh
Скрипт start.sh запустит все контейнеры в правильном порядке.
Доступные сервисы
После запуска доступны:
- API документация: http://localhost:8001/docs
- Веб-интерфейс: http://localhost:5000
- Telegram бот: работает в фоне
📦 Структура проекта
LichessStatTgWeb/
├── LichessWebServices/ # REST API сервис
│ ├── main.py # FastAPI приложение
│ ├── stats_service.py # Логика обработки статистики
│ ├── lichess_client.py # Клиент для Lichess API
│ └── models.py # Pydantic модели
│
├── LichessClientTG_bot/ # Telegram бот
│ ├── bot.py # Основная логика бота
│ ├── database.py # Работа с БД
│ ├── lichess_api.py # API клиент
│ ├── formatters.py # Форматирование ответов
│ └── config.py # Конфигурация
│
├── LichessWebView/ # Веб-интерфейс
│ ├── app.py # Flask приложение
│ └── templates/ # HTML шаблоны
│ └── index.html # Главная страница
│
├── docker-compose.yml # Общая конфигурация контейнеров
├── start.sh # Скрипт запуска всех сервисов
└── README.md # Этот файл
🔧 Компоненты
1. LichessWebServices (API)
REST API для получения статистики игроков Lichess.
Возможности:
- Статистика за сегодня/вчера/неделю
- Статистика игр по режимам (Bullet, Blitz, Rapid)
- Статистика решения задач (puzzles)
- Получение игр за произвольный период
Endpoints:
GET /stats/{username}/today- статистика за сегодняGET /stats/{username}/yesterday- статистика за вчераGET /stats/{username}/week- статистика за неделюGET /games/{username}/period- игры за периодGET /puzzle/period- задачи за период (требует токен)
2. LichessClientTG_bot (Telegram бот)
Telegram бот для управления отслеживанием игроков Lichess.
Возможности:
- Добавление игроков для отслеживания (друзья, соперники, ученики)
- Выбор активного игрока
- Получение статистики (сегодня/вчера/неделя)
- Статистика по режимам (Bullet, Blitz, Rapid)
- Статистика решения задач (puzzles)
- Настройка периодических уведомлений
- Каждый пользователь имеет свой набор игроков
Команды:
/start- начало работы с ботом/addgamer- добавить игрока Lichess (только имя пользователя)/addtoken- добавить игрока с токеном (для статистики по задачам)/getgamers- выбрать активного игрока/delgamer- удалить игрока из списка/today- статистика за сегодня/yesterday- статистика за вчера/week- статистика за неделю/setperiod- настроить уведомления
Подробнее о боте: см. about.md
3. LichessWebView (Веб-интерфейс)
Веб-интерфейс для просмотра пользователей и их игроков.
Возможности:
- Просмотр всех пользователей бота
- Фильтрация пользователей по имени/никнейму
- Отображение игроков каждого пользователя
- Статистика по каждому пользователю
- Отображение активных игроков и периодов
🗄️ База данных
Система использует SQLite базу данных с таблицами:
telegram_users- пользователи Telegramgamers- игроки Lichessuser_gamers- связь пользователей с игроками и настройки
Структура:
- Каждый пользователь видит только своих игроков
- У каждого пользователя свой активный игрок
- Период отслеживания привязывается к паре пользователь-игрок
🐳 Docker
Все компоненты запускаются в Docker контейнерах:
# Запуск всех сервисов
docker-compose up -d
# Просмотр логов
docker-compose logs -f
# Остановка всех сервисов
docker-compose down
🔑 Конфигурация
Telegram бот
Токен бота настраивается в LichessClientTG_bot/config.py:
TELEGRAM_BOT_TOKEN = "YOUR_TOKEN_HERE"
Lichess API
Для получения статистики по задачам нужен токен Lichess:
- Зайдите на https://lichess.org/account/oauth/token/create
- Создайте токен с правами на чтение
- Используйте токен при добавлении игрока в боте
📊 API документация
Полная документация API доступна по адресу: http://localhost:8001/docs
Включает:
- Swagger UI для интерактивного тестирования
- Описание всех endpoints
- Примеры запросов и ответов
🛠️ Разработка
Локальная разработка
# API сервис
cd LichessWebServices
docker-compose up -d
# Telegram бот
cd LichessClientTG_bot
docker-compose up -d
# Веб-интерфейс
cd LichessWebView
docker-compose up -d
Логи
# Логи API
docker logs lichesswebservices_lichess-api_1 -f
# Логи бота
docker logs lichess-telegram-bot -f
# Логи веб-интерфейса
docker logs lichess-web-view -f
📝 Лицензия
MIT
👤 Автор
Roman Vrubel
📖 Дополнительная информация
- О боте - подробное описание функций бота, для кого он предназначен и примеры использования