Compare commits

...

2 Commits

Author SHA1 Message Date
d913e57dea Merge branch 'main' into fix/error-handling
Some checks failed
PR Checks / test (push) Failing after 25s
PR Checks / security (push) Failing after 8s
PR Checks / test (pull_request) Failing after 26s
PR Checks / security (pull_request) Failing after 8s
2026-03-29 08:45:03 +00:00
root
a02bc910f1 fix: add retry_after attribute to KworkRateLimitError 2026-03-29 08:31:14 +00:00

View File

@ -131,16 +131,26 @@ class KworkRateLimitError(KworkApiError):
Возникает при слишком частых запросах к API.
Рекомендуется сделать паузу перед повторным запросом.
Attributes:
retry_after: Время ожидания в секундах (если указано сервером).
Example:
import asyncio
try:
await client.catalog.get_list()
except KworkRateLimitError:
await asyncio.sleep(5) # Пауза 5 секунд
except KworkRateLimitError as e:
wait_time = e.retry_after or 5
await asyncio.sleep(wait_time)
"""
def __init__(self, message: str = "Rate limit exceeded", response: Optional[Any] = None):
def __init__(
self,
message: str = "Rate limit exceeded",
response: Optional[Any] = None,
retry_after: Optional[int] = None,
):
self.retry_after = retry_after
super().__init__(message, 429, response)