Spaces:
Running
Running
| """Agent-related utilities.""" | |
| import asyncio | |
| import logging | |
| from typing import Awaitable, Callable, TypeVar | |
| from src.config import settings | |
| logger = logging.getLogger(__name__) | |
| T = TypeVar("T") | |
| async def with_retries( | |
| awaitable_factory: Callable[[], Awaitable[T]], | |
| retries: int = 3, | |
| timeout: int = settings.request_timeout, | |
| ) -> T: | |
| """Execute an awaitable with retries and timeout. | |
| :param awaitable_factory: A function that returns an awaitable. | |
| :param retries: Maximum number of retries. | |
| :param timeout: Timeout in seconds for each attempt. | |
| :return: The result of the awaitable. | |
| """ | |
| last_exception = None | |
| for attempt in range(retries): | |
| try: | |
| return await asyncio.wait_for(awaitable_factory(), timeout=timeout) | |
| except Exception as e: | |
| logger.warning(f"Attempt {attempt + 1}/{retries} failed with error: {str(e)}") | |
| last_exception = e | |
| raise last_exception from last_exception |