|
@@ -1,7 +1,7 @@
|
|
|
import logging
|
|
|
import re
|
|
|
from string import Template
|
|
|
-from typing import Any, Optional
|
|
|
+from typing import Any, Mapping, Optional
|
|
|
|
|
|
from embedchain.config.base_config import BaseConfig
|
|
|
from embedchain.helpers.json_serializable import register_deserializable
|
|
@@ -99,6 +99,7 @@ class BaseLlmConfig(BaseConfig):
|
|
|
endpoint: Optional[str] = None,
|
|
|
model_kwargs: Optional[dict[str, Any]] = None,
|
|
|
local: Optional[bool] = False,
|
|
|
+ default_headers: Optional[Mapping[str, str]] = None,
|
|
|
):
|
|
|
"""
|
|
|
Initializes a configuration class instance for the LLM.
|
|
@@ -144,6 +145,8 @@ class BaseLlmConfig(BaseConfig):
|
|
|
:type query_type: Optional[str], optional
|
|
|
:param local: If True, the model will be run locally, defaults to False (for huggingface provider)
|
|
|
:type local: Optional[bool], optional
|
|
|
+ :param default_headers: Set additional HTTP headers to be sent with requests to OpenAI
|
|
|
+ :type default_headers: Optional[Mapping[str, str]], optional
|
|
|
:raises ValueError: If the template is not valid as template should
|
|
|
contain $context and $query (and optionally $history)
|
|
|
:raises ValueError: Stream is not boolean
|
|
@@ -173,6 +176,7 @@ class BaseLlmConfig(BaseConfig):
|
|
|
self.endpoint = endpoint
|
|
|
self.model_kwargs = model_kwargs
|
|
|
self.local = local
|
|
|
+ self.default_headers = default_headers
|
|
|
|
|
|
if isinstance(prompt, str):
|
|
|
prompt = Template(prompt)
|