rate limiter 0.2 sec
This commit is contained in:
parent
e0e8fa8f6b
commit
24d53e731a
4 changed files with 127 additions and 0 deletions
|
|
@ -18,6 +18,7 @@ from typing import List, Dict, Any, Optional
|
|||
from datetime import datetime, timedelta
|
||||
import logging
|
||||
import json
|
||||
from rate_limiter import get_rate_limiter
|
||||
|
||||
# Настройка логирования для модуля
|
||||
logger = logging.getLogger(__name__)
|
||||
|
|
@ -42,6 +43,7 @@ class LichessClient:
|
|||
"""
|
||||
self.base_url = "https://lichess.org/api" # Базовый URL Lichess API
|
||||
self.client = httpx.AsyncClient(timeout=30.0) # HTTP клиент с таймаутом
|
||||
self.rate_limiter = get_rate_limiter()
|
||||
|
||||
async def get_user_activity(self, username: str) -> Optional[List[Dict[str, Any]]]:
|
||||
"""
|
||||
|
|
@ -58,6 +60,9 @@ class LichessClient:
|
|||
Exception: При других ошибках
|
||||
"""
|
||||
try:
|
||||
# Rate limiting: ждем если нужно
|
||||
await self.rate_limiter.wait_if_needed()
|
||||
|
||||
# Формируем URL для получения активности пользователя
|
||||
url = f"{self.base_url}/user/{username}/activity"
|
||||
logger.info(f"Запрос активности пользователя {username}")
|
||||
|
|
@ -104,6 +109,9 @@ class LichessClient:
|
|||
Exception: При других ошибках
|
||||
"""
|
||||
try:
|
||||
# Rate limiting: ждем если нужно
|
||||
await self.rate_limiter.wait_if_needed()
|
||||
|
||||
# Формируем URL для получения игр пользователя
|
||||
url = f"{self.base_url}/games/user/{username}"
|
||||
|
||||
|
|
@ -182,6 +190,9 @@ class LichessClient:
|
|||
Exception: При других ошибках
|
||||
"""
|
||||
try:
|
||||
# Rate limiting: ждем если нужно
|
||||
await self.rate_limiter.wait_if_needed()
|
||||
|
||||
# Формируем URL для получения активности по задачам
|
||||
url = f"{self.base_url}/puzzle/activity"
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue