mistralai 0.4.2__py3-none-any.whl → 1.0.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.
Files changed (246) hide show
  1. mistralai/__init__.py +5 -0
  2. mistralai/_hooks/__init__.py +5 -0
  3. mistralai/_hooks/custom_user_agent.py +16 -0
  4. mistralai/_hooks/deprecation_warning.py +26 -0
  5. mistralai/_hooks/registration.py +17 -0
  6. mistralai/_hooks/sdkhooks.py +57 -0
  7. mistralai/_hooks/types.py +76 -0
  8. mistralai/agents.py +434 -0
  9. mistralai/async_client.py +5 -413
  10. mistralai/basesdk.py +253 -0
  11. mistralai/chat.py +470 -0
  12. mistralai/client.py +5 -414
  13. mistralai/embeddings.py +182 -0
  14. mistralai/files.py +600 -84
  15. mistralai/fim.py +438 -0
  16. mistralai/fine_tuning.py +16 -0
  17. mistralai/httpclient.py +78 -0
  18. mistralai/jobs.py +822 -150
  19. mistralai/models/__init__.py +82 -0
  20. mistralai/models/agentscompletionrequest.py +96 -0
  21. mistralai/models/agentscompletionstreamrequest.py +92 -0
  22. mistralai/models/archiveftmodelout.py +19 -0
  23. mistralai/models/assistantmessage.py +53 -0
  24. mistralai/models/chatcompletionchoice.py +22 -0
  25. mistralai/models/chatcompletionrequest.py +109 -0
  26. mistralai/models/chatcompletionresponse.py +27 -0
  27. mistralai/models/chatcompletionstreamrequest.py +107 -0
  28. mistralai/models/checkpointout.py +25 -0
  29. mistralai/models/completionchunk.py +27 -0
  30. mistralai/models/completionevent.py +15 -0
  31. mistralai/models/completionresponsestreamchoice.py +48 -0
  32. mistralai/models/contentchunk.py +17 -0
  33. mistralai/models/delete_model_v1_models_model_id_deleteop.py +18 -0
  34. mistralai/models/deletefileout.py +24 -0
  35. mistralai/models/deletemodelout.py +25 -0
  36. mistralai/models/deltamessage.py +47 -0
  37. mistralai/models/detailedjobout.py +91 -0
  38. mistralai/models/embeddingrequest.py +61 -0
  39. mistralai/models/embeddingresponse.py +24 -0
  40. mistralai/models/embeddingresponsedata.py +19 -0
  41. mistralai/models/eventout.py +50 -0
  42. mistralai/models/files_api_routes_delete_fileop.py +16 -0
  43. mistralai/models/files_api_routes_retrieve_fileop.py +16 -0
  44. mistralai/models/files_api_routes_upload_fileop.py +51 -0
  45. mistralai/models/fileschema.py +71 -0
  46. mistralai/models/fimcompletionrequest.py +94 -0
  47. mistralai/models/fimcompletionresponse.py +27 -0
  48. mistralai/models/fimcompletionstreamrequest.py +92 -0
  49. mistralai/models/finetuneablemodel.py +8 -0
  50. mistralai/models/ftmodelcapabilitiesout.py +21 -0
  51. mistralai/models/ftmodelout.py +65 -0
  52. mistralai/models/function.py +19 -0
  53. mistralai/models/functioncall.py +22 -0
  54. mistralai/models/githubrepositoryin.py +52 -0
  55. mistralai/models/githubrepositoryout.py +52 -0
  56. mistralai/models/httpvalidationerror.py +23 -0
  57. mistralai/models/jobin.py +73 -0
  58. mistralai/models/jobmetadataout.py +54 -0
  59. mistralai/models/jobout.py +107 -0
  60. mistralai/models/jobs_api_routes_fine_tuning_archive_fine_tuned_modelop.py +18 -0
  61. mistralai/models/jobs_api_routes_fine_tuning_cancel_fine_tuning_jobop.py +18 -0
  62. mistralai/models/jobs_api_routes_fine_tuning_create_fine_tuning_jobop.py +15 -0
  63. mistralai/models/jobs_api_routes_fine_tuning_get_fine_tuning_jobop.py +18 -0
  64. mistralai/models/jobs_api_routes_fine_tuning_get_fine_tuning_jobsop.py +81 -0
  65. mistralai/models/jobs_api_routes_fine_tuning_start_fine_tuning_jobop.py +16 -0
  66. mistralai/models/jobs_api_routes_fine_tuning_unarchive_fine_tuned_modelop.py +18 -0
  67. mistralai/models/jobs_api_routes_fine_tuning_update_fine_tuned_modelop.py +21 -0
  68. mistralai/models/jobsout.py +20 -0
  69. mistralai/models/legacyjobmetadataout.py +80 -0
  70. mistralai/models/listfilesout.py +17 -0
  71. mistralai/models/metricout.py +50 -0
  72. mistralai/models/modelcapabilities.py +21 -0
  73. mistralai/models/modelcard.py +66 -0
  74. mistralai/models/modellist.py +18 -0
  75. mistralai/models/responseformat.py +18 -0
  76. mistralai/models/retrieve_model_v1_models_model_id_getop.py +18 -0
  77. mistralai/models/retrievefileout.py +71 -0
  78. mistralai/models/sampletype.py +7 -0
  79. mistralai/models/sdkerror.py +22 -0
  80. mistralai/models/security.py +16 -0
  81. mistralai/models/source.py +7 -0
  82. mistralai/models/systemmessage.py +26 -0
  83. mistralai/models/textchunk.py +17 -0
  84. mistralai/models/tool.py +18 -0
  85. mistralai/models/toolcall.py +20 -0
  86. mistralai/models/toolmessage.py +50 -0
  87. mistralai/models/trainingfile.py +17 -0
  88. mistralai/models/trainingparameters.py +48 -0
  89. mistralai/models/trainingparametersin.py +56 -0
  90. mistralai/models/unarchiveftmodelout.py +19 -0
  91. mistralai/models/updateftmodelin.py +44 -0
  92. mistralai/models/uploadfileout.py +71 -0
  93. mistralai/models/usageinfo.py +18 -0
  94. mistralai/models/usermessage.py +26 -0
  95. mistralai/models/validationerror.py +24 -0
  96. mistralai/models/wandbintegration.py +56 -0
  97. mistralai/models/wandbintegrationout.py +52 -0
  98. mistralai/models_.py +928 -0
  99. mistralai/py.typed +1 -0
  100. mistralai/sdk.py +119 -0
  101. mistralai/sdkconfiguration.py +54 -0
  102. mistralai/types/__init__.py +21 -0
  103. mistralai/types/basemodel.py +39 -0
  104. mistralai/utils/__init__.py +86 -0
  105. mistralai/utils/annotations.py +19 -0
  106. mistralai/utils/enums.py +34 -0
  107. mistralai/utils/eventstreaming.py +178 -0
  108. mistralai/utils/forms.py +207 -0
  109. mistralai/utils/headers.py +136 -0
  110. mistralai/utils/logger.py +16 -0
  111. mistralai/utils/metadata.py +118 -0
  112. mistralai/utils/queryparams.py +203 -0
  113. mistralai/utils/requestbodies.py +66 -0
  114. mistralai/utils/retries.py +216 -0
  115. mistralai/utils/security.py +185 -0
  116. mistralai/utils/serializers.py +181 -0
  117. mistralai/utils/url.py +150 -0
  118. mistralai/utils/values.py +128 -0
  119. {mistralai-0.4.2.dist-info → mistralai-1.0.0.dist-info}/LICENSE +1 -1
  120. mistralai-1.0.0.dist-info/METADATA +695 -0
  121. mistralai-1.0.0.dist-info/RECORD +235 -0
  122. mistralai_azure/__init__.py +5 -0
  123. mistralai_azure/_hooks/__init__.py +5 -0
  124. mistralai_azure/_hooks/custom_user_agent.py +16 -0
  125. mistralai_azure/_hooks/registration.py +15 -0
  126. mistralai_azure/_hooks/sdkhooks.py +57 -0
  127. mistralai_azure/_hooks/types.py +76 -0
  128. mistralai_azure/basesdk.py +253 -0
  129. mistralai_azure/chat.py +470 -0
  130. mistralai_azure/httpclient.py +78 -0
  131. mistralai_azure/models/__init__.py +28 -0
  132. mistralai_azure/models/assistantmessage.py +53 -0
  133. mistralai_azure/models/chatcompletionchoice.py +22 -0
  134. mistralai_azure/models/chatcompletionrequest.py +109 -0
  135. mistralai_azure/models/chatcompletionresponse.py +27 -0
  136. mistralai_azure/models/chatcompletionstreamrequest.py +107 -0
  137. mistralai_azure/models/completionchunk.py +27 -0
  138. mistralai_azure/models/completionevent.py +15 -0
  139. mistralai_azure/models/completionresponsestreamchoice.py +48 -0
  140. mistralai_azure/models/contentchunk.py +17 -0
  141. mistralai_azure/models/deltamessage.py +47 -0
  142. mistralai_azure/models/function.py +19 -0
  143. mistralai_azure/models/functioncall.py +22 -0
  144. mistralai_azure/models/httpvalidationerror.py +23 -0
  145. mistralai_azure/models/responseformat.py +18 -0
  146. mistralai_azure/models/sdkerror.py +22 -0
  147. mistralai_azure/models/security.py +16 -0
  148. mistralai_azure/models/systemmessage.py +26 -0
  149. mistralai_azure/models/textchunk.py +17 -0
  150. mistralai_azure/models/tool.py +18 -0
  151. mistralai_azure/models/toolcall.py +20 -0
  152. mistralai_azure/models/toolmessage.py +50 -0
  153. mistralai_azure/models/usageinfo.py +18 -0
  154. mistralai_azure/models/usermessage.py +26 -0
  155. mistralai_azure/models/validationerror.py +24 -0
  156. mistralai_azure/py.typed +1 -0
  157. mistralai_azure/sdk.py +107 -0
  158. mistralai_azure/sdkconfiguration.py +54 -0
  159. mistralai_azure/types/__init__.py +21 -0
  160. mistralai_azure/types/basemodel.py +39 -0
  161. mistralai_azure/utils/__init__.py +84 -0
  162. mistralai_azure/utils/annotations.py +19 -0
  163. mistralai_azure/utils/enums.py +34 -0
  164. mistralai_azure/utils/eventstreaming.py +178 -0
  165. mistralai_azure/utils/forms.py +207 -0
  166. mistralai_azure/utils/headers.py +136 -0
  167. mistralai_azure/utils/logger.py +16 -0
  168. mistralai_azure/utils/metadata.py +118 -0
  169. mistralai_azure/utils/queryparams.py +203 -0
  170. mistralai_azure/utils/requestbodies.py +66 -0
  171. mistralai_azure/utils/retries.py +216 -0
  172. mistralai_azure/utils/security.py +168 -0
  173. mistralai_azure/utils/serializers.py +181 -0
  174. mistralai_azure/utils/url.py +150 -0
  175. mistralai_azure/utils/values.py +128 -0
  176. mistralai_gcp/__init__.py +5 -0
  177. mistralai_gcp/_hooks/__init__.py +5 -0
  178. mistralai_gcp/_hooks/custom_user_agent.py +16 -0
  179. mistralai_gcp/_hooks/registration.py +15 -0
  180. mistralai_gcp/_hooks/sdkhooks.py +57 -0
  181. mistralai_gcp/_hooks/types.py +76 -0
  182. mistralai_gcp/basesdk.py +253 -0
  183. mistralai_gcp/chat.py +458 -0
  184. mistralai_gcp/fim.py +438 -0
  185. mistralai_gcp/httpclient.py +78 -0
  186. mistralai_gcp/models/__init__.py +31 -0
  187. mistralai_gcp/models/assistantmessage.py +53 -0
  188. mistralai_gcp/models/chatcompletionchoice.py +22 -0
  189. mistralai_gcp/models/chatcompletionrequest.py +105 -0
  190. mistralai_gcp/models/chatcompletionresponse.py +27 -0
  191. mistralai_gcp/models/chatcompletionstreamrequest.py +103 -0
  192. mistralai_gcp/models/completionchunk.py +27 -0
  193. mistralai_gcp/models/completionevent.py +15 -0
  194. mistralai_gcp/models/completionresponsestreamchoice.py +48 -0
  195. mistralai_gcp/models/contentchunk.py +17 -0
  196. mistralai_gcp/models/deltamessage.py +47 -0
  197. mistralai_gcp/models/fimcompletionrequest.py +94 -0
  198. mistralai_gcp/models/fimcompletionresponse.py +27 -0
  199. mistralai_gcp/models/fimcompletionstreamrequest.py +92 -0
  200. mistralai_gcp/models/function.py +19 -0
  201. mistralai_gcp/models/functioncall.py +22 -0
  202. mistralai_gcp/models/httpvalidationerror.py +23 -0
  203. mistralai_gcp/models/responseformat.py +18 -0
  204. mistralai_gcp/models/sdkerror.py +22 -0
  205. mistralai_gcp/models/security.py +16 -0
  206. mistralai_gcp/models/systemmessage.py +26 -0
  207. mistralai_gcp/models/textchunk.py +17 -0
  208. mistralai_gcp/models/tool.py +18 -0
  209. mistralai_gcp/models/toolcall.py +20 -0
  210. mistralai_gcp/models/toolmessage.py +50 -0
  211. mistralai_gcp/models/usageinfo.py +18 -0
  212. mistralai_gcp/models/usermessage.py +26 -0
  213. mistralai_gcp/models/validationerror.py +24 -0
  214. mistralai_gcp/py.typed +1 -0
  215. mistralai_gcp/sdk.py +174 -0
  216. mistralai_gcp/sdkconfiguration.py +54 -0
  217. mistralai_gcp/types/__init__.py +21 -0
  218. mistralai_gcp/types/basemodel.py +39 -0
  219. mistralai_gcp/utils/__init__.py +84 -0
  220. mistralai_gcp/utils/annotations.py +19 -0
  221. mistralai_gcp/utils/enums.py +34 -0
  222. mistralai_gcp/utils/eventstreaming.py +178 -0
  223. mistralai_gcp/utils/forms.py +207 -0
  224. mistralai_gcp/utils/headers.py +136 -0
  225. mistralai_gcp/utils/logger.py +16 -0
  226. mistralai_gcp/utils/metadata.py +118 -0
  227. mistralai_gcp/utils/queryparams.py +203 -0
  228. mistralai_gcp/utils/requestbodies.py +66 -0
  229. mistralai_gcp/utils/retries.py +216 -0
  230. mistralai_gcp/utils/security.py +168 -0
  231. mistralai_gcp/utils/serializers.py +181 -0
  232. mistralai_gcp/utils/url.py +150 -0
  233. mistralai_gcp/utils/values.py +128 -0
  234. py.typed +1 -0
  235. mistralai/client_base.py +0 -211
  236. mistralai/constants.py +0 -5
  237. mistralai/exceptions.py +0 -54
  238. mistralai/models/chat_completion.py +0 -93
  239. mistralai/models/common.py +0 -9
  240. mistralai/models/embeddings.py +0 -19
  241. mistralai/models/files.py +0 -23
  242. mistralai/models/jobs.py +0 -100
  243. mistralai/models/models.py +0 -39
  244. mistralai-0.4.2.dist-info/METADATA +0 -82
  245. mistralai-0.4.2.dist-info/RECORD +0 -20
  246. {mistralai-0.4.2.dist-info → mistralai-1.0.0.dist-info}/WHEEL +0 -0
@@ -0,0 +1,23 @@
1
+ """Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
2
+
3
+ from __future__ import annotations
4
+ from .validationerror import ValidationError
5
+ from mistralai_gcp import utils
6
+ from mistralai_gcp.types import BaseModel
7
+ from typing import List, Optional
8
+
9
+ class HTTPValidationErrorData(BaseModel):
10
+ detail: Optional[List[ValidationError]] = None
11
+
12
+
13
+
14
+ class HTTPValidationError(Exception):
15
+ r"""Validation Error"""
16
+ data: HTTPValidationErrorData
17
+
18
+ def __init__(self, data: HTTPValidationErrorData):
19
+ self.data = data
20
+
21
+ def __str__(self) -> str:
22
+ return utils.marshal_json(self.data, HTTPValidationErrorData)
23
+
@@ -0,0 +1,18 @@
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 typing import Literal, Optional, TypedDict
6
+ from typing_extensions import NotRequired
7
+
8
+
9
+ ResponseFormats = Literal["text", "json_object"]
10
+ 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."""
11
+
12
+ class ResponseFormatTypedDict(TypedDict):
13
+ type: NotRequired[ResponseFormats]
14
+
15
+
16
+ class ResponseFormat(BaseModel):
17
+ type: Optional[ResponseFormats] = "text"
18
+
@@ -0,0 +1,22 @@
1
+ """Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
2
+
3
+ from dataclasses import dataclass
4
+ from typing import Optional
5
+ import httpx
6
+
7
+
8
+ @dataclass
9
+ class SDKError(Exception):
10
+ """Represents an error returned by the API."""
11
+
12
+ message: str
13
+ status_code: int = -1
14
+ body: str = ""
15
+ raw_response: Optional[httpx.Response] = None
16
+
17
+ def __str__(self):
18
+ body = ""
19
+ if len(self.body) > 0:
20
+ body = f"\n{self.body}"
21
+
22
+ return f"{self.message}: Status {self.status_code}{body}"
@@ -0,0 +1,16 @@
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 FieldMetadata, SecurityMetadata
6
+ from typing import TypedDict
7
+ from typing_extensions import Annotated
8
+
9
+
10
+ class SecurityTypedDict(TypedDict):
11
+ api_key: str
12
+
13
+
14
+ class Security(BaseModel):
15
+ api_key: Annotated[str, FieldMetadata(security=SecurityMetadata(scheme=True, scheme_type="http", sub_type="bearer", field_name="Authorization"))]
16
+
@@ -0,0 +1,26 @@
1
+ """Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
2
+
3
+ from __future__ import annotations
4
+ from .contentchunk import ContentChunk, ContentChunkTypedDict
5
+ from mistralai_gcp.types import BaseModel
6
+ from typing import List, Literal, Optional, TypedDict, Union
7
+ from typing_extensions import NotRequired
8
+
9
+
10
+ Role = Literal["system"]
11
+
12
+ class SystemMessageTypedDict(TypedDict):
13
+ content: ContentTypedDict
14
+ role: NotRequired[Role]
15
+
16
+
17
+ class SystemMessage(BaseModel):
18
+ content: Content
19
+ role: Optional[Role] = "system"
20
+
21
+
22
+ ContentTypedDict = Union[str, List[ContentChunkTypedDict]]
23
+
24
+
25
+ Content = Union[str, List[ContentChunk]]
26
+
@@ -0,0 +1,17 @@
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
+ import pydantic
6
+ from typing import Final, Optional, TypedDict
7
+ from typing_extensions import Annotated
8
+
9
+
10
+ class TextChunkTypedDict(TypedDict):
11
+ text: str
12
+
13
+
14
+ class TextChunk(BaseModel):
15
+ text: str
16
+ TYPE: Annotated[Final[Optional[str]], pydantic.Field(alias="type")] = "text" # type: ignore
17
+
@@ -0,0 +1,18 @@
1
+ """Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
2
+
3
+ from __future__ import annotations
4
+ from .function import Function, FunctionTypedDict
5
+ from mistralai_gcp.types import BaseModel
6
+ import pydantic
7
+ from typing import Final, Optional, TypedDict
8
+ from typing_extensions import Annotated
9
+
10
+
11
+ class ToolTypedDict(TypedDict):
12
+ function: FunctionTypedDict
13
+
14
+
15
+ class Tool(BaseModel):
16
+ function: Function
17
+ TYPE: Annotated[Final[Optional[str]], pydantic.Field(alias="type")] = "function" # type: ignore
18
+
@@ -0,0 +1,20 @@
1
+ """Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
2
+
3
+ from __future__ import annotations
4
+ from .functioncall import FunctionCall, FunctionCallTypedDict
5
+ from mistralai_gcp.types import BaseModel
6
+ import pydantic
7
+ from typing import Final, Optional, TypedDict
8
+ from typing_extensions import Annotated, NotRequired
9
+
10
+
11
+ class ToolCallTypedDict(TypedDict):
12
+ function: FunctionCallTypedDict
13
+ id: NotRequired[str]
14
+
15
+
16
+ class ToolCall(BaseModel):
17
+ function: FunctionCall
18
+ id: Optional[str] = "null"
19
+ TYPE: Annotated[Final[Optional[str]], pydantic.Field(alias="type")] = "function" # type: ignore
20
+
@@ -0,0 +1,50 @@
1
+ """Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
2
+
3
+ from __future__ import annotations
4
+ from mistralai_gcp.types import BaseModel, Nullable, OptionalNullable, UNSET, UNSET_SENTINEL
5
+ from pydantic import model_serializer
6
+ from typing import Literal, Optional, TypedDict
7
+ from typing_extensions import NotRequired
8
+
9
+
10
+ ToolMessageRole = Literal["tool"]
11
+
12
+ class ToolMessageTypedDict(TypedDict):
13
+ content: str
14
+ tool_call_id: NotRequired[Nullable[str]]
15
+ name: NotRequired[Nullable[str]]
16
+ role: NotRequired[ToolMessageRole]
17
+
18
+
19
+ class ToolMessage(BaseModel):
20
+ content: str
21
+ tool_call_id: OptionalNullable[str] = UNSET
22
+ name: OptionalNullable[str] = UNSET
23
+ role: Optional[ToolMessageRole] = "tool"
24
+
25
+ @model_serializer(mode="wrap")
26
+ def serialize_model(self, handler):
27
+ optional_fields = ["tool_call_id", "name", "role"]
28
+ nullable_fields = ["tool_call_id", "name"]
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
+
39
+ optional_nullable = k in optional_fields and k in nullable_fields
40
+ is_set = (self.__pydantic_fields_set__.intersection({n}) or k in null_default_fields) # pylint: disable=no-member
41
+
42
+ if val is not None and val != UNSET_SENTINEL:
43
+ m[k] = val
44
+ elif val != UNSET_SENTINEL and (
45
+ not k in optional_fields or (optional_nullable and is_set)
46
+ ):
47
+ m[k] = val
48
+
49
+ return m
50
+
@@ -0,0 +1,18 @@
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 typing import TypedDict
6
+
7
+
8
+ class UsageInfoTypedDict(TypedDict):
9
+ prompt_tokens: int
10
+ completion_tokens: int
11
+ total_tokens: int
12
+
13
+
14
+ class UsageInfo(BaseModel):
15
+ prompt_tokens: int
16
+ completion_tokens: int
17
+ total_tokens: int
18
+
@@ -0,0 +1,26 @@
1
+ """Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
2
+
3
+ from __future__ import annotations
4
+ from .textchunk import TextChunk, TextChunkTypedDict
5
+ from mistralai_gcp.types import BaseModel
6
+ from typing import List, Literal, Optional, TypedDict, Union
7
+ from typing_extensions import NotRequired
8
+
9
+
10
+ UserMessageRole = Literal["user"]
11
+
12
+ class UserMessageTypedDict(TypedDict):
13
+ content: UserMessageContentTypedDict
14
+ role: NotRequired[UserMessageRole]
15
+
16
+
17
+ class UserMessage(BaseModel):
18
+ content: UserMessageContent
19
+ role: Optional[UserMessageRole] = "user"
20
+
21
+
22
+ UserMessageContentTypedDict = Union[str, List[TextChunkTypedDict]]
23
+
24
+
25
+ UserMessageContent = Union[str, List[TextChunk]]
26
+
@@ -0,0 +1,24 @@
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 typing import List, TypedDict, Union
6
+
7
+
8
+ class ValidationErrorTypedDict(TypedDict):
9
+ loc: List[LocTypedDict]
10
+ msg: str
11
+ type: str
12
+
13
+
14
+ class ValidationError(BaseModel):
15
+ loc: List[Loc]
16
+ msg: str
17
+ type: str
18
+
19
+
20
+ LocTypedDict = Union[str, int]
21
+
22
+
23
+ Loc = Union[str, int]
24
+
mistralai_gcp/py.typed ADDED
@@ -0,0 +1 @@
1
+ # Marker file for PEP 561. The package enables type hints.
mistralai_gcp/sdk.py ADDED
@@ -0,0 +1,174 @@
1
+ """Code generated by Speakeasy (https://speakeasyapi.dev). DO NOT EDIT."""
2
+
3
+ import json
4
+ from typing import Optional, Union
5
+
6
+ import google.auth
7
+ import google.auth.credentials
8
+ import google.auth.transport
9
+ import google.auth.transport.requests
10
+ import httpx
11
+ from mistralai_gcp import models
12
+ from mistralai_gcp._hooks import BeforeRequestHook, SDKHooks
13
+ from mistralai_gcp.chat import Chat
14
+ from mistralai_gcp.fim import Fim
15
+ from mistralai_gcp.types import Nullable
16
+
17
+ from .basesdk import BaseSDK
18
+ from .httpclient import AsyncHttpClient, HttpClient
19
+ from .sdkconfiguration import SDKConfiguration
20
+ from .utils.logger import Logger, NoOpLogger
21
+ from .utils.retries import RetryConfig
22
+
23
+
24
+ class MistralGoogleCloud(BaseSDK):
25
+ r"""Mistral AI API: Our Chat Completion and Embeddings APIs specification. Create your account on [La Plateforme](https://console.mistral.ai) to get access and read the [docs](https://docs.mistral.ai) to learn how to use it."""
26
+
27
+ chat: Chat
28
+ fim: Fim
29
+ r"""Chat Completion API"""
30
+
31
+ def __init__(
32
+ self,
33
+ region: str = "europe-west4",
34
+ project_id: Optional[str] = None,
35
+ client: Optional[HttpClient] = None,
36
+ async_client: Optional[AsyncHttpClient] = None,
37
+ retry_config: Optional[Nullable[RetryConfig]] = None,
38
+ debug_logger: Optional[Logger] = None,
39
+ ) -> None:
40
+ r"""Instantiates the SDK configuring it with the provided parameters.
41
+
42
+ :param region: The Google Cloud region to use for all methods
43
+ :param project_id: The project ID to use for all methods
44
+ :param client: The HTTP client to use for all synchronous methods
45
+ :param async_client: The Async HTTP client to use for all asynchronous methods
46
+ :param retry_config: The retry configuration to use for all supported methods
47
+ """
48
+
49
+ credentials, loaded_project_id = google.auth.default(
50
+ scopes=["https://www.googleapis.com/auth/cloud-platform"],
51
+ )
52
+
53
+ if not isinstance(credentials, google.auth.credentials.Credentials):
54
+ raise models.SDKError(
55
+ "credentials must be an instance of google.auth.credentials.Credentials"
56
+ )
57
+
58
+ project_id = project_id or loaded_project_id
59
+ if project_id is None:
60
+ raise models.SDKError("project_id must be provided")
61
+
62
+ def auth_token() -> str:
63
+ if credentials.expired:
64
+ credentials.refresh(google.auth.transport.requests.Request())
65
+ token = credentials.token
66
+ if not token:
67
+ raise models.SDKError("Failed to get token from credentials")
68
+ return token
69
+
70
+ if client is None:
71
+ client = httpx.Client()
72
+
73
+ assert issubclass(
74
+ type(client), HttpClient
75
+ ), "The provided client must implement the HttpClient protocol."
76
+
77
+ if async_client is None:
78
+ async_client = httpx.AsyncClient()
79
+
80
+ if debug_logger is None:
81
+ debug_logger = NoOpLogger()
82
+
83
+ assert issubclass(
84
+ type(async_client), AsyncHttpClient
85
+ ), "The provided async_client must implement the AsyncHttpClient protocol."
86
+
87
+ security = None
88
+ if callable(auth_token):
89
+ security = lambda: models.Security( # pylint: disable=unnecessary-lambda-assignment
90
+ api_key=auth_token()
91
+ )
92
+ else:
93
+ security = models.Security(api_key=auth_token)
94
+
95
+ BaseSDK.__init__(
96
+ self,
97
+ SDKConfiguration(
98
+ client=client,
99
+ async_client=async_client,
100
+ security=security,
101
+ server_url=f"https://{region}-aiplatform.googleapis.com",
102
+ server=None,
103
+ retry_config=retry_config,
104
+ debug_logger=debug_logger,
105
+ ),
106
+ )
107
+
108
+ hooks = SDKHooks()
109
+
110
+ hook = GoogleCloudBeforeRequestHook(region, project_id)
111
+ hooks.register_before_request_hook(hook)
112
+
113
+ current_server_url, *_ = self.sdk_configuration.get_server_details()
114
+ server_url, self.sdk_configuration.client = hooks.sdk_init(
115
+ current_server_url, self.sdk_configuration.client
116
+ )
117
+ if current_server_url != server_url:
118
+ self.sdk_configuration.server_url = server_url
119
+
120
+ # pylint: disable=protected-access
121
+ self.sdk_configuration.__dict__["_hooks"] = hooks
122
+
123
+ self._init_sdks()
124
+
125
+ def _init_sdks(self):
126
+ self.chat = Chat(self.sdk_configuration)
127
+ self.fim = Fim(self.sdk_configuration)
128
+
129
+
130
+ class GoogleCloudBeforeRequestHook(BeforeRequestHook):
131
+
132
+ def __init__(self, region: str, project_id: str):
133
+ self.region = region
134
+ self.project_id = project_id
135
+
136
+ def before_request(
137
+ self, hook_ctx, request: httpx.Request
138
+ ) -> Union[httpx.Request, Exception]:
139
+ # The goal of this function is to template in the region, project, model, and model_version into the URL path
140
+ # We do this here so that the API remains more user-friendly
141
+ model = None
142
+ model_version = None
143
+ new_content = None
144
+ if request.content:
145
+ parsed = json.loads(request.content.decode("utf-8"))
146
+ model_raw = parsed.get("model")
147
+ model = "-".join(model_raw.split("-")[:-1])
148
+ model_version = model_raw.split("-")[-1]
149
+ parsed["model"] = model
150
+ new_content = json.dumps(parsed).encode("utf-8")
151
+
152
+ if model == "":
153
+ raise models.SDKError("model must be provided")
154
+
155
+ if model_version is None:
156
+ raise models.SDKError("model_version must be provided")
157
+
158
+ stream = "streamRawPredict" in request.url.path
159
+ specifier = "streamRawPredict" if stream else "rawPredict"
160
+ url = f"/v1/projects/{self.project_id}/locations/{self.region}/publishers/mistralai/models/{model}@{model_version}:{specifier}"
161
+
162
+ headers = dict(request.headers)
163
+ # Delete content-length header as it will need to be recalculated
164
+ headers.pop("content-length", None)
165
+
166
+ next_request = httpx.Request(
167
+ method=request.method,
168
+ url=request.url.copy_with(path=url),
169
+ headers=headers,
170
+ content=new_content,
171
+ stream=None,
172
+ )
173
+
174
+ return next_request
@@ -0,0 +1,54 @@
1
+ """Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
2
+
3
+
4
+ from ._hooks import SDKHooks
5
+ from .httpclient import AsyncHttpClient, HttpClient
6
+ from .utils import Logger, RetryConfig, remove_suffix
7
+ from dataclasses import dataclass
8
+ from mistralai_gcp import models
9
+ from mistralai_gcp.types import OptionalNullable, UNSET
10
+ from pydantic import Field
11
+ from typing import Callable, Dict, Optional, Tuple, Union
12
+
13
+
14
+ SERVER_PROD = "prod"
15
+ r"""Production server"""
16
+ SERVERS = {
17
+ SERVER_PROD: "https://api.mistral.ai",
18
+ }
19
+ """Contains the list of servers available to the SDK"""
20
+
21
+
22
+ @dataclass
23
+ class SDKConfiguration:
24
+ client: HttpClient
25
+ async_client: AsyncHttpClient
26
+ debug_logger: Logger
27
+ security: Optional[Union[models.Security,Callable[[], models.Security]]] = None
28
+ server_url: Optional[str] = ""
29
+ server: Optional[str] = ""
30
+ language: str = "python"
31
+ openapi_doc_version: str = "0.0.2"
32
+ sdk_version: str = "1.0.0-rc.2"
33
+ gen_version: str = "2.388.1"
34
+ user_agent: str = "speakeasy-sdk/python 1.0.0-rc.2 2.388.1 0.0.2 mistralai-gcp"
35
+ retry_config: OptionalNullable[RetryConfig] = Field(default_factory=lambda: UNSET)
36
+ timeout_ms: Optional[int] = None
37
+
38
+ def __post_init__(self):
39
+ self._hooks = SDKHooks()
40
+
41
+ def get_server_details(self) -> Tuple[str, Dict[str, str]]:
42
+ if self.server_url is not None and self.server_url:
43
+ return remove_suffix(self.server_url, "/"), {}
44
+ if not self.server:
45
+ self.server = SERVER_PROD
46
+
47
+ if self.server not in SERVERS:
48
+ raise ValueError(f"Invalid server \"{self.server}\"")
49
+
50
+ return SERVERS[self.server], {}
51
+
52
+
53
+ def get_hooks(self) -> SDKHooks:
54
+ return self._hooks
@@ -0,0 +1,21 @@
1
+ """Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
2
+
3
+ from .basemodel import (
4
+ BaseModel,
5
+ Nullable,
6
+ OptionalNullable,
7
+ UnrecognizedInt,
8
+ UnrecognizedStr,
9
+ UNSET,
10
+ UNSET_SENTINEL,
11
+ )
12
+
13
+ __all__ = [
14
+ "BaseModel",
15
+ "Nullable",
16
+ "OptionalNullable",
17
+ "UnrecognizedInt",
18
+ "UnrecognizedStr",
19
+ "UNSET",
20
+ "UNSET_SENTINEL",
21
+ ]
@@ -0,0 +1,39 @@
1
+ """Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
2
+
3
+ from pydantic import ConfigDict, model_serializer
4
+ from pydantic import BaseModel as PydanticBaseModel
5
+ from typing import TYPE_CHECKING, Literal, Optional, TypeVar, Union, NewType
6
+ from typing_extensions import TypeAliasType, TypeAlias
7
+
8
+
9
+ class BaseModel(PydanticBaseModel):
10
+ model_config = ConfigDict(
11
+ populate_by_name=True, arbitrary_types_allowed=True, protected_namespaces=()
12
+ )
13
+
14
+
15
+ class Unset(BaseModel):
16
+ @model_serializer(mode="plain")
17
+ def serialize_model(self):
18
+ return UNSET_SENTINEL
19
+
20
+ def __bool__(self) -> Literal[False]:
21
+ return False
22
+
23
+
24
+ UNSET = Unset()
25
+ UNSET_SENTINEL = "~?~unset~?~sentinel~?~"
26
+
27
+
28
+ T = TypeVar("T")
29
+ if TYPE_CHECKING:
30
+ Nullable: TypeAlias = Union[T, None]
31
+ OptionalNullable: TypeAlias = Union[Optional[Nullable[T]], Unset]
32
+ else:
33
+ Nullable = TypeAliasType("Nullable", Union[T, None], type_params=(T,))
34
+ OptionalNullable = TypeAliasType(
35
+ "OptionalNullable", Union[Optional[Nullable[T]], Unset], type_params=(T,)
36
+ )
37
+
38
+ UnrecognizedInt = NewType("UnrecognizedInt", int)
39
+ UnrecognizedStr = NewType("UnrecognizedStr", str)
@@ -0,0 +1,84 @@
1
+ """Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
2
+
3
+ from .annotations import get_discriminator
4
+ from .enums import OpenEnumMeta
5
+ from .headers import get_headers, get_response_headers
6
+ from .metadata import (
7
+ FieldMetadata,
8
+ find_metadata,
9
+ FormMetadata,
10
+ HeaderMetadata,
11
+ MultipartFormMetadata,
12
+ PathParamMetadata,
13
+ QueryParamMetadata,
14
+ RequestMetadata,
15
+ SecurityMetadata,
16
+ )
17
+ from .queryparams import get_query_params
18
+ from .retries import BackoffStrategy, Retries, retry, retry_async, RetryConfig
19
+ from .requestbodies import serialize_request_body, SerializedRequestBody
20
+ from .security import get_security
21
+ from .serializers import (
22
+ get_pydantic_model,
23
+ marshal_json,
24
+ unmarshal,
25
+ unmarshal_json,
26
+ serialize_decimal,
27
+ serialize_float,
28
+ serialize_int,
29
+ stream_to_text,
30
+ validate_decimal,
31
+ validate_float,
32
+ validate_int,
33
+ validate_open_enum,
34
+ )
35
+ from .url import generate_url, template_url, remove_suffix
36
+ from .values import get_global_from_env, match_content_type, match_status_codes, match_response
37
+ from .logger import Logger, get_body_content, NoOpLogger
38
+
39
+ __all__ = [
40
+ "BackoffStrategy",
41
+ "FieldMetadata",
42
+ "find_metadata",
43
+ "FormMetadata",
44
+ "generate_url",
45
+ "get_body_content",
46
+ "get_discriminator",
47
+ "get_global_from_env",
48
+ "get_headers",
49
+ "get_pydantic_model",
50
+ "get_query_params",
51
+ "get_response_headers",
52
+ "get_security",
53
+ "HeaderMetadata",
54
+ "Logger",
55
+ "marshal_json",
56
+ "match_content_type",
57
+ "match_status_codes",
58
+ "match_response",
59
+ "MultipartFormMetadata",
60
+ "NoOpLogger",
61
+ "OpenEnumMeta",
62
+ "PathParamMetadata",
63
+ "QueryParamMetadata",
64
+ "remove_suffix",
65
+ "Retries",
66
+ "retry",
67
+ "retry_async",
68
+ "RetryConfig",
69
+ "RequestMetadata",
70
+ "SecurityMetadata",
71
+ "serialize_decimal",
72
+ "serialize_float",
73
+ "serialize_int",
74
+ "serialize_request_body",
75
+ "SerializedRequestBody",
76
+ "stream_to_text",
77
+ "template_url",
78
+ "unmarshal",
79
+ "unmarshal_json",
80
+ "validate_decimal",
81
+ "validate_float",
82
+ "validate_int",
83
+ "validate_open_enum",
84
+ ]