unique_toolkit 0.7.38__py3-none-any.whl → 0.7.39__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- unique_toolkit/framework_utilities/langchain/client.py +45 -0
- unique_toolkit/framework_utilities/openai/client.py +45 -0
- unique_toolkit/framework_utilities/openai/message_builder.py +133 -0
- unique_toolkit/framework_utilities/utils.py +23 -0
- {unique_toolkit-0.7.38.dist-info → unique_toolkit-0.7.39.dist-info}/METADATA +5 -1
- {unique_toolkit-0.7.38.dist-info → unique_toolkit-0.7.39.dist-info}/RECORD +8 -4
- {unique_toolkit-0.7.38.dist-info → unique_toolkit-0.7.39.dist-info}/LICENSE +0 -0
- {unique_toolkit-0.7.38.dist-info → unique_toolkit-0.7.39.dist-info}/WHEEL +0 -0
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import importlib.util
|
|
2
|
+
import logging
|
|
3
|
+
from pathlib import Path
|
|
4
|
+
|
|
5
|
+
from unique_toolkit.app.unique_settings import UniqueSettings
|
|
6
|
+
from unique_toolkit.framework_utilities.utils import get_default_headers
|
|
7
|
+
|
|
8
|
+
logger = logging.getLogger("toolkit.framework_utilities.langchain")
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
class LangchainNotInstalledError(ImportError):
|
|
12
|
+
"""Raised when langchain-openai package is not installed but functionality requiring it is accessed."""
|
|
13
|
+
|
|
14
|
+
def __init__(self):
|
|
15
|
+
super().__init__(
|
|
16
|
+
"langchain-openai package is not installed. Install it with 'poetry install --with langchain'."
|
|
17
|
+
)
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
if importlib.util.find_spec("langchain_openai") is not None:
|
|
21
|
+
from langchain_openai import ChatOpenAI
|
|
22
|
+
else:
|
|
23
|
+
raise LangchainNotInstalledError()
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
def get_client(env_file: Path | None = None) -> ChatOpenAI:
|
|
27
|
+
"""Get a Langchain ChatOpenAI client instance.
|
|
28
|
+
|
|
29
|
+
Args:
|
|
30
|
+
env_file: Optional path to environment file
|
|
31
|
+
|
|
32
|
+
Returns:
|
|
33
|
+
ChatOpenAI client instance
|
|
34
|
+
|
|
35
|
+
Raises:
|
|
36
|
+
LangchainNotInstalledError: If langchain-openai package is not installed
|
|
37
|
+
"""
|
|
38
|
+
settings = UniqueSettings.from_env(env_file=env_file)
|
|
39
|
+
|
|
40
|
+
return ChatOpenAI(
|
|
41
|
+
base_url=settings.app.base_url + "/openai-proxy/",
|
|
42
|
+
default_headers=get_default_headers(settings.app, settings.auth),
|
|
43
|
+
model="AZURE_GPT_4o_2024_0806",
|
|
44
|
+
api_key=settings.app.key,
|
|
45
|
+
)
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import importlib.util
|
|
2
|
+
import logging
|
|
3
|
+
from pathlib import Path
|
|
4
|
+
|
|
5
|
+
from unique_toolkit.app.unique_settings import UniqueSettings
|
|
6
|
+
from unique_toolkit.framework_utilities.utils import get_default_headers
|
|
7
|
+
|
|
8
|
+
logger = logging.getLogger("toolkit.framework_utilities.openai")
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
class OpenAINotInstalledError(ImportError):
|
|
12
|
+
"""Raised when OpenAI package is not installed but functionality requiring it is accessed."""
|
|
13
|
+
|
|
14
|
+
def __init__(self):
|
|
15
|
+
super().__init__(
|
|
16
|
+
"OpenAI package is not installed. Install it with 'poetry install --with openai'."
|
|
17
|
+
)
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
if importlib.util.find_spec("openai") is not None:
|
|
21
|
+
from openai import OpenAI
|
|
22
|
+
else:
|
|
23
|
+
raise OpenAINotInstalledError()
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
def get_openai_client(env_file: Path | None = None) -> OpenAI:
|
|
27
|
+
"""Get an OpenAI client instance.
|
|
28
|
+
|
|
29
|
+
Args:
|
|
30
|
+
env_file: Optional path to environment file
|
|
31
|
+
|
|
32
|
+
Returns:
|
|
33
|
+
OpenAI client instance
|
|
34
|
+
|
|
35
|
+
Raises:
|
|
36
|
+
OpenAINotInstalledError: If OpenAI package is not installed
|
|
37
|
+
"""
|
|
38
|
+
settings = UniqueSettings.from_env(env_file=env_file)
|
|
39
|
+
default_headers = get_default_headers(settings.app, settings.auth)
|
|
40
|
+
|
|
41
|
+
return OpenAI(
|
|
42
|
+
api_key=settings.app.key.get_secret_value(),
|
|
43
|
+
base_url=settings.app.base_url + "/openai-proxy/",
|
|
44
|
+
default_headers=default_headers,
|
|
45
|
+
)
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
from collections.abc import Iterable
|
|
2
|
+
from typing import Self
|
|
3
|
+
|
|
4
|
+
from openai.types.chat.chat_completion_assistant_message_param import (
|
|
5
|
+
ChatCompletionAssistantMessageParam,
|
|
6
|
+
ContentArrayOfContentPart,
|
|
7
|
+
)
|
|
8
|
+
from openai.types.chat.chat_completion_content_part_param import (
|
|
9
|
+
ChatCompletionContentPartParam,
|
|
10
|
+
)
|
|
11
|
+
from openai.types.chat.chat_completion_content_part_text_param import (
|
|
12
|
+
ChatCompletionContentPartTextParam,
|
|
13
|
+
)
|
|
14
|
+
from openai.types.chat.chat_completion_developer_message_param import (
|
|
15
|
+
ChatCompletionDeveloperMessageParam,
|
|
16
|
+
)
|
|
17
|
+
from openai.types.chat.chat_completion_function_message_param import (
|
|
18
|
+
ChatCompletionFunctionMessageParam,
|
|
19
|
+
)
|
|
20
|
+
from openai.types.chat.chat_completion_message_param import ChatCompletionMessageParam
|
|
21
|
+
from openai.types.chat.chat_completion_system_message_param import (
|
|
22
|
+
ChatCompletionSystemMessageParam,
|
|
23
|
+
)
|
|
24
|
+
from openai.types.chat.chat_completion_tool_message_param import (
|
|
25
|
+
ChatCompletionToolMessageParam,
|
|
26
|
+
)
|
|
27
|
+
from openai.types.chat.chat_completion_user_message_param import (
|
|
28
|
+
ChatCompletionUserMessageParam,
|
|
29
|
+
)
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
class OpenAIMessageBuilder:
|
|
33
|
+
def __init__(
|
|
34
|
+
self,
|
|
35
|
+
messages: list[ChatCompletionMessageParam] | None = None,
|
|
36
|
+
) -> None:
|
|
37
|
+
self._messages: list[ChatCompletionMessageParam] = []
|
|
38
|
+
if messages:
|
|
39
|
+
self._messages = messages
|
|
40
|
+
|
|
41
|
+
@classmethod
|
|
42
|
+
def from_messages(cls, messages: list[ChatCompletionMessageParam]) -> Self:
|
|
43
|
+
builder = cls()
|
|
44
|
+
builder._messages = messages.copy()
|
|
45
|
+
return builder
|
|
46
|
+
|
|
47
|
+
def append_system_message(
|
|
48
|
+
self,
|
|
49
|
+
content: str | Iterable[ChatCompletionContentPartTextParam],
|
|
50
|
+
name: str = "user",
|
|
51
|
+
) -> Self:
|
|
52
|
+
self._messages.append(
|
|
53
|
+
ChatCompletionSystemMessageParam(
|
|
54
|
+
content=content,
|
|
55
|
+
role="system",
|
|
56
|
+
name=name,
|
|
57
|
+
),
|
|
58
|
+
)
|
|
59
|
+
return self
|
|
60
|
+
|
|
61
|
+
def append_user_message(
|
|
62
|
+
self,
|
|
63
|
+
content: str | Iterable[ChatCompletionContentPartParam],
|
|
64
|
+
name: str = "user",
|
|
65
|
+
) -> Self:
|
|
66
|
+
self._messages.append(
|
|
67
|
+
ChatCompletionUserMessageParam(
|
|
68
|
+
content=content,
|
|
69
|
+
role="user",
|
|
70
|
+
name=name,
|
|
71
|
+
),
|
|
72
|
+
)
|
|
73
|
+
return self
|
|
74
|
+
|
|
75
|
+
def append_assistant_message(
|
|
76
|
+
self,
|
|
77
|
+
content: str | Iterable[ContentArrayOfContentPart],
|
|
78
|
+
name: str = "assistant",
|
|
79
|
+
) -> Self:
|
|
80
|
+
self._messages.append(
|
|
81
|
+
ChatCompletionAssistantMessageParam(
|
|
82
|
+
content=content,
|
|
83
|
+
role="assistant",
|
|
84
|
+
name=name,
|
|
85
|
+
),
|
|
86
|
+
)
|
|
87
|
+
return self
|
|
88
|
+
|
|
89
|
+
def append_developper_message(
|
|
90
|
+
self,
|
|
91
|
+
content: str | Iterable[ChatCompletionContentPartTextParam],
|
|
92
|
+
name: str = "developer",
|
|
93
|
+
) -> Self:
|
|
94
|
+
self._messages.append(
|
|
95
|
+
ChatCompletionDeveloperMessageParam(
|
|
96
|
+
content=content,
|
|
97
|
+
role="developer",
|
|
98
|
+
name=name,
|
|
99
|
+
),
|
|
100
|
+
)
|
|
101
|
+
return self
|
|
102
|
+
|
|
103
|
+
def append_function_message(
|
|
104
|
+
self,
|
|
105
|
+
content: str | None,
|
|
106
|
+
name: str = "function",
|
|
107
|
+
) -> Self:
|
|
108
|
+
self._messages.append(
|
|
109
|
+
ChatCompletionFunctionMessageParam(
|
|
110
|
+
content=content,
|
|
111
|
+
role="function",
|
|
112
|
+
name=name,
|
|
113
|
+
),
|
|
114
|
+
)
|
|
115
|
+
return self
|
|
116
|
+
|
|
117
|
+
def append_tool_message(
|
|
118
|
+
self,
|
|
119
|
+
content: str | Iterable[ChatCompletionContentPartTextParam],
|
|
120
|
+
tool_call_id: str,
|
|
121
|
+
) -> Self:
|
|
122
|
+
self._messages.append(
|
|
123
|
+
ChatCompletionToolMessageParam(
|
|
124
|
+
content=content,
|
|
125
|
+
role="tool",
|
|
126
|
+
tool_call_id=tool_call_id,
|
|
127
|
+
),
|
|
128
|
+
)
|
|
129
|
+
return self
|
|
130
|
+
|
|
131
|
+
@property
|
|
132
|
+
def messages(self) -> list[ChatCompletionMessageParam]:
|
|
133
|
+
return self._messages
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
from unique_toolkit.app.unique_settings import UniqueApp, UniqueAuth
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
def auth_headers(auth_settings: UniqueAuth) -> dict[str, str]:
|
|
5
|
+
return {
|
|
6
|
+
"x-user-id": auth_settings.user_id.get_secret_value(),
|
|
7
|
+
"x-company-id": auth_settings.company_id.get_secret_value(),
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
def app_headers(app_settings: UniqueApp) -> dict[str, str]:
|
|
12
|
+
return {
|
|
13
|
+
"x-app-id": app_settings.id.get_secret_value(),
|
|
14
|
+
"Authorization": f"Bearer {app_settings.key.get_secret_value()}",
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
def get_default_headers(app_settings: UniqueApp, auth_settings: UniqueAuth):
|
|
19
|
+
default_headers = {}
|
|
20
|
+
default_headers.update(app_headers(app_settings))
|
|
21
|
+
default_headers.update(auth_headers(auth_settings))
|
|
22
|
+
default_headers["x-api-version"] = "2023-12-06"
|
|
23
|
+
return default_headers
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.1
|
|
2
2
|
Name: unique_toolkit
|
|
3
|
-
Version: 0.7.
|
|
3
|
+
Version: 0.7.39
|
|
4
4
|
Summary:
|
|
5
5
|
License: Proprietary
|
|
6
6
|
Author: Martin Fadler
|
|
@@ -113,6 +113,10 @@ All notable changes to this project will be documented in this file.
|
|
|
113
113
|
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
|
|
114
114
|
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
|
115
115
|
|
|
116
|
+
## [0.7.39] - 2025-07-28
|
|
117
|
+
- Implement utitilites to work with openai client
|
|
118
|
+
- Implement utitilites to work with langchain llm
|
|
119
|
+
|
|
116
120
|
## [0.7.38] - 2025-07-25
|
|
117
121
|
- Fix issues with secret strings in settings
|
|
118
122
|
|
|
@@ -47,7 +47,11 @@ unique_toolkit/evaluators/hallucination/service.py,sha256=k8qro5Lw4Ak58m4HYp3G4H
|
|
|
47
47
|
unique_toolkit/evaluators/hallucination/utils.py,sha256=gO2AOzDQwVTev2_5vDKgJ9A6A9e0himJyAta_wglVG8,8326
|
|
48
48
|
unique_toolkit/evaluators/output_parser.py,sha256=eI72qkzK1dZyUvnfP2SOAQCGBj_-PwX5wy_aLPMsJMY,883
|
|
49
49
|
unique_toolkit/evaluators/schemas.py,sha256=Jaue6Uhx75X1CyHKWj8sT3RE1JZXTqoLtfLt2xQNCX8,2507
|
|
50
|
+
unique_toolkit/framework_utilities/langchain/client.py,sha256=GWzL2GSxErj52dpYC15w8ABmDB5S2nr2QmV8rKmeEFM,1367
|
|
50
51
|
unique_toolkit/framework_utilities/langchain/history.py,sha256=8ejA0utPUIlX4z8gtX9IkVFiooY-vOT1UcjI_MoJaAU,638
|
|
52
|
+
unique_toolkit/framework_utilities/openai/client.py,sha256=itbEv098j4alz2Rftp4kbjeloFsAqaxyyBHdZTH5OYM,1297
|
|
53
|
+
unique_toolkit/framework_utilities/openai/message_builder.py,sha256=meJVGPaSQ6xEafNZtACujcD0KXdiSYGTNiv02FSJULE,3834
|
|
54
|
+
unique_toolkit/framework_utilities/utils.py,sha256=JK7g2yMfEx3eMprug26769xqNpS5WJcizf8n2zWMBng,789
|
|
51
55
|
unique_toolkit/language_model/__init__.py,sha256=lRQyLlbwHbNFf4-0foBU13UGb09lwEeodbVsfsSgaCk,1971
|
|
52
56
|
unique_toolkit/language_model/builder.py,sha256=69WCcmkm2rMP2-YEH_EjHiEp6OzwjwCs8VbhjVJaCe0,3168
|
|
53
57
|
unique_toolkit/language_model/constants.py,sha256=B-topqW0r83dkC_25DeQfnPk3n53qzIHUCBS7YJ0-1U,119
|
|
@@ -66,7 +70,7 @@ unique_toolkit/short_term_memory/schemas.py,sha256=OhfcXyF6ACdwIXW45sKzjtZX_gkcJ
|
|
|
66
70
|
unique_toolkit/short_term_memory/service.py,sha256=8sW7cFJRd4vcRfotJSWb0uHZYl-e5hQWp3G1SddL5Bg,8110
|
|
67
71
|
unique_toolkit/smart_rules/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
68
72
|
unique_toolkit/smart_rules/compile.py,sha256=cxWjb2dxEI2HGsakKdVCkSNi7VK9mr08w5sDcFCQyWI,9553
|
|
69
|
-
unique_toolkit-0.7.
|
|
70
|
-
unique_toolkit-0.7.
|
|
71
|
-
unique_toolkit-0.7.
|
|
72
|
-
unique_toolkit-0.7.
|
|
73
|
+
unique_toolkit-0.7.39.dist-info/LICENSE,sha256=GlN8wHNdh53xwOPg44URnwag6TEolCjoq3YD_KrWgss,193
|
|
74
|
+
unique_toolkit-0.7.39.dist-info/METADATA,sha256=4vZp5-p04GYGeJBpu6vhRg2FhCvBwZGqHl8AH1dIiPI,25393
|
|
75
|
+
unique_toolkit-0.7.39.dist-info/WHEEL,sha256=sP946D7jFCHeNz5Iq4fL4Lu-PrWrFsgfLXbbkciIZwg,88
|
|
76
|
+
unique_toolkit-0.7.39.dist-info/RECORD,,
|
|
File without changes
|
|
File without changes
|