mistralai 1.0.2__py3-none-any.whl → 1.1.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 (199) hide show
  1. mistralai/_hooks/sdkhooks.py +23 -4
  2. mistralai/_hooks/types.py +27 -9
  3. mistralai/agents.py +286 -150
  4. mistralai/basesdk.py +90 -5
  5. mistralai/chat.py +260 -144
  6. mistralai/embeddings.py +73 -53
  7. mistralai/files.py +252 -192
  8. mistralai/fim.py +174 -110
  9. mistralai/fine_tuning.py +3 -2
  10. mistralai/jobs.py +372 -263
  11. mistralai/models/__init__.py +499 -46
  12. mistralai/models/agentscompletionrequest.py +47 -11
  13. mistralai/models/agentscompletionstreamrequest.py +49 -11
  14. mistralai/models/archiveftmodelout.py +6 -2
  15. mistralai/models/assistantmessage.py +11 -4
  16. mistralai/models/{modelcard.py → basemodelcard.py} +37 -14
  17. mistralai/models/chatcompletionchoice.py +4 -2
  18. mistralai/models/chatcompletionrequest.py +57 -11
  19. mistralai/models/chatcompletionresponse.py +6 -2
  20. mistralai/models/chatcompletionstreamrequest.py +59 -11
  21. mistralai/models/checkpointout.py +3 -2
  22. mistralai/models/completionchunk.py +10 -3
  23. mistralai/models/completionevent.py +1 -2
  24. mistralai/models/completionresponsestreamchoice.py +13 -5
  25. mistralai/models/contentchunk.py +13 -10
  26. mistralai/models/delete_model_v1_models_model_id_deleteop.py +4 -3
  27. mistralai/models/deletefileout.py +3 -2
  28. mistralai/models/deletemodelout.py +3 -2
  29. mistralai/models/deltamessage.py +9 -4
  30. mistralai/models/detailedjobout.py +59 -7
  31. mistralai/models/embeddingrequest.py +9 -4
  32. mistralai/models/embeddingresponse.py +5 -2
  33. mistralai/models/embeddingresponsedata.py +3 -2
  34. mistralai/models/eventout.py +9 -4
  35. mistralai/models/files_api_routes_delete_fileop.py +4 -3
  36. mistralai/models/files_api_routes_retrieve_fileop.py +4 -3
  37. mistralai/models/files_api_routes_upload_fileop.py +27 -8
  38. mistralai/models/fileschema.py +26 -5
  39. mistralai/models/fimcompletionrequest.py +26 -5
  40. mistralai/models/fimcompletionresponse.py +6 -2
  41. mistralai/models/fimcompletionstreamrequest.py +26 -5
  42. mistralai/models/finetuneablemodel.py +7 -1
  43. mistralai/models/ftmodelcapabilitiesout.py +4 -2
  44. mistralai/models/ftmodelcard.py +103 -0
  45. mistralai/models/ftmodelout.py +32 -6
  46. mistralai/models/function.py +3 -2
  47. mistralai/models/functioncall.py +2 -2
  48. mistralai/models/functionname.py +17 -0
  49. mistralai/models/githubrepositoryin.py +15 -4
  50. mistralai/models/githubrepositoryout.py +15 -4
  51. mistralai/models/httpvalidationerror.py +2 -2
  52. mistralai/models/imageurl.py +48 -0
  53. mistralai/models/imageurlchunk.py +32 -0
  54. mistralai/models/jobin.py +22 -5
  55. mistralai/models/jobmetadataout.py +31 -6
  56. mistralai/models/jobout.py +55 -7
  57. mistralai/models/jobs_api_routes_fine_tuning_archive_fine_tuned_modelop.py +4 -3
  58. mistralai/models/jobs_api_routes_fine_tuning_cancel_fine_tuning_jobop.py +4 -3
  59. mistralai/models/jobs_api_routes_fine_tuning_create_fine_tuning_jobop.py +3 -2
  60. mistralai/models/jobs_api_routes_fine_tuning_get_fine_tuning_jobop.py +4 -3
  61. mistralai/models/jobs_api_routes_fine_tuning_get_fine_tuning_jobsop.py +83 -16
  62. mistralai/models/jobs_api_routes_fine_tuning_start_fine_tuning_jobop.py +4 -3
  63. mistralai/models/jobs_api_routes_fine_tuning_unarchive_fine_tuned_modelop.py +4 -3
  64. mistralai/models/jobs_api_routes_fine_tuning_update_fine_tuned_modelop.py +9 -4
  65. mistralai/models/jobsout.py +6 -2
  66. mistralai/models/legacyjobmetadataout.py +45 -6
  67. mistralai/models/listfilesout.py +2 -2
  68. mistralai/models/metricout.py +11 -6
  69. mistralai/models/modelcapabilities.py +7 -2
  70. mistralai/models/modellist.py +21 -7
  71. mistralai/models/responseformat.py +6 -7
  72. mistralai/models/responseformats.py +8 -0
  73. mistralai/models/retrieve_model_v1_models_model_id_getop.py +24 -5
  74. mistralai/models/retrievefileout.py +26 -5
  75. mistralai/models/security.py +12 -3
  76. mistralai/models/systemmessage.py +6 -5
  77. mistralai/models/textchunk.py +9 -4
  78. mistralai/models/tool.py +9 -8
  79. mistralai/models/toolcall.py +9 -7
  80. mistralai/models/toolchoice.py +29 -0
  81. mistralai/models/toolchoiceenum.py +7 -0
  82. mistralai/models/toolmessage.py +11 -4
  83. mistralai/models/tooltypes.py +8 -0
  84. mistralai/models/trainingfile.py +2 -2
  85. mistralai/models/trainingparameters.py +27 -6
  86. mistralai/models/trainingparametersin.py +29 -8
  87. mistralai/models/unarchiveftmodelout.py +6 -2
  88. mistralai/models/updateftmodelin.py +8 -4
  89. mistralai/models/uploadfileout.py +26 -5
  90. mistralai/models/usageinfo.py +3 -2
  91. mistralai/models/usermessage.py +6 -5
  92. mistralai/models/validationerror.py +3 -2
  93. mistralai/models/wandbintegration.py +14 -4
  94. mistralai/models/wandbintegrationout.py +13 -4
  95. mistralai/models_.py +392 -294
  96. mistralai/sdk.py +24 -19
  97. mistralai/sdkconfiguration.py +6 -8
  98. mistralai/utils/__init__.py +6 -1
  99. mistralai/utils/logger.py +4 -1
  100. mistralai/utils/retries.py +2 -1
  101. mistralai/utils/security.py +13 -6
  102. {mistralai-1.0.2.dist-info → mistralai-1.1.0.dist-info}/METADATA +103 -74
  103. mistralai-1.1.0.dist-info/RECORD +254 -0
  104. mistralai_azure/_hooks/sdkhooks.py +23 -4
  105. mistralai_azure/_hooks/types.py +27 -9
  106. mistralai_azure/basesdk.py +91 -6
  107. mistralai_azure/chat.py +252 -144
  108. mistralai_azure/models/__init__.py +157 -15
  109. mistralai_azure/models/assistantmessage.py +18 -5
  110. mistralai_azure/models/chatcompletionchoice.py +7 -3
  111. mistralai_azure/models/chatcompletionrequest.py +65 -12
  112. mistralai_azure/models/chatcompletionresponse.py +6 -2
  113. mistralai_azure/models/chatcompletionstreamrequest.py +67 -12
  114. mistralai_azure/models/completionchunk.py +10 -3
  115. mistralai_azure/models/completionevent.py +1 -2
  116. mistralai_azure/models/completionresponsestreamchoice.py +10 -4
  117. mistralai_azure/models/contentchunk.py +4 -11
  118. mistralai_azure/models/deltamessage.py +16 -5
  119. mistralai_azure/models/function.py +3 -2
  120. mistralai_azure/models/functioncall.py +2 -2
  121. mistralai_azure/models/functionname.py +17 -0
  122. mistralai_azure/models/httpvalidationerror.py +2 -2
  123. mistralai_azure/models/responseformat.py +6 -7
  124. mistralai_azure/models/responseformats.py +8 -0
  125. mistralai_azure/models/security.py +12 -3
  126. mistralai_azure/models/systemmessage.py +6 -5
  127. mistralai_azure/models/textchunk.py +9 -4
  128. mistralai_azure/models/tool.py +9 -8
  129. mistralai_azure/models/toolcall.py +9 -7
  130. mistralai_azure/models/toolchoice.py +29 -0
  131. mistralai_azure/models/toolchoiceenum.py +7 -0
  132. mistralai_azure/models/toolmessage.py +18 -5
  133. mistralai_azure/models/tooltypes.py +8 -0
  134. mistralai_azure/models/usageinfo.py +3 -2
  135. mistralai_azure/models/usermessage.py +6 -5
  136. mistralai_azure/models/validationerror.py +3 -2
  137. mistralai_azure/sdkconfiguration.py +6 -8
  138. mistralai_azure/utils/__init__.py +8 -3
  139. mistralai_azure/utils/forms.py +10 -9
  140. mistralai_azure/utils/headers.py +8 -8
  141. mistralai_azure/utils/logger.py +6 -0
  142. mistralai_azure/utils/queryparams.py +16 -14
  143. mistralai_azure/utils/retries.py +2 -1
  144. mistralai_azure/utils/security.py +12 -6
  145. mistralai_azure/utils/serializers.py +17 -8
  146. mistralai_azure/utils/url.py +13 -8
  147. mistralai_azure/utils/values.py +6 -0
  148. mistralai_gcp/_hooks/sdkhooks.py +23 -4
  149. mistralai_gcp/_hooks/types.py +27 -9
  150. mistralai_gcp/basesdk.py +91 -6
  151. mistralai_gcp/chat.py +252 -144
  152. mistralai_gcp/fim.py +166 -110
  153. mistralai_gcp/models/__init__.py +179 -17
  154. mistralai_gcp/models/assistantmessage.py +18 -5
  155. mistralai_gcp/models/chatcompletionchoice.py +7 -3
  156. mistralai_gcp/models/chatcompletionrequest.py +62 -12
  157. mistralai_gcp/models/chatcompletionresponse.py +6 -2
  158. mistralai_gcp/models/chatcompletionstreamrequest.py +64 -12
  159. mistralai_gcp/models/completionchunk.py +10 -3
  160. mistralai_gcp/models/completionevent.py +1 -2
  161. mistralai_gcp/models/completionresponsestreamchoice.py +10 -4
  162. mistralai_gcp/models/contentchunk.py +4 -11
  163. mistralai_gcp/models/deltamessage.py +16 -5
  164. mistralai_gcp/models/fimcompletionrequest.py +33 -6
  165. mistralai_gcp/models/fimcompletionresponse.py +6 -2
  166. mistralai_gcp/models/fimcompletionstreamrequest.py +33 -6
  167. mistralai_gcp/models/function.py +3 -2
  168. mistralai_gcp/models/functioncall.py +2 -2
  169. mistralai_gcp/models/functionname.py +17 -0
  170. mistralai_gcp/models/httpvalidationerror.py +2 -2
  171. mistralai_gcp/models/responseformat.py +6 -7
  172. mistralai_gcp/models/responseformats.py +8 -0
  173. mistralai_gcp/models/security.py +12 -3
  174. mistralai_gcp/models/systemmessage.py +6 -5
  175. mistralai_gcp/models/textchunk.py +9 -4
  176. mistralai_gcp/models/tool.py +9 -8
  177. mistralai_gcp/models/toolcall.py +9 -7
  178. mistralai_gcp/models/toolchoice.py +29 -0
  179. mistralai_gcp/models/toolchoiceenum.py +7 -0
  180. mistralai_gcp/models/toolmessage.py +18 -5
  181. mistralai_gcp/models/tooltypes.py +8 -0
  182. mistralai_gcp/models/usageinfo.py +3 -2
  183. mistralai_gcp/models/usermessage.py +6 -5
  184. mistralai_gcp/models/validationerror.py +3 -2
  185. mistralai_gcp/sdk.py +14 -10
  186. mistralai_gcp/sdkconfiguration.py +6 -8
  187. mistralai_gcp/utils/__init__.py +8 -3
  188. mistralai_gcp/utils/forms.py +10 -9
  189. mistralai_gcp/utils/headers.py +8 -8
  190. mistralai_gcp/utils/logger.py +6 -0
  191. mistralai_gcp/utils/queryparams.py +16 -14
  192. mistralai_gcp/utils/retries.py +2 -1
  193. mistralai_gcp/utils/security.py +12 -6
  194. mistralai_gcp/utils/serializers.py +17 -8
  195. mistralai_gcp/utils/url.py +13 -8
  196. mistralai_gcp/utils/values.py +6 -0
  197. mistralai-1.0.2.dist-info/RECORD +0 -236
  198. {mistralai-1.0.2.dist-info → mistralai-1.1.0.dist-info}/LICENSE +0 -0
  199. {mistralai-1.0.2.dist-info → mistralai-1.1.0.dist-info}/WHEEL +0 -0
@@ -0,0 +1,8 @@
1
+ """Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
2
+
3
+ from __future__ import annotations
4
+ from mistralai_gcp.types import UnrecognizedStr
5
+ from typing import Literal, Union
6
+
7
+
8
+ ToolTypes = Union[Literal["function"], UnrecognizedStr]
@@ -9,10 +9,11 @@ class UsageInfoTypedDict(TypedDict):
9
9
  prompt_tokens: int
10
10
  completion_tokens: int
11
11
  total_tokens: int
12
-
12
+
13
13
 
14
14
  class UsageInfo(BaseModel):
15
15
  prompt_tokens: int
16
+
16
17
  completion_tokens: int
18
+
17
19
  total_tokens: int
18
-
@@ -1,26 +1,27 @@
1
1
  """Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
2
2
 
3
3
  from __future__ import annotations
4
- from .textchunk import TextChunk, TextChunkTypedDict
4
+ from .contentchunk import ContentChunk, ContentChunkTypedDict
5
5
  from mistralai_gcp.types import BaseModel
6
6
  from typing import List, Literal, Optional, TypedDict, Union
7
7
  from typing_extensions import NotRequired
8
8
 
9
9
 
10
- UserMessageContentTypedDict = Union[str, List[TextChunkTypedDict]]
10
+ UserMessageContentTypedDict = Union[str, List[ContentChunkTypedDict]]
11
11
 
12
12
 
13
- UserMessageContent = Union[str, List[TextChunk]]
13
+ UserMessageContent = Union[str, List[ContentChunk]]
14
14
 
15
15
 
16
16
  UserMessageRole = Literal["user"]
17
17
 
18
+
18
19
  class UserMessageTypedDict(TypedDict):
19
20
  content: UserMessageContentTypedDict
20
21
  role: NotRequired[UserMessageRole]
21
-
22
+
22
23
 
23
24
  class UserMessage(BaseModel):
24
25
  content: UserMessageContent
26
+
25
27
  role: Optional[UserMessageRole] = "user"
26
-
@@ -15,10 +15,11 @@ class ValidationErrorTypedDict(TypedDict):
15
15
  loc: List[LocTypedDict]
16
16
  msg: str
17
17
  type: str
18
-
18
+
19
19
 
20
20
  class ValidationError(BaseModel):
21
21
  loc: List[Loc]
22
+
22
23
  msg: str
24
+
23
25
  type: str
24
-
mistralai_gcp/sdk.py CHANGED
@@ -32,6 +32,7 @@ class MistralGoogleCloud(BaseSDK):
32
32
  self,
33
33
  region: str = "europe-west4",
34
34
  project_id: Optional[str] = None,
35
+ access_token: Optional[str] = None,
35
36
  client: Optional[HttpClient] = None,
36
37
  async_client: Optional[AsyncHttpClient] = None,
37
38
  retry_config: Optional[Nullable[RetryConfig]] = None,
@@ -46,22 +47,25 @@ class MistralGoogleCloud(BaseSDK):
46
47
  :param retry_config: The retry configuration to use for all supported methods
47
48
  """
48
49
 
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"
50
+ if not access_token:
51
+ credentials, loaded_project_id = google.auth.default(
52
+ scopes=["https://www.googleapis.com/auth/cloud-platform"],
56
53
  )
54
+ credentials.refresh(google.auth.transport.requests.Request())
55
+
56
+ if not isinstance(credentials, google.auth.credentials.Credentials):
57
+ raise models.SDKError(
58
+ "credentials must be an instance of google.auth.credentials.Credentials"
59
+ )
57
60
 
58
- project_id = project_id or loaded_project_id
61
+ project_id = project_id or loaded_project_id
59
62
  if project_id is None:
60
63
  raise models.SDKError("project_id must be provided")
61
64
 
62
65
  def auth_token() -> str:
63
- if credentials.expired:
64
- credentials.refresh(google.auth.transport.requests.Request())
66
+ if access_token:
67
+ return access_token
68
+ credentials.refresh(google.auth.transport.requests.Request())
65
69
  token = credentials.token
66
70
  if not token:
67
71
  raise models.SDKError("Failed to get token from credentials")
@@ -1,6 +1,5 @@
1
1
  """Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
2
2
 
3
-
4
3
  from ._hooks import SDKHooks
5
4
  from .httpclient import AsyncHttpClient, HttpClient
6
5
  from .utils import Logger, RetryConfig, remove_suffix
@@ -14,7 +13,7 @@ from typing import Callable, Dict, Optional, Tuple, Union
14
13
  SERVER_PROD = "prod"
15
14
  r"""Production server"""
16
15
  SERVERS = {
17
- SERVER_PROD: "https://api.mistral.ai",
16
+ SERVER_PROD: "https://api.mistral.ai",
18
17
  }
19
18
  """Contains the list of servers available to the SDK"""
20
19
 
@@ -24,14 +23,14 @@ class SDKConfiguration:
24
23
  client: HttpClient
25
24
  async_client: AsyncHttpClient
26
25
  debug_logger: Logger
27
- security: Optional[Union[models.Security,Callable[[], models.Security]]] = None
26
+ security: Optional[Union[models.Security, Callable[[], models.Security]]] = None
28
27
  server_url: Optional[str] = ""
29
28
  server: Optional[str] = ""
30
29
  language: str = "python"
31
30
  openapi_doc_version: str = "0.0.2"
32
- sdk_version: str = "1.0.1"
33
- gen_version: str = "2.399.0"
34
- user_agent: str = "speakeasy-sdk/python 1.0.1 2.399.0 0.0.2 mistralai-gcp"
31
+ sdk_version: str = "1.2.2"
32
+ gen_version: str = "2.415.6"
33
+ user_agent: str = "speakeasy-sdk/python 1.2.2 2.415.6 0.0.2 mistralai-gcp"
35
34
  retry_config: OptionalNullable[RetryConfig] = Field(default_factory=lambda: UNSET)
36
35
  timeout_ms: Optional[int] = None
37
36
 
@@ -45,10 +44,9 @@ class SDKConfiguration:
45
44
  self.server = SERVER_PROD
46
45
 
47
46
  if self.server not in SERVERS:
48
- raise ValueError(f"Invalid server \"{self.server}\"")
47
+ raise ValueError(f'Invalid server "{self.server}"')
49
48
 
50
49
  return SERVERS[self.server], {}
51
50
 
52
-
53
51
  def get_hooks(self) -> SDKHooks:
54
52
  return self._hooks
@@ -33,8 +33,13 @@ from .serializers import (
33
33
  validate_open_enum,
34
34
  )
35
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
36
+ from .values import (
37
+ get_global_from_env,
38
+ match_content_type,
39
+ match_status_codes,
40
+ match_response,
41
+ )
42
+ from .logger import Logger, get_body_content, get_default_logger
38
43
 
39
44
  __all__ = [
40
45
  "BackoffStrategy",
@@ -43,6 +48,7 @@ __all__ = [
43
48
  "FormMetadata",
44
49
  "generate_url",
45
50
  "get_body_content",
51
+ "get_default_logger",
46
52
  "get_discriminator",
47
53
  "get_global_from_env",
48
54
  "get_headers",
@@ -57,7 +63,6 @@ __all__ = [
57
63
  "match_status_codes",
58
64
  "match_response",
59
65
  "MultipartFormMetadata",
60
- "NoOpLogger",
61
66
  "OpenEnumMeta",
62
67
  "PathParamMetadata",
63
68
  "QueryParamMetadata",
@@ -17,7 +17,7 @@ from .metadata import (
17
17
  MultipartFormMetadata,
18
18
  find_field_metadata,
19
19
  )
20
- from .values import _val_to_string
20
+ from .values import _is_set, _val_to_string
21
21
 
22
22
 
23
23
  def _populate_form(
@@ -27,7 +27,7 @@ def _populate_form(
27
27
  delimiter: str,
28
28
  form: Dict[str, List[str]],
29
29
  ):
30
- if obj is None:
30
+ if not _is_set(obj):
31
31
  return form
32
32
 
33
33
  if isinstance(obj, BaseModel):
@@ -41,7 +41,7 @@ def _populate_form(
41
41
  continue
42
42
 
43
43
  val = getattr(obj, name)
44
- if val is None:
44
+ if not _is_set(val):
45
45
  continue
46
46
 
47
47
  if explode:
@@ -54,7 +54,7 @@ def _populate_form(
54
54
  elif isinstance(obj, Dict):
55
55
  items = []
56
56
  for key, value in obj.items():
57
- if value is None:
57
+ if not _is_set(value):
58
58
  continue
59
59
 
60
60
  if explode:
@@ -68,7 +68,7 @@ def _populate_form(
68
68
  items = []
69
69
 
70
70
  for value in obj:
71
- if value is None:
71
+ if not _is_set(value):
72
72
  continue
73
73
 
74
74
  if explode:
@@ -102,7 +102,7 @@ def serialize_multipart_form(
102
102
  field = request_fields[name]
103
103
 
104
104
  val = getattr(request, name)
105
- if val is None:
105
+ if not _is_set(val):
106
106
  continue
107
107
 
108
108
  field_metadata = find_field_metadata(field, MultipartFormMetadata)
@@ -156,7 +156,7 @@ def serialize_multipart_form(
156
156
  values = []
157
157
 
158
158
  for value in val:
159
- if value is None:
159
+ if not _is_set(value):
160
160
  continue
161
161
  values.append(_val_to_string(value))
162
162
 
@@ -176,7 +176,7 @@ def serialize_form_data(data: Any) -> Dict[str, Any]:
176
176
  field = data_fields[name]
177
177
 
178
178
  val = getattr(data, name)
179
- if val is None:
179
+ if not _is_set(val):
180
180
  continue
181
181
 
182
182
  metadata = find_field_metadata(field, FormMetadata)
@@ -200,7 +200,8 @@ def serialize_form_data(data: Any) -> Dict[str, Any]:
200
200
  raise ValueError(f"Invalid form style for field {name}")
201
201
  elif isinstance(data, Dict):
202
202
  for key, value in data.items():
203
- form[key] = [_val_to_string(value)]
203
+ if _is_set(value):
204
+ form[key] = [_val_to_string(value)]
204
205
  else:
205
206
  raise TypeError(f"Invalid request body type {type(data)} for form data")
206
207
 
@@ -15,16 +15,16 @@ from .metadata import (
15
15
  find_field_metadata,
16
16
  )
17
17
 
18
- from .values import _populate_from_globals, _val_to_string
18
+ from .values import _is_set, _populate_from_globals, _val_to_string
19
19
 
20
20
 
21
21
  def get_headers(headers_params: Any, gbls: Optional[Any] = None) -> Dict[str, str]:
22
22
  headers: Dict[str, str] = {}
23
23
 
24
24
  globals_already_populated = []
25
- if headers_params is not None:
25
+ if _is_set(headers_params):
26
26
  globals_already_populated = _populate_headers(headers_params, gbls, headers, [])
27
- if gbls is not None:
27
+ if _is_set(gbls):
28
28
  _populate_headers(gbls, None, headers, globals_already_populated)
29
29
 
30
30
  return headers
@@ -67,7 +67,7 @@ def _populate_headers(
67
67
 
68
68
 
69
69
  def _serialize_header(explode: bool, obj: Any) -> str:
70
- if obj is None:
70
+ if not _is_set(obj):
71
71
  return ""
72
72
 
73
73
  if isinstance(obj, BaseModel):
@@ -83,7 +83,7 @@ def _serialize_header(explode: bool, obj: Any) -> str:
83
83
  f_name = obj_field.alias if obj_field.alias is not None else name
84
84
 
85
85
  val = getattr(obj, name)
86
- if val is None:
86
+ if not _is_set(val):
87
87
  continue
88
88
 
89
89
  if explode:
@@ -98,7 +98,7 @@ def _serialize_header(explode: bool, obj: Any) -> str:
98
98
  items = []
99
99
 
100
100
  for key, value in obj.items():
101
- if value is None:
101
+ if not _is_set(value):
102
102
  continue
103
103
 
104
104
  if explode:
@@ -113,14 +113,14 @@ def _serialize_header(explode: bool, obj: Any) -> str:
113
113
  items = []
114
114
 
115
115
  for value in obj:
116
- if value is None:
116
+ if not _is_set(value):
117
117
  continue
118
118
 
119
119
  items.append(_val_to_string(value))
120
120
 
121
121
  if len(items) > 0:
122
122
  return ",".join(items)
123
- else:
123
+ elif _is_set(obj):
124
124
  return f"{_val_to_string(obj)}"
125
125
 
126
126
  return ""
@@ -3,14 +3,20 @@
3
3
  import httpx
4
4
  from typing import Any, Protocol
5
5
 
6
+
6
7
  class Logger(Protocol):
7
8
  def debug(self, msg: str, *args: Any, **kwargs: Any) -> None:
8
9
  pass
9
10
 
11
+
10
12
  class NoOpLogger:
11
13
  def debug(self, msg: str, *args: Any, **kwargs: Any) -> None:
12
14
  pass
13
15
 
16
+
14
17
  def get_body_content(req: httpx.Request) -> str:
15
18
  return "<streaming body>" if not hasattr(req, "_content") else str(req.content)
16
19
 
20
+
21
+ def get_default_logger() -> Logger:
22
+ return NoOpLogger()
@@ -15,7 +15,12 @@ from .metadata import (
15
15
  QueryParamMetadata,
16
16
  find_field_metadata,
17
17
  )
18
- from .values import _get_serialized_params, _populate_from_globals, _val_to_string
18
+ from .values import (
19
+ _get_serialized_params,
20
+ _is_set,
21
+ _populate_from_globals,
22
+ _val_to_string,
23
+ )
19
24
  from .forms import _populate_form
20
25
 
21
26
 
@@ -26,7 +31,7 @@ def get_query_params(
26
31
  params: Dict[str, List[str]] = {}
27
32
 
28
33
  globals_already_populated = _populate_query_params(query_params, gbls, params, [])
29
- if gbls is not None:
34
+ if _is_set(gbls):
30
35
  _populate_query_params(gbls, None, params, globals_already_populated)
31
36
 
32
37
  return params
@@ -55,7 +60,7 @@ def _populate_query_params(
55
60
  if not metadata:
56
61
  continue
57
62
 
58
- value = getattr(query_params, name) if query_params is not None else None
63
+ value = getattr(query_params, name) if _is_set(query_params) else None
59
64
 
60
65
  value, global_found = _populate_from_globals(
61
66
  name, value, QueryParamMetadata, gbls
@@ -99,7 +104,7 @@ def _populate_deep_object_query_params(
99
104
  obj: Any,
100
105
  params: Dict[str, List[str]],
101
106
  ):
102
- if obj is None:
107
+ if not _is_set(obj):
103
108
  return
104
109
 
105
110
  if isinstance(obj, BaseModel):
@@ -113,10 +118,7 @@ def _populate_deep_object_query_params_basemodel(
113
118
  obj: Any,
114
119
  params: Dict[str, List[str]],
115
120
  ):
116
- if obj is None:
117
- return
118
-
119
- if not isinstance(obj, BaseModel):
121
+ if not _is_set(obj) or not isinstance(obj, BaseModel):
120
122
  return
121
123
 
122
124
  obj_fields: Dict[str, FieldInfo] = obj.__class__.model_fields
@@ -128,11 +130,11 @@ def _populate_deep_object_query_params_basemodel(
128
130
  params_key = f"{prior_params_key}[{f_name}]"
129
131
 
130
132
  obj_param_metadata = find_field_metadata(obj_field, QueryParamMetadata)
131
- if obj_param_metadata is None:
133
+ if not _is_set(obj_param_metadata):
132
134
  continue
133
135
 
134
136
  obj_val = getattr(obj, name)
135
- if obj_val is None:
137
+ if not _is_set(obj_val):
136
138
  continue
137
139
 
138
140
  if isinstance(obj_val, BaseModel):
@@ -150,11 +152,11 @@ def _populate_deep_object_query_params_dict(
150
152
  value: Dict,
151
153
  params: Dict[str, List[str]],
152
154
  ):
153
- if value is None:
155
+ if not _is_set(value):
154
156
  return
155
157
 
156
158
  for key, val in value.items():
157
- if val is None:
159
+ if not _is_set(val):
158
160
  continue
159
161
 
160
162
  params_key = f"{prior_params_key}[{key}]"
@@ -174,11 +176,11 @@ def _populate_deep_object_query_params_list(
174
176
  value: List,
175
177
  params: Dict[str, List[str]],
176
178
  ):
177
- if value is None:
179
+ if not _is_set(value):
178
180
  return
179
181
 
180
182
  for val in value:
181
- if val is None:
183
+ if not _is_set(val):
182
184
  continue
183
185
 
184
186
  if params.get(params_key) is None:
@@ -1,5 +1,6 @@
1
1
  """Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
2
2
 
3
+ import asyncio
3
4
  import random
4
5
  import time
5
6
  from typing import List
@@ -212,5 +213,5 @@ async def retry_with_backoff_async(
212
213
  raise
213
214
  sleep = (initial_interval / 1000) * exponent**retries + random.uniform(0, 1)
214
215
  sleep = min(sleep, max_interval / 1000)
215
- time.sleep(sleep)
216
+ await asyncio.sleep(sleep)
216
217
  retries += 1
@@ -16,7 +16,6 @@ from .metadata import (
16
16
  )
17
17
 
18
18
 
19
-
20
19
  def get_security(security: Any) -> Tuple[Dict[str, str], Dict[str, List[str]]]:
21
20
  headers: Dict[str, str] = {}
22
21
  query_params: Dict[str, List[str]] = {}
@@ -42,8 +41,10 @@ def get_security(security: Any) -> Tuple[Dict[str, str], Dict[str, List[str]]]:
42
41
  _parse_security_option(headers, query_params, value)
43
42
  return headers, query_params
44
43
  if metadata.scheme:
45
- # Special case for basic auth which could be a flattened model
46
- if metadata.sub_type == "basic" and not isinstance(value, BaseModel):
44
+ # Special case for basic auth or custom auth which could be a flattened model
45
+ if metadata.sub_type in ["basic", "custom"] and not isinstance(
46
+ value, BaseModel
47
+ ):
47
48
  _parse_security_scheme(headers, query_params, metadata, name, security)
48
49
  else:
49
50
  _parse_security_scheme(headers, query_params, metadata, name, value)
@@ -80,9 +81,12 @@ def _parse_security_scheme(
80
81
  sub_type = scheme_metadata.sub_type
81
82
 
82
83
  if isinstance(scheme, BaseModel):
83
- if scheme_type == "http" and sub_type == "basic":
84
- _parse_basic_auth_scheme(headers, scheme)
85
- return
84
+ if scheme_type == "http":
85
+ if sub_type == "basic":
86
+ _parse_basic_auth_scheme(headers, scheme)
87
+ return
88
+ if sub_type == "custom":
89
+ return
86
90
 
87
91
  scheme_fields: Dict[str, FieldInfo] = scheme.__class__.model_fields
88
92
  for name in scheme_fields:
@@ -131,6 +135,8 @@ def _parse_security_scheme_value(
131
135
  elif scheme_type == "http":
132
136
  if sub_type == "bearer":
133
137
  headers[header_name] = _apply_bearer(value)
138
+ elif sub_type == "custom":
139
+ return
134
140
  else:
135
141
  raise ValueError("sub type {sub_type} not supported")
136
142
  else:
@@ -9,13 +9,15 @@ from pydantic import ConfigDict, create_model
9
9
  from pydantic_core import from_json
10
10
  from typing_inspect import is_optional_type
11
11
 
12
- from ..types.basemodel import BaseModel, Nullable, OptionalNullable
12
+ from ..types.basemodel import BaseModel, Nullable, OptionalNullable, Unset
13
13
 
14
14
 
15
15
  def serialize_decimal(as_str: bool):
16
16
  def serialize(d):
17
17
  if is_optional_type(type(d)) and d is None:
18
18
  return None
19
+ if isinstance(d, Unset):
20
+ return d
19
21
 
20
22
  if not isinstance(d, Decimal):
21
23
  raise ValueError("Expected Decimal object")
@@ -29,7 +31,7 @@ def validate_decimal(d):
29
31
  if d is None:
30
32
  return None
31
33
 
32
- if isinstance(d, Decimal):
34
+ if isinstance(d, (Decimal, Unset)):
33
35
  return d
34
36
 
35
37
  if not isinstance(d, (str, int, float)):
@@ -42,6 +44,8 @@ def serialize_float(as_str: bool):
42
44
  def serialize(f):
43
45
  if is_optional_type(type(f)) and f is None:
44
46
  return None
47
+ if isinstance(f, Unset):
48
+ return f
45
49
 
46
50
  if not isinstance(f, float):
47
51
  raise ValueError("Expected float")
@@ -55,7 +59,7 @@ def validate_float(f):
55
59
  if f is None:
56
60
  return None
57
61
 
58
- if isinstance(f, float):
62
+ if isinstance(f, (float, Unset)):
59
63
  return f
60
64
 
61
65
  if not isinstance(f, str):
@@ -65,14 +69,16 @@ def validate_float(f):
65
69
 
66
70
 
67
71
  def serialize_int(as_str: bool):
68
- def serialize(b):
69
- if is_optional_type(type(b)) and b is None:
72
+ def serialize(i):
73
+ if is_optional_type(type(i)) and i is None:
70
74
  return None
75
+ if isinstance(i, Unset):
76
+ return i
71
77
 
72
- if not isinstance(b, int):
78
+ if not isinstance(i, int):
73
79
  raise ValueError("Expected int")
74
80
 
75
- return str(b) if as_str else b
81
+ return str(i) if as_str else i
76
82
 
77
83
  return serialize
78
84
 
@@ -81,7 +87,7 @@ def validate_int(b):
81
87
  if b is None:
82
88
  return None
83
89
 
84
- if isinstance(b, int):
90
+ if isinstance(b, (int, Unset)):
85
91
  return b
86
92
 
87
93
  if not isinstance(b, str):
@@ -95,6 +101,9 @@ def validate_open_enum(is_int: bool):
95
101
  if e is None:
96
102
  return None
97
103
 
104
+ if isinstance(e, Unset):
105
+ return e
106
+
98
107
  if is_int:
99
108
  if not isinstance(e, int):
100
109
  raise ValueError("Expected int")
@@ -18,7 +18,12 @@ from .metadata import (
18
18
  PathParamMetadata,
19
19
  find_field_metadata,
20
20
  )
21
- from .values import _get_serialized_params, _populate_from_globals, _val_to_string
21
+ from .values import (
22
+ _get_serialized_params,
23
+ _is_set,
24
+ _populate_from_globals,
25
+ _val_to_string,
26
+ )
22
27
 
23
28
 
24
29
  def generate_url(
@@ -32,7 +37,7 @@ def generate_url(
32
37
  globals_already_populated = _populate_path_params(
33
38
  path_params, gbls, path_param_values, []
34
39
  )
35
- if gbls is not None:
40
+ if _is_set(gbls):
36
41
  _populate_path_params(gbls, None, path_param_values, globals_already_populated)
37
42
 
38
43
  for key, value in path_param_values.items():
@@ -64,14 +69,14 @@ def _populate_path_params(
64
69
  if param_metadata is None:
65
70
  continue
66
71
 
67
- param = getattr(path_params, name) if path_params is not None else None
72
+ param = getattr(path_params, name) if _is_set(path_params) else None
68
73
  param, global_found = _populate_from_globals(
69
74
  name, param, PathParamMetadata, gbls
70
75
  )
71
76
  if global_found:
72
77
  globals_already_populated.append(name)
73
78
 
74
- if param is None:
79
+ if not _is_set(param):
75
80
  continue
76
81
 
77
82
  f_name = field.alias if field.alias is not None else name
@@ -87,13 +92,13 @@ def _populate_path_params(
87
92
  if param_metadata.style == "simple":
88
93
  if isinstance(param, List):
89
94
  for pp_val in param:
90
- if pp_val is None:
95
+ if not _is_set(pp_val):
91
96
  continue
92
97
  pp_vals.append(_val_to_string(pp_val))
93
98
  path_param_values[f_name] = ",".join(pp_vals)
94
99
  elif isinstance(param, Dict):
95
100
  for pp_key in param:
96
- if param[pp_key] is None:
101
+ if not _is_set(param[pp_key]):
97
102
  continue
98
103
  if param_metadata.explode:
99
104
  pp_vals.append(f"{pp_key}={_val_to_string(param[pp_key])}")
@@ -116,7 +121,7 @@ def _populate_path_params(
116
121
  )
117
122
 
118
123
  param_field_val = getattr(param, name)
119
- if param_field_val is None:
124
+ if not _is_set(param_field_val):
120
125
  continue
121
126
  if param_metadata.explode:
122
127
  pp_vals.append(
@@ -127,7 +132,7 @@ def _populate_path_params(
127
132
  f"{param_name},{_val_to_string(param_field_val)}"
128
133
  )
129
134
  path_param_values[f_name] = ",".join(pp_vals)
130
- else:
135
+ elif _is_set(param):
131
136
  path_param_values[f_name] = _val_to_string(param)
132
137
 
133
138
  return globals_already_populated