mistralai 1.5.2__py3-none-any.whl → 1.6.0__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.
- mistralai/_hooks/types.py +15 -3
- mistralai/_version.py +3 -3
- mistralai/agents.py +44 -12
- mistralai/basesdk.py +8 -0
- mistralai/chat.py +44 -12
- mistralai/classifiers.py +36 -16
- mistralai/embeddings.py +16 -6
- mistralai/files.py +36 -0
- mistralai/fim.py +32 -12
- mistralai/httpclient.py +4 -2
- mistralai/jobs.py +30 -0
- mistralai/mistral_jobs.py +24 -0
- mistralai/models/agentscompletionrequest.py +4 -0
- mistralai/models/agentscompletionstreamrequest.py +4 -0
- mistralai/models/chatcompletionrequest.py +4 -0
- mistralai/models/chatcompletionstreamrequest.py +4 -0
- mistralai/models/function.py +2 -2
- mistralai/models/jsonschema.py +1 -1
- mistralai/models_.py +66 -18
- mistralai/ocr.py +16 -6
- mistralai/sdk.py +19 -3
- mistralai/sdkconfiguration.py +4 -2
- mistralai/utils/__init__.py +2 -0
- mistralai/utils/serializers.py +10 -6
- mistralai/utils/values.py +4 -1
- {mistralai-1.5.2.dist-info → mistralai-1.6.0.dist-info}/METADATA +63 -16
- {mistralai-1.5.2.dist-info → mistralai-1.6.0.dist-info}/RECORD +80 -72
- mistralai_azure/__init__.py +10 -1
- mistralai_azure/_hooks/types.py +15 -3
- mistralai_azure/_version.py +4 -1
- mistralai_azure/basesdk.py +8 -0
- mistralai_azure/chat.py +100 -20
- mistralai_azure/httpclient.py +52 -0
- mistralai_azure/models/__init__.py +22 -0
- mistralai_azure/models/assistantmessage.py +2 -0
- mistralai_azure/models/chatcompletionrequest.py +12 -10
- mistralai_azure/models/chatcompletionstreamrequest.py +12 -10
- mistralai_azure/models/contentchunk.py +6 -2
- mistralai_azure/models/function.py +4 -1
- mistralai_azure/models/imageurl.py +53 -0
- mistralai_azure/models/imageurlchunk.py +33 -0
- mistralai_azure/models/jsonschema.py +61 -0
- mistralai_azure/models/prediction.py +25 -0
- mistralai_azure/models/responseformat.py +42 -1
- mistralai_azure/models/responseformats.py +1 -1
- mistralai_azure/models/toolcall.py +3 -0
- mistralai_azure/sdk.py +56 -14
- mistralai_azure/sdkconfiguration.py +14 -6
- mistralai_azure/utils/__init__.py +2 -0
- mistralai_azure/utils/serializers.py +10 -6
- mistralai_azure/utils/values.py +4 -1
- mistralai_gcp/__init__.py +10 -1
- mistralai_gcp/_hooks/types.py +15 -3
- mistralai_gcp/_version.py +4 -1
- mistralai_gcp/basesdk.py +8 -0
- mistralai_gcp/chat.py +101 -21
- mistralai_gcp/fim.py +61 -21
- mistralai_gcp/httpclient.py +52 -0
- mistralai_gcp/models/__init__.py +22 -0
- mistralai_gcp/models/assistantmessage.py +2 -0
- mistralai_gcp/models/chatcompletionrequest.py +12 -10
- mistralai_gcp/models/chatcompletionstreamrequest.py +12 -10
- mistralai_gcp/models/contentchunk.py +6 -2
- mistralai_gcp/models/fimcompletionrequest.py +2 -3
- mistralai_gcp/models/fimcompletionstreamrequest.py +2 -3
- mistralai_gcp/models/function.py +4 -1
- mistralai_gcp/models/imageurl.py +53 -0
- mistralai_gcp/models/imageurlchunk.py +33 -0
- mistralai_gcp/models/jsonschema.py +61 -0
- mistralai_gcp/models/prediction.py +25 -0
- mistralai_gcp/models/responseformat.py +42 -1
- mistralai_gcp/models/responseformats.py +1 -1
- mistralai_gcp/models/toolcall.py +3 -0
- mistralai_gcp/sdk.py +63 -19
- mistralai_gcp/sdkconfiguration.py +14 -6
- mistralai_gcp/utils/__init__.py +2 -0
- mistralai_gcp/utils/serializers.py +10 -6
- mistralai_gcp/utils/values.py +4 -1
- {mistralai-1.5.2.dist-info → mistralai-1.6.0.dist-info}/LICENSE +0 -0
- {mistralai-1.5.2.dist-info → mistralai-1.6.0.dist-info}/WHEEL +0 -0
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
from __future__ import annotations
|
|
4
4
|
from .assistantmessage import AssistantMessage, AssistantMessageTypedDict
|
|
5
|
+
from .prediction import Prediction, PredictionTypedDict
|
|
5
6
|
from .responseformat import ResponseFormat, ResponseFormatTypedDict
|
|
6
7
|
from .systemmessage import SystemMessage, SystemMessageTypedDict
|
|
7
8
|
from .tool import Tool, ToolTypedDict
|
|
@@ -68,7 +69,7 @@ ChatCompletionRequestToolChoice = TypeAliasType(
|
|
|
68
69
|
|
|
69
70
|
|
|
70
71
|
class ChatCompletionRequestTypedDict(TypedDict):
|
|
71
|
-
model:
|
|
72
|
+
model: str
|
|
72
73
|
r"""ID of the model to use. You can use the [List Available Models](/api/#tag/models/operation/list_models_v1_models_get) API to see all of your available models, or see our [Model overview](/models) for model descriptions."""
|
|
73
74
|
messages: List[ChatCompletionRequestMessagesTypedDict]
|
|
74
75
|
r"""The prompt(s) to generate completions for, encoded as a list of dict with role and content."""
|
|
@@ -93,10 +94,12 @@ class ChatCompletionRequestTypedDict(TypedDict):
|
|
|
93
94
|
r"""frequency_penalty penalizes the repetition of words based on their frequency in the generated text. A higher frequency penalty discourages the model from repeating words that have already appeared frequently in the output, promoting diversity and reducing repetition."""
|
|
94
95
|
n: NotRequired[Nullable[int]]
|
|
95
96
|
r"""Number of completions to return for each request, input tokens are only billed once."""
|
|
97
|
+
prediction: NotRequired[PredictionTypedDict]
|
|
98
|
+
parallel_tool_calls: NotRequired[bool]
|
|
96
99
|
|
|
97
100
|
|
|
98
101
|
class ChatCompletionRequest(BaseModel):
|
|
99
|
-
model:
|
|
102
|
+
model: str
|
|
100
103
|
r"""ID of the model to use. You can use the [List Available Models](/api/#tag/models/operation/list_models_v1_models_get) API to see all of your available models, or see our [Model overview](/models) for model descriptions."""
|
|
101
104
|
|
|
102
105
|
messages: List[ChatCompletionRequestMessages]
|
|
@@ -135,6 +138,10 @@ class ChatCompletionRequest(BaseModel):
|
|
|
135
138
|
n: OptionalNullable[int] = UNSET
|
|
136
139
|
r"""Number of completions to return for each request, input tokens are only billed once."""
|
|
137
140
|
|
|
141
|
+
prediction: Optional[Prediction] = None
|
|
142
|
+
|
|
143
|
+
parallel_tool_calls: Optional[bool] = None
|
|
144
|
+
|
|
138
145
|
@model_serializer(mode="wrap")
|
|
139
146
|
def serialize_model(self, handler):
|
|
140
147
|
optional_fields = [
|
|
@@ -150,15 +157,10 @@ class ChatCompletionRequest(BaseModel):
|
|
|
150
157
|
"presence_penalty",
|
|
151
158
|
"frequency_penalty",
|
|
152
159
|
"n",
|
|
160
|
+
"prediction",
|
|
161
|
+
"parallel_tool_calls",
|
|
153
162
|
]
|
|
154
|
-
nullable_fields = [
|
|
155
|
-
"model",
|
|
156
|
-
"temperature",
|
|
157
|
-
"max_tokens",
|
|
158
|
-
"random_seed",
|
|
159
|
-
"tools",
|
|
160
|
-
"n",
|
|
161
|
-
]
|
|
163
|
+
nullable_fields = ["temperature", "max_tokens", "random_seed", "tools", "n"]
|
|
162
164
|
null_default_fields = []
|
|
163
165
|
|
|
164
166
|
serialized = handler(self)
|
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
from __future__ import annotations
|
|
4
4
|
from .assistantmessage import AssistantMessage, AssistantMessageTypedDict
|
|
5
|
+
from .prediction import Prediction, PredictionTypedDict
|
|
5
6
|
from .responseformat import ResponseFormat, ResponseFormatTypedDict
|
|
6
7
|
from .systemmessage import SystemMessage, SystemMessageTypedDict
|
|
7
8
|
from .tool import Tool, ToolTypedDict
|
|
@@ -64,7 +65,7 @@ ChatCompletionStreamRequestToolChoice = TypeAliasType(
|
|
|
64
65
|
|
|
65
66
|
|
|
66
67
|
class ChatCompletionStreamRequestTypedDict(TypedDict):
|
|
67
|
-
model:
|
|
68
|
+
model: str
|
|
68
69
|
r"""ID of the model to use. You can use the [List Available Models](/api/#tag/models/operation/list_models_v1_models_get) API to see all of your available models, or see our [Model overview](/models) for model descriptions."""
|
|
69
70
|
messages: List[MessagesTypedDict]
|
|
70
71
|
r"""The prompt(s) to generate completions for, encoded as a list of dict with role and content."""
|
|
@@ -88,10 +89,12 @@ class ChatCompletionStreamRequestTypedDict(TypedDict):
|
|
|
88
89
|
r"""frequency_penalty penalizes the repetition of words based on their frequency in the generated text. A higher frequency penalty discourages the model from repeating words that have already appeared frequently in the output, promoting diversity and reducing repetition."""
|
|
89
90
|
n: NotRequired[Nullable[int]]
|
|
90
91
|
r"""Number of completions to return for each request, input tokens are only billed once."""
|
|
92
|
+
prediction: NotRequired[PredictionTypedDict]
|
|
93
|
+
parallel_tool_calls: NotRequired[bool]
|
|
91
94
|
|
|
92
95
|
|
|
93
96
|
class ChatCompletionStreamRequest(BaseModel):
|
|
94
|
-
model:
|
|
97
|
+
model: str
|
|
95
98
|
r"""ID of the model to use. You can use the [List Available Models](/api/#tag/models/operation/list_models_v1_models_get) API to see all of your available models, or see our [Model overview](/models) for model descriptions."""
|
|
96
99
|
|
|
97
100
|
messages: List[Messages]
|
|
@@ -129,6 +132,10 @@ class ChatCompletionStreamRequest(BaseModel):
|
|
|
129
132
|
n: OptionalNullable[int] = UNSET
|
|
130
133
|
r"""Number of completions to return for each request, input tokens are only billed once."""
|
|
131
134
|
|
|
135
|
+
prediction: Optional[Prediction] = None
|
|
136
|
+
|
|
137
|
+
parallel_tool_calls: Optional[bool] = None
|
|
138
|
+
|
|
132
139
|
@model_serializer(mode="wrap")
|
|
133
140
|
def serialize_model(self, handler):
|
|
134
141
|
optional_fields = [
|
|
@@ -144,15 +151,10 @@ class ChatCompletionStreamRequest(BaseModel):
|
|
|
144
151
|
"presence_penalty",
|
|
145
152
|
"frequency_penalty",
|
|
146
153
|
"n",
|
|
154
|
+
"prediction",
|
|
155
|
+
"parallel_tool_calls",
|
|
147
156
|
]
|
|
148
|
-
nullable_fields = [
|
|
149
|
-
"model",
|
|
150
|
-
"temperature",
|
|
151
|
-
"max_tokens",
|
|
152
|
-
"random_seed",
|
|
153
|
-
"tools",
|
|
154
|
-
"n",
|
|
155
|
-
]
|
|
157
|
+
nullable_fields = ["temperature", "max_tokens", "random_seed", "tools", "n"]
|
|
156
158
|
null_default_fields = []
|
|
157
159
|
|
|
158
160
|
serialized = handler(self)
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
"""Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
|
|
2
2
|
|
|
3
3
|
from __future__ import annotations
|
|
4
|
+
from .imageurlchunk import ImageURLChunk, ImageURLChunkTypedDict
|
|
4
5
|
from .referencechunk import ReferenceChunk, ReferenceChunkTypedDict
|
|
5
6
|
from .textchunk import TextChunk, TextChunkTypedDict
|
|
6
7
|
from mistralai_gcp.utils import get_discriminator
|
|
@@ -10,13 +11,16 @@ from typing_extensions import Annotated, TypeAliasType
|
|
|
10
11
|
|
|
11
12
|
|
|
12
13
|
ContentChunkTypedDict = TypeAliasType(
|
|
13
|
-
"ContentChunkTypedDict",
|
|
14
|
+
"ContentChunkTypedDict",
|
|
15
|
+
Union[TextChunkTypedDict, ImageURLChunkTypedDict, ReferenceChunkTypedDict],
|
|
14
16
|
)
|
|
15
17
|
|
|
16
18
|
|
|
17
19
|
ContentChunk = Annotated[
|
|
18
20
|
Union[
|
|
19
|
-
Annotated[
|
|
21
|
+
Annotated[ImageURLChunk, Tag("image_url")],
|
|
22
|
+
Annotated[TextChunk, Tag("text")],
|
|
23
|
+
Annotated[ReferenceChunk, Tag("reference")],
|
|
20
24
|
],
|
|
21
25
|
Discriminator(lambda m: get_discriminator(m, "type", "type")),
|
|
22
26
|
]
|
|
@@ -26,7 +26,7 @@ r"""Stop generation if this token is detected. Or if one of these tokens is dete
|
|
|
26
26
|
|
|
27
27
|
|
|
28
28
|
class FIMCompletionRequestTypedDict(TypedDict):
|
|
29
|
-
model:
|
|
29
|
+
model: str
|
|
30
30
|
r"""ID of the model to use. Only compatible for now with:
|
|
31
31
|
- `codestral-2405`
|
|
32
32
|
- `codestral-latest`
|
|
@@ -52,7 +52,7 @@ class FIMCompletionRequestTypedDict(TypedDict):
|
|
|
52
52
|
|
|
53
53
|
|
|
54
54
|
class FIMCompletionRequest(BaseModel):
|
|
55
|
-
model:
|
|
55
|
+
model: str
|
|
56
56
|
r"""ID of the model to use. Only compatible for now with:
|
|
57
57
|
- `codestral-2405`
|
|
58
58
|
- `codestral-latest`
|
|
@@ -98,7 +98,6 @@ class FIMCompletionRequest(BaseModel):
|
|
|
98
98
|
"min_tokens",
|
|
99
99
|
]
|
|
100
100
|
nullable_fields = [
|
|
101
|
-
"model",
|
|
102
101
|
"temperature",
|
|
103
102
|
"max_tokens",
|
|
104
103
|
"random_seed",
|
|
@@ -26,7 +26,7 @@ r"""Stop generation if this token is detected. Or if one of these tokens is dete
|
|
|
26
26
|
|
|
27
27
|
|
|
28
28
|
class FIMCompletionStreamRequestTypedDict(TypedDict):
|
|
29
|
-
model:
|
|
29
|
+
model: str
|
|
30
30
|
r"""ID of the model to use. Only compatible for now with:
|
|
31
31
|
- `codestral-2405`
|
|
32
32
|
- `codestral-latest`
|
|
@@ -51,7 +51,7 @@ class FIMCompletionStreamRequestTypedDict(TypedDict):
|
|
|
51
51
|
|
|
52
52
|
|
|
53
53
|
class FIMCompletionStreamRequest(BaseModel):
|
|
54
|
-
model:
|
|
54
|
+
model: str
|
|
55
55
|
r"""ID of the model to use. Only compatible for now with:
|
|
56
56
|
- `codestral-2405`
|
|
57
57
|
- `codestral-latest`
|
|
@@ -96,7 +96,6 @@ class FIMCompletionStreamRequest(BaseModel):
|
|
|
96
96
|
"min_tokens",
|
|
97
97
|
]
|
|
98
98
|
nullable_fields = [
|
|
99
|
-
"model",
|
|
100
99
|
"temperature",
|
|
101
100
|
"max_tokens",
|
|
102
101
|
"random_seed",
|
mistralai_gcp/models/function.py
CHANGED
|
@@ -10,6 +10,7 @@ class FunctionTypedDict(TypedDict):
|
|
|
10
10
|
name: str
|
|
11
11
|
parameters: Dict[str, Any]
|
|
12
12
|
description: NotRequired[str]
|
|
13
|
+
strict: NotRequired[bool]
|
|
13
14
|
|
|
14
15
|
|
|
15
16
|
class Function(BaseModel):
|
|
@@ -17,4 +18,6 @@ class Function(BaseModel):
|
|
|
17
18
|
|
|
18
19
|
parameters: Dict[str, Any]
|
|
19
20
|
|
|
20
|
-
description: Optional[str] =
|
|
21
|
+
description: Optional[str] = None
|
|
22
|
+
|
|
23
|
+
strict: Optional[bool] = None
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
"""Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
|
|
2
|
+
|
|
3
|
+
from __future__ import annotations
|
|
4
|
+
from mistralai_gcp.types import (
|
|
5
|
+
BaseModel,
|
|
6
|
+
Nullable,
|
|
7
|
+
OptionalNullable,
|
|
8
|
+
UNSET,
|
|
9
|
+
UNSET_SENTINEL,
|
|
10
|
+
)
|
|
11
|
+
from pydantic import model_serializer
|
|
12
|
+
from typing_extensions import NotRequired, TypedDict
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
class ImageURLTypedDict(TypedDict):
|
|
16
|
+
url: str
|
|
17
|
+
detail: NotRequired[Nullable[str]]
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
class ImageURL(BaseModel):
|
|
21
|
+
url: str
|
|
22
|
+
|
|
23
|
+
detail: OptionalNullable[str] = UNSET
|
|
24
|
+
|
|
25
|
+
@model_serializer(mode="wrap")
|
|
26
|
+
def serialize_model(self, handler):
|
|
27
|
+
optional_fields = ["detail"]
|
|
28
|
+
nullable_fields = ["detail"]
|
|
29
|
+
null_default_fields = []
|
|
30
|
+
|
|
31
|
+
serialized = handler(self)
|
|
32
|
+
|
|
33
|
+
m = {}
|
|
34
|
+
|
|
35
|
+
for n, f in self.model_fields.items():
|
|
36
|
+
k = f.alias or n
|
|
37
|
+
val = serialized.get(k)
|
|
38
|
+
serialized.pop(k, None)
|
|
39
|
+
|
|
40
|
+
optional_nullable = k in optional_fields and k in nullable_fields
|
|
41
|
+
is_set = (
|
|
42
|
+
self.__pydantic_fields_set__.intersection({n})
|
|
43
|
+
or k in null_default_fields
|
|
44
|
+
) # pylint: disable=no-member
|
|
45
|
+
|
|
46
|
+
if val is not None and val != UNSET_SENTINEL:
|
|
47
|
+
m[k] = val
|
|
48
|
+
elif val != UNSET_SENTINEL and (
|
|
49
|
+
not k in optional_fields or (optional_nullable and is_set)
|
|
50
|
+
):
|
|
51
|
+
m[k] = val
|
|
52
|
+
|
|
53
|
+
return m
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"""Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
|
|
2
|
+
|
|
3
|
+
from __future__ import annotations
|
|
4
|
+
from .imageurl import ImageURL, ImageURLTypedDict
|
|
5
|
+
from mistralai_gcp.types import BaseModel
|
|
6
|
+
from typing import Literal, Optional, Union
|
|
7
|
+
from typing_extensions import NotRequired, TypeAliasType, TypedDict
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
ImageURLChunkImageURLTypedDict = TypeAliasType(
|
|
11
|
+
"ImageURLChunkImageURLTypedDict", Union[ImageURLTypedDict, str]
|
|
12
|
+
)
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
ImageURLChunkImageURL = TypeAliasType("ImageURLChunkImageURL", Union[ImageURL, str])
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
ImageURLChunkType = Literal["image_url"]
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
class ImageURLChunkTypedDict(TypedDict):
|
|
22
|
+
r"""{\"type\":\"image_url\",\"image_url\":{\"url\":\""""
|
|
23
|
+
|
|
24
|
+
image_url: ImageURLChunkImageURLTypedDict
|
|
25
|
+
type: NotRequired[ImageURLChunkType]
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
class ImageURLChunk(BaseModel):
|
|
29
|
+
r"""{\"type\":\"image_url\",\"image_url\":{\"url\":\""""
|
|
30
|
+
|
|
31
|
+
image_url: ImageURLChunkImageURL
|
|
32
|
+
|
|
33
|
+
type: Optional[ImageURLChunkType] = "image_url"
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
"""Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
|
|
2
|
+
|
|
3
|
+
from __future__ import annotations
|
|
4
|
+
from mistralai_gcp.types import (
|
|
5
|
+
BaseModel,
|
|
6
|
+
Nullable,
|
|
7
|
+
OptionalNullable,
|
|
8
|
+
UNSET,
|
|
9
|
+
UNSET_SENTINEL,
|
|
10
|
+
)
|
|
11
|
+
import pydantic
|
|
12
|
+
from pydantic import model_serializer
|
|
13
|
+
from typing import Any, Dict, Optional
|
|
14
|
+
from typing_extensions import Annotated, NotRequired, TypedDict
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
class JSONSchemaTypedDict(TypedDict):
|
|
18
|
+
name: str
|
|
19
|
+
schema_definition: Dict[str, Any]
|
|
20
|
+
description: NotRequired[Nullable[str]]
|
|
21
|
+
strict: NotRequired[bool]
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
class JSONSchema(BaseModel):
|
|
25
|
+
name: str
|
|
26
|
+
|
|
27
|
+
schema_definition: Annotated[Dict[str, Any], pydantic.Field(alias="schema")]
|
|
28
|
+
|
|
29
|
+
description: OptionalNullable[str] = UNSET
|
|
30
|
+
|
|
31
|
+
strict: Optional[bool] = None
|
|
32
|
+
|
|
33
|
+
@model_serializer(mode="wrap")
|
|
34
|
+
def serialize_model(self, handler):
|
|
35
|
+
optional_fields = ["description", "strict"]
|
|
36
|
+
nullable_fields = ["description"]
|
|
37
|
+
null_default_fields = []
|
|
38
|
+
|
|
39
|
+
serialized = handler(self)
|
|
40
|
+
|
|
41
|
+
m = {}
|
|
42
|
+
|
|
43
|
+
for n, f in self.model_fields.items():
|
|
44
|
+
k = f.alias or n
|
|
45
|
+
val = serialized.get(k)
|
|
46
|
+
serialized.pop(k, None)
|
|
47
|
+
|
|
48
|
+
optional_nullable = k in optional_fields and k in nullable_fields
|
|
49
|
+
is_set = (
|
|
50
|
+
self.__pydantic_fields_set__.intersection({n})
|
|
51
|
+
or k in null_default_fields
|
|
52
|
+
) # pylint: disable=no-member
|
|
53
|
+
|
|
54
|
+
if val is not None and val != UNSET_SENTINEL:
|
|
55
|
+
m[k] = val
|
|
56
|
+
elif val != UNSET_SENTINEL and (
|
|
57
|
+
not k in optional_fields or (optional_nullable and is_set)
|
|
58
|
+
):
|
|
59
|
+
m[k] = val
|
|
60
|
+
|
|
61
|
+
return m
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"""Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
|
|
2
|
+
|
|
3
|
+
from __future__ import annotations
|
|
4
|
+
from mistralai_gcp.types import BaseModel
|
|
5
|
+
from mistralai_gcp.utils import validate_const
|
|
6
|
+
import pydantic
|
|
7
|
+
from pydantic.functional_validators import AfterValidator
|
|
8
|
+
from typing import Literal, Optional
|
|
9
|
+
from typing_extensions import Annotated, NotRequired, TypedDict
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
class PredictionTypedDict(TypedDict):
|
|
13
|
+
type: Literal["content"]
|
|
14
|
+
content: NotRequired[str]
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
class Prediction(BaseModel):
|
|
18
|
+
TYPE: Annotated[
|
|
19
|
+
Annotated[
|
|
20
|
+
Optional[Literal["content"]], AfterValidator(validate_const("content"))
|
|
21
|
+
],
|
|
22
|
+
pydantic.Field(alias="type"),
|
|
23
|
+
] = "content"
|
|
24
|
+
|
|
25
|
+
content: Optional[str] = ""
|
|
@@ -1,8 +1,16 @@
|
|
|
1
1
|
"""Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
|
|
2
2
|
|
|
3
3
|
from __future__ import annotations
|
|
4
|
+
from .jsonschema import JSONSchema, JSONSchemaTypedDict
|
|
4
5
|
from .responseformats import ResponseFormats
|
|
5
|
-
from mistralai_gcp.types import
|
|
6
|
+
from mistralai_gcp.types import (
|
|
7
|
+
BaseModel,
|
|
8
|
+
Nullable,
|
|
9
|
+
OptionalNullable,
|
|
10
|
+
UNSET,
|
|
11
|
+
UNSET_SENTINEL,
|
|
12
|
+
)
|
|
13
|
+
from pydantic import model_serializer
|
|
6
14
|
from typing import Optional
|
|
7
15
|
from typing_extensions import NotRequired, TypedDict
|
|
8
16
|
|
|
@@ -10,8 +18,41 @@ from typing_extensions import NotRequired, TypedDict
|
|
|
10
18
|
class ResponseFormatTypedDict(TypedDict):
|
|
11
19
|
type: NotRequired[ResponseFormats]
|
|
12
20
|
r"""An object specifying the format that the model must output. Setting to `{ \"type\": \"json_object\" }` enables JSON mode, which guarantees the message the model generates is in JSON. When using JSON mode you MUST also instruct the model to produce JSON yourself with a system or a user message."""
|
|
21
|
+
json_schema: NotRequired[Nullable[JSONSchemaTypedDict]]
|
|
13
22
|
|
|
14
23
|
|
|
15
24
|
class ResponseFormat(BaseModel):
|
|
16
25
|
type: Optional[ResponseFormats] = None
|
|
17
26
|
r"""An object specifying the format that the model must output. Setting to `{ \"type\": \"json_object\" }` enables JSON mode, which guarantees the message the model generates is in JSON. When using JSON mode you MUST also instruct the model to produce JSON yourself with a system or a user message."""
|
|
27
|
+
|
|
28
|
+
json_schema: OptionalNullable[JSONSchema] = UNSET
|
|
29
|
+
|
|
30
|
+
@model_serializer(mode="wrap")
|
|
31
|
+
def serialize_model(self, handler):
|
|
32
|
+
optional_fields = ["type", "json_schema"]
|
|
33
|
+
nullable_fields = ["json_schema"]
|
|
34
|
+
null_default_fields = []
|
|
35
|
+
|
|
36
|
+
serialized = handler(self)
|
|
37
|
+
|
|
38
|
+
m = {}
|
|
39
|
+
|
|
40
|
+
for n, f in self.model_fields.items():
|
|
41
|
+
k = f.alias or n
|
|
42
|
+
val = serialized.get(k)
|
|
43
|
+
serialized.pop(k, None)
|
|
44
|
+
|
|
45
|
+
optional_nullable = k in optional_fields and k in nullable_fields
|
|
46
|
+
is_set = (
|
|
47
|
+
self.__pydantic_fields_set__.intersection({n})
|
|
48
|
+
or k in null_default_fields
|
|
49
|
+
) # pylint: disable=no-member
|
|
50
|
+
|
|
51
|
+
if val is not None and val != UNSET_SENTINEL:
|
|
52
|
+
m[k] = val
|
|
53
|
+
elif val != UNSET_SENTINEL and (
|
|
54
|
+
not k in optional_fields or (optional_nullable and is_set)
|
|
55
|
+
):
|
|
56
|
+
m[k] = val
|
|
57
|
+
|
|
58
|
+
return m
|
|
@@ -4,5 +4,5 @@ from __future__ import annotations
|
|
|
4
4
|
from typing import Literal
|
|
5
5
|
|
|
6
6
|
|
|
7
|
-
ResponseFormats = Literal["text", "json_object"]
|
|
7
|
+
ResponseFormats = Literal["text", "json_object", "json_schema"]
|
|
8
8
|
r"""An object specifying the format that the model must output. Setting to `{ \"type\": \"json_object\" }` enables JSON mode, which guarantees the message the model generates is in JSON. When using JSON mode you MUST also instruct the model to produce JSON yourself with a system or a user message."""
|
mistralai_gcp/models/toolcall.py
CHANGED
|
@@ -14,6 +14,7 @@ class ToolCallTypedDict(TypedDict):
|
|
|
14
14
|
function: FunctionCallTypedDict
|
|
15
15
|
id: NotRequired[str]
|
|
16
16
|
type: NotRequired[ToolTypes]
|
|
17
|
+
index: NotRequired[int]
|
|
17
18
|
|
|
18
19
|
|
|
19
20
|
class ToolCall(BaseModel):
|
|
@@ -24,3 +25,5 @@ class ToolCall(BaseModel):
|
|
|
24
25
|
type: Annotated[Optional[ToolTypes], PlainValidator(validate_open_enum(False))] = (
|
|
25
26
|
None
|
|
26
27
|
)
|
|
28
|
+
|
|
29
|
+
index: Optional[int] = 0
|