orq-ai-sdk 4.2.0rc28__py3-none-any.whl → 4.3.0rc7__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.
- orq_ai_sdk/_version.py +3 -3
- orq_ai_sdk/agents.py +186 -186
- orq_ai_sdk/audio.py +30 -0
- orq_ai_sdk/basesdk.py +20 -6
- orq_ai_sdk/chat.py +22 -0
- orq_ai_sdk/completions.py +438 -0
- orq_ai_sdk/contacts.py +43 -855
- orq_ai_sdk/deployments.py +61 -0
- orq_ai_sdk/edits.py +364 -0
- orq_ai_sdk/embeddings.py +344 -0
- orq_ai_sdk/generations.py +370 -0
- orq_ai_sdk/identities.py +1037 -0
- orq_ai_sdk/images.py +28 -0
- orq_ai_sdk/models/__init__.py +5746 -737
- orq_ai_sdk/models/actionreviewedstreamingevent.py +18 -1
- orq_ai_sdk/models/actionreviewrequestedstreamingevent.py +44 -1
- orq_ai_sdk/models/agenterroredstreamingevent.py +18 -1
- orq_ai_sdk/models/agentinactivestreamingevent.py +168 -70
- orq_ai_sdk/models/agentmessagecreatedstreamingevent.py +18 -2
- orq_ai_sdk/models/agentresponsemessage.py +18 -2
- orq_ai_sdk/models/agentstartedstreamingevent.py +127 -2
- orq_ai_sdk/models/agentthoughtstreamingevent.py +178 -211
- orq_ai_sdk/models/conversationresponse.py +31 -20
- orq_ai_sdk/models/conversationwithmessagesresponse.py +31 -20
- orq_ai_sdk/models/createagentrequestop.py +1945 -383
- orq_ai_sdk/models/createagentresponse.py +147 -91
- orq_ai_sdk/models/createagentresponserequestop.py +111 -2
- orq_ai_sdk/models/createchatcompletionop.py +1381 -861
- orq_ai_sdk/models/createchunkop.py +46 -19
- orq_ai_sdk/models/createcompletionop.py +2078 -0
- orq_ai_sdk/models/createcontactop.py +45 -56
- orq_ai_sdk/models/createconversationop.py +61 -39
- orq_ai_sdk/models/createconversationresponseop.py +68 -4
- orq_ai_sdk/models/createdatasetitemop.py +424 -80
- orq_ai_sdk/models/createdatasetop.py +19 -2
- orq_ai_sdk/models/createdatasourceop.py +92 -26
- orq_ai_sdk/models/createembeddingop.py +579 -0
- orq_ai_sdk/models/createevalop.py +552 -24
- orq_ai_sdk/models/createidentityop.py +176 -0
- orq_ai_sdk/models/createimageeditop.py +715 -0
- orq_ai_sdk/models/createimageop.py +407 -128
- orq_ai_sdk/models/createimagevariationop.py +706 -0
- orq_ai_sdk/models/createknowledgeop.py +186 -121
- orq_ai_sdk/models/creatememorydocumentop.py +50 -1
- orq_ai_sdk/models/creatememoryop.py +34 -21
- orq_ai_sdk/models/creatememorystoreop.py +34 -1
- orq_ai_sdk/models/createmoderationop.py +521 -0
- orq_ai_sdk/models/createpromptop.py +2759 -1251
- orq_ai_sdk/models/creatererankop.py +608 -0
- orq_ai_sdk/models/createresponseop.py +2567 -0
- orq_ai_sdk/models/createspeechop.py +466 -0
- orq_ai_sdk/models/createtoolop.py +537 -12
- orq_ai_sdk/models/createtranscriptionop.py +732 -0
- orq_ai_sdk/models/createtranslationop.py +702 -0
- orq_ai_sdk/models/datapart.py +18 -1
- orq_ai_sdk/models/deletechunksop.py +34 -1
- orq_ai_sdk/models/{deletecontactop.py → deleteidentityop.py} +9 -9
- orq_ai_sdk/models/deletepromptop.py +26 -0
- orq_ai_sdk/models/deploymentcreatemetricop.py +362 -76
- orq_ai_sdk/models/deploymentgetconfigop.py +635 -194
- orq_ai_sdk/models/deploymentinvokeop.py +168 -173
- orq_ai_sdk/models/deploymentsop.py +195 -58
- orq_ai_sdk/models/deploymentstreamop.py +652 -304
- orq_ai_sdk/models/errorpart.py +18 -1
- orq_ai_sdk/models/filecontentpartschema.py +18 -1
- orq_ai_sdk/models/filegetop.py +19 -2
- orq_ai_sdk/models/filelistop.py +35 -2
- orq_ai_sdk/models/filepart.py +50 -1
- orq_ai_sdk/models/fileuploadop.py +51 -2
- orq_ai_sdk/models/generateconversationnameop.py +31 -20
- orq_ai_sdk/models/get_v2_evaluators_id_versionsop.py +34 -1
- orq_ai_sdk/models/get_v2_tools_tool_id_versions_version_id_op.py +18 -1
- orq_ai_sdk/models/get_v2_tools_tool_id_versionsop.py +34 -1
- orq_ai_sdk/models/getallmemoriesop.py +34 -21
- orq_ai_sdk/models/getallmemorydocumentsop.py +42 -1
- orq_ai_sdk/models/getallmemorystoresop.py +34 -1
- orq_ai_sdk/models/getallpromptsop.py +1696 -230
- orq_ai_sdk/models/getalltoolsop.py +325 -8
- orq_ai_sdk/models/getchunkscountop.py +34 -1
- orq_ai_sdk/models/getevalsop.py +395 -43
- orq_ai_sdk/models/getonechunkop.py +14 -19
- orq_ai_sdk/models/getoneknowledgeop.py +116 -96
- orq_ai_sdk/models/getonepromptop.py +1679 -230
- orq_ai_sdk/models/getpromptversionop.py +1676 -216
- orq_ai_sdk/models/imagecontentpartschema.py +50 -1
- orq_ai_sdk/models/internal/globals.py +18 -1
- orq_ai_sdk/models/invokeagentop.py +140 -2
- orq_ai_sdk/models/invokedeploymentrequest.py +418 -80
- orq_ai_sdk/models/invokeevalop.py +160 -131
- orq_ai_sdk/models/listagentsop.py +805 -166
- orq_ai_sdk/models/listchunksop.py +32 -19
- orq_ai_sdk/models/listchunkspaginatedop.py +46 -19
- orq_ai_sdk/models/listconversationsop.py +18 -1
- orq_ai_sdk/models/listdatasetdatapointsop.py +252 -42
- orq_ai_sdk/models/listdatasetsop.py +35 -2
- orq_ai_sdk/models/listdatasourcesop.py +35 -26
- orq_ai_sdk/models/{listcontactsop.py → listidentitiesop.py} +89 -79
- orq_ai_sdk/models/listknowledgebasesop.py +132 -96
- orq_ai_sdk/models/listmodelsop.py +1 -0
- orq_ai_sdk/models/listpromptversionsop.py +1690 -216
- orq_ai_sdk/models/parseop.py +161 -17
- orq_ai_sdk/models/partdoneevent.py +19 -2
- orq_ai_sdk/models/post_v2_router_ocrop.py +408 -0
- orq_ai_sdk/models/publiccontact.py +27 -4
- orq_ai_sdk/models/publicidentity.py +62 -0
- orq_ai_sdk/models/reasoningpart.py +19 -2
- orq_ai_sdk/models/refusalpartschema.py +18 -1
- orq_ai_sdk/models/remoteconfigsgetconfigop.py +34 -1
- orq_ai_sdk/models/responsedoneevent.py +114 -84
- orq_ai_sdk/models/responsestartedevent.py +18 -1
- orq_ai_sdk/models/retrieveagentrequestop.py +799 -166
- orq_ai_sdk/models/retrievedatapointop.py +236 -42
- orq_ai_sdk/models/retrievedatasetop.py +19 -2
- orq_ai_sdk/models/retrievedatasourceop.py +17 -26
- orq_ai_sdk/models/{retrievecontactop.py → retrieveidentityop.py} +38 -41
- orq_ai_sdk/models/retrievememorydocumentop.py +18 -1
- orq_ai_sdk/models/retrievememoryop.py +18 -21
- orq_ai_sdk/models/retrievememorystoreop.py +18 -1
- orq_ai_sdk/models/retrievetoolop.py +309 -8
- orq_ai_sdk/models/runagentop.py +1462 -196
- orq_ai_sdk/models/searchknowledgeop.py +108 -1
- orq_ai_sdk/models/security.py +18 -1
- orq_ai_sdk/models/streamagentop.py +93 -2
- orq_ai_sdk/models/streamrunagentop.py +1439 -194
- orq_ai_sdk/models/textcontentpartschema.py +34 -1
- orq_ai_sdk/models/thinkingconfigenabledschema.py +18 -1
- orq_ai_sdk/models/toolcallpart.py +18 -1
- orq_ai_sdk/models/tooldoneevent.py +18 -1
- orq_ai_sdk/models/toolexecutionfailedstreamingevent.py +50 -1
- orq_ai_sdk/models/toolexecutionfinishedstreamingevent.py +34 -1
- orq_ai_sdk/models/toolexecutionstartedstreamingevent.py +34 -1
- orq_ai_sdk/models/toolresultpart.py +18 -1
- orq_ai_sdk/models/toolreviewrequestedevent.py +18 -1
- orq_ai_sdk/models/toolstartedevent.py +18 -1
- orq_ai_sdk/models/updateagentop.py +1968 -397
- orq_ai_sdk/models/updatechunkop.py +46 -19
- orq_ai_sdk/models/updateconversationop.py +61 -39
- orq_ai_sdk/models/updatedatapointop.py +424 -80
- orq_ai_sdk/models/updatedatasetop.py +51 -2
- orq_ai_sdk/models/updatedatasourceop.py +17 -26
- orq_ai_sdk/models/updateevalop.py +577 -16
- orq_ai_sdk/models/{updatecontactop.py → updateidentityop.py} +78 -68
- orq_ai_sdk/models/updateknowledgeop.py +234 -190
- orq_ai_sdk/models/updatememorydocumentop.py +50 -1
- orq_ai_sdk/models/updatememoryop.py +50 -21
- orq_ai_sdk/models/updatememorystoreop.py +66 -1
- orq_ai_sdk/models/updatepromptop.py +2854 -1448
- orq_ai_sdk/models/updatetoolop.py +592 -9
- orq_ai_sdk/models/usermessagerequest.py +18 -2
- orq_ai_sdk/moderations.py +218 -0
- orq_ai_sdk/orq_completions.py +666 -0
- orq_ai_sdk/orq_responses.py +398 -0
- orq_ai_sdk/prompts.py +28 -36
- orq_ai_sdk/rerank.py +330 -0
- orq_ai_sdk/router.py +89 -641
- orq_ai_sdk/sdk.py +3 -0
- orq_ai_sdk/speech.py +333 -0
- orq_ai_sdk/transcriptions.py +416 -0
- orq_ai_sdk/translations.py +384 -0
- orq_ai_sdk/utils/__init__.py +13 -1
- orq_ai_sdk/variations.py +364 -0
- {orq_ai_sdk-4.2.0rc28.dist-info → orq_ai_sdk-4.3.0rc7.dist-info}/METADATA +169 -148
- orq_ai_sdk-4.3.0rc7.dist-info/RECORD +263 -0
- {orq_ai_sdk-4.2.0rc28.dist-info → orq_ai_sdk-4.3.0rc7.dist-info}/WHEEL +2 -1
- orq_ai_sdk-4.3.0rc7.dist-info/top_level.txt +1 -0
- orq_ai_sdk-4.2.0rc28.dist-info/RECORD +0 -233
|
@@ -2,9 +2,10 @@
|
|
|
2
2
|
|
|
3
3
|
from __future__ import annotations
|
|
4
4
|
from datetime import datetime
|
|
5
|
-
from orq_ai_sdk.types import BaseModel
|
|
5
|
+
from orq_ai_sdk.types import BaseModel, UNSET_SENTINEL
|
|
6
6
|
from orq_ai_sdk.utils import parse_datetime
|
|
7
7
|
import pydantic
|
|
8
|
+
from pydantic import model_serializer
|
|
8
9
|
from typing import Optional
|
|
9
10
|
from typing_extensions import Annotated, NotRequired, TypedDict
|
|
10
11
|
|
|
@@ -93,5 +94,21 @@ class CreateDatasetResponseBody(BaseModel):
|
|
|
93
94
|
created: Optional[datetime] = None
|
|
94
95
|
r"""The date and time the resource was created"""
|
|
95
96
|
|
|
96
|
-
updated: Optional[datetime] = parse_datetime("2026-01-
|
|
97
|
+
updated: Optional[datetime] = parse_datetime("2026-01-28T17:03:47.548Z")
|
|
97
98
|
r"""The date and time the resource was last updated"""
|
|
99
|
+
|
|
100
|
+
@model_serializer(mode="wrap")
|
|
101
|
+
def serialize_model(self, handler):
|
|
102
|
+
optional_fields = set(["created_by_id", "updated_by_id", "created", "updated"])
|
|
103
|
+
serialized = handler(self)
|
|
104
|
+
m = {}
|
|
105
|
+
|
|
106
|
+
for n, f in type(self).model_fields.items():
|
|
107
|
+
k = f.alias or n
|
|
108
|
+
val = serialized.get(k)
|
|
109
|
+
|
|
110
|
+
if val != UNSET_SENTINEL:
|
|
111
|
+
if val is not None or k not in optional_fields:
|
|
112
|
+
m[k] = val
|
|
113
|
+
|
|
114
|
+
return m
|
|
@@ -44,6 +44,22 @@ class ChunkingConfiguration2(BaseModel):
|
|
|
44
44
|
chunk_overlap: Optional[float] = 0
|
|
45
45
|
r"""Specifies the number of characters to overlap between consecutive chunks. This overlap helps maintain semantic continuity when splitting large text elements."""
|
|
46
46
|
|
|
47
|
+
@model_serializer(mode="wrap")
|
|
48
|
+
def serialize_model(self, handler):
|
|
49
|
+
optional_fields = set(["chunk_max_characters", "chunk_overlap"])
|
|
50
|
+
serialized = handler(self)
|
|
51
|
+
m = {}
|
|
52
|
+
|
|
53
|
+
for n, f in type(self).model_fields.items():
|
|
54
|
+
k = f.alias or n
|
|
55
|
+
val = serialized.get(k)
|
|
56
|
+
|
|
57
|
+
if val != UNSET_SENTINEL:
|
|
58
|
+
if val is not None or k not in optional_fields:
|
|
59
|
+
m[k] = val
|
|
60
|
+
|
|
61
|
+
return m
|
|
62
|
+
|
|
47
63
|
|
|
48
64
|
ChunkingConfigurationType = Literal["default",]
|
|
49
65
|
|
|
@@ -125,6 +141,33 @@ class ChunkingCleanupOptions(BaseModel):
|
|
|
125
141
|
clean_whitespaces: Optional[bool] = None
|
|
126
142
|
r"""Trims and normalizes excessive whitespace throughout the text."""
|
|
127
143
|
|
|
144
|
+
@model_serializer(mode="wrap")
|
|
145
|
+
def serialize_model(self, handler):
|
|
146
|
+
optional_fields = set(
|
|
147
|
+
[
|
|
148
|
+
"delete_emails",
|
|
149
|
+
"delete_credit_cards",
|
|
150
|
+
"delete_phone_numbers",
|
|
151
|
+
"clean_bullet_points",
|
|
152
|
+
"clean_numbered_list",
|
|
153
|
+
"clean_unicode",
|
|
154
|
+
"clean_dashes",
|
|
155
|
+
"clean_whitespaces",
|
|
156
|
+
]
|
|
157
|
+
)
|
|
158
|
+
serialized = handler(self)
|
|
159
|
+
m = {}
|
|
160
|
+
|
|
161
|
+
for n, f in type(self).model_fields.items():
|
|
162
|
+
k = f.alias or n
|
|
163
|
+
val = serialized.get(k)
|
|
164
|
+
|
|
165
|
+
if val != UNSET_SENTINEL:
|
|
166
|
+
if val is not None or k not in optional_fields:
|
|
167
|
+
m[k] = val
|
|
168
|
+
|
|
169
|
+
return m
|
|
170
|
+
|
|
128
171
|
|
|
129
172
|
class ChunkingOptionsTypedDict(TypedDict):
|
|
130
173
|
r"""Configuration options specifying how the datasource file is chunked. Required if `file_id` is specified. Defaults to standard chunking options if omitted."""
|
|
@@ -144,6 +187,22 @@ class ChunkingOptions(BaseModel):
|
|
|
144
187
|
chunking_cleanup_options: Optional[ChunkingCleanupOptions] = None
|
|
145
188
|
r"""The cleanup options applied to the datasource content. All options are enabled by default to ensure enhanced security and optimal chunk quality. Defaults to system-standard cleanup options if not specified."""
|
|
146
189
|
|
|
190
|
+
@model_serializer(mode="wrap")
|
|
191
|
+
def serialize_model(self, handler):
|
|
192
|
+
optional_fields = set(["chunking_configuration", "chunking_cleanup_options"])
|
|
193
|
+
serialized = handler(self)
|
|
194
|
+
m = {}
|
|
195
|
+
|
|
196
|
+
for n, f in type(self).model_fields.items():
|
|
197
|
+
k = f.alias or n
|
|
198
|
+
val = serialized.get(k)
|
|
199
|
+
|
|
200
|
+
if val != UNSET_SENTINEL:
|
|
201
|
+
if val is not None or k not in optional_fields:
|
|
202
|
+
m[k] = val
|
|
203
|
+
|
|
204
|
+
return m
|
|
205
|
+
|
|
147
206
|
|
|
148
207
|
class CreateDatasourceRequestBodyTypedDict(TypedDict):
|
|
149
208
|
display_name: NotRequired[str]
|
|
@@ -164,6 +223,22 @@ class CreateDatasourceRequestBody(BaseModel):
|
|
|
164
223
|
chunking_options: Optional[ChunkingOptions] = None
|
|
165
224
|
r"""Configuration options specifying how the datasource file is chunked. Required if `file_id` is specified. Defaults to standard chunking options if omitted."""
|
|
166
225
|
|
|
226
|
+
@model_serializer(mode="wrap")
|
|
227
|
+
def serialize_model(self, handler):
|
|
228
|
+
optional_fields = set(["display_name", "file_id", "chunking_options"])
|
|
229
|
+
serialized = handler(self)
|
|
230
|
+
m = {}
|
|
231
|
+
|
|
232
|
+
for n, f in type(self).model_fields.items():
|
|
233
|
+
k = f.alias or n
|
|
234
|
+
val = serialized.get(k)
|
|
235
|
+
|
|
236
|
+
if val != UNSET_SENTINEL:
|
|
237
|
+
if val is not None or k not in optional_fields:
|
|
238
|
+
m[k] = val
|
|
239
|
+
|
|
240
|
+
return m
|
|
241
|
+
|
|
167
242
|
|
|
168
243
|
class CreateDatasourceRequestTypedDict(TypedDict):
|
|
169
244
|
knowledge_id: str
|
|
@@ -239,7 +314,7 @@ class CreateDatasourceResponseBody(BaseModel):
|
|
|
239
314
|
r"""The number of chunks in the datasource"""
|
|
240
315
|
|
|
241
316
|
id: Annotated[Optional[str], pydantic.Field(alias="_id")] = (
|
|
242
|
-
"
|
|
317
|
+
"01KG2RZQXWVHXSANH80W3TQW09"
|
|
243
318
|
)
|
|
244
319
|
r"""The unique identifier of the data source"""
|
|
245
320
|
|
|
@@ -257,36 +332,27 @@ class CreateDatasourceResponseBody(BaseModel):
|
|
|
257
332
|
|
|
258
333
|
@model_serializer(mode="wrap")
|
|
259
334
|
def serialize_model(self, handler):
|
|
260
|
-
optional_fields =
|
|
261
|
-
"_id",
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
"created_by_id",
|
|
265
|
-
"update_by_id",
|
|
266
|
-
]
|
|
267
|
-
nullable_fields = ["file_id", "created_by_id", "update_by_id"]
|
|
268
|
-
null_default_fields = []
|
|
269
|
-
|
|
335
|
+
optional_fields = set(
|
|
336
|
+
["_id", "description", "file_id", "created_by_id", "update_by_id"]
|
|
337
|
+
)
|
|
338
|
+
nullable_fields = set(["file_id", "created_by_id", "update_by_id"])
|
|
270
339
|
serialized = handler(self)
|
|
271
|
-
|
|
272
340
|
m = {}
|
|
273
341
|
|
|
274
342
|
for n, f in type(self).model_fields.items():
|
|
275
343
|
k = f.alias or n
|
|
276
344
|
val = serialized.get(k)
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
):
|
|
290
|
-
m[k] = val
|
|
345
|
+
is_nullable_and_explicitly_set = (
|
|
346
|
+
k in nullable_fields
|
|
347
|
+
and (self.__pydantic_fields_set__.intersection({n})) # pylint: disable=no-member
|
|
348
|
+
)
|
|
349
|
+
|
|
350
|
+
if val != UNSET_SENTINEL:
|
|
351
|
+
if (
|
|
352
|
+
val is not None
|
|
353
|
+
or k not in optional_fields
|
|
354
|
+
or is_nullable_and_explicitly_set
|
|
355
|
+
):
|
|
356
|
+
m[k] = val
|
|
291
357
|
|
|
292
358
|
return m
|