Spaces:
Paused
Paused
| from abc import ABC, abstractmethod | |
| from typing import TYPE_CHECKING, Any, AsyncIterator, Dict, List, Optional, Tuple | |
| import httpx | |
| from litellm.types.llms.anthropic_messages.anthropic_response import ( | |
| AnthropicMessagesResponse, | |
| ) | |
| from litellm.types.router import GenericLiteLLMParams | |
| if TYPE_CHECKING: | |
| from litellm.litellm_core_utils.litellm_logging import Logging as _LiteLLMLoggingObj | |
| LiteLLMLoggingObj = _LiteLLMLoggingObj | |
| else: | |
| LiteLLMLoggingObj = Any | |
| class BaseAnthropicMessagesConfig(ABC): | |
| def validate_anthropic_messages_environment( # use different name because return type is different from base config's validate_environment | |
| self, | |
| headers: dict, | |
| model: str, | |
| messages: List[Any], | |
| optional_params: dict, | |
| litellm_params: dict, | |
| api_key: Optional[str] = None, | |
| api_base: Optional[str] = None, | |
| ) -> Tuple[dict, Optional[str]]: | |
| """ | |
| OPTIONAL | |
| Validate the environment for the request | |
| Returns: | |
| - headers: dict | |
| - api_base: Optional[str] - If the provider needs to update the api_base, return it here. Otherwise, return None. | |
| """ | |
| return headers, api_base | |
| def get_complete_url( | |
| self, | |
| api_base: Optional[str], | |
| api_key: Optional[str], | |
| model: str, | |
| optional_params: dict, | |
| litellm_params: dict, | |
| stream: Optional[bool] = None, | |
| ) -> str: | |
| """ | |
| OPTIONAL | |
| Get the complete url for the request | |
| Some providers need `model` in `api_base` | |
| """ | |
| return api_base or "" | |
| def get_supported_anthropic_messages_params(self, model: str) -> list: | |
| pass | |
| def transform_anthropic_messages_request( | |
| self, | |
| model: str, | |
| messages: List[Dict], | |
| anthropic_messages_optional_request_params: Dict, | |
| litellm_params: GenericLiteLLMParams, | |
| headers: dict, | |
| ) -> Dict: | |
| pass | |
| def transform_anthropic_messages_response( | |
| self, | |
| model: str, | |
| raw_response: httpx.Response, | |
| logging_obj: LiteLLMLoggingObj, | |
| ) -> AnthropicMessagesResponse: | |
| pass | |
| def sign_request( | |
| self, | |
| headers: dict, | |
| optional_params: dict, | |
| request_data: dict, | |
| api_base: str, | |
| model: Optional[str] = None, | |
| stream: Optional[bool] = None, | |
| fake_stream: Optional[bool] = None, | |
| ) -> Tuple[dict, Optional[bytes]]: | |
| """ | |
| OPTIONAL | |
| Sign the request, providers like Bedrock need to sign the request before sending it to the API | |
| For all other providers, this is a no-op and we just return the headers | |
| """ | |
| return headers, None | |
| def get_async_streaming_response_iterator( | |
| self, | |
| model: str, | |
| httpx_response: httpx.Response, | |
| request_body: dict, | |
| litellm_logging_obj: LiteLLMLoggingObj, | |
| ) -> AsyncIterator: | |
| raise NotImplementedError("Subclasses must implement this method") | |