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. Возникает при слишком частых запросах к API.
Рекомендуется сделать паузу перед повторным запросом. Рекомендуется сделать паузу перед повторным запросом.
Attributes:
retry_after: Время ожидания в секундах (если указано сервером).
Example: Example:
import asyncio import asyncio
try: try:
await client.catalog.get_list() await client.catalog.get_list()
except KworkRateLimitError: except KworkRateLimitError as e:
await asyncio.sleep(5) # Пауза 5 секунд 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) super().__init__(message, 429, response)