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.
Files changed (166) hide show
  1. orq_ai_sdk/_version.py +3 -3
  2. orq_ai_sdk/agents.py +186 -186
  3. orq_ai_sdk/audio.py +30 -0
  4. orq_ai_sdk/basesdk.py +20 -6
  5. orq_ai_sdk/chat.py +22 -0
  6. orq_ai_sdk/completions.py +438 -0
  7. orq_ai_sdk/contacts.py +43 -855
  8. orq_ai_sdk/deployments.py +61 -0
  9. orq_ai_sdk/edits.py +364 -0
  10. orq_ai_sdk/embeddings.py +344 -0
  11. orq_ai_sdk/generations.py +370 -0
  12. orq_ai_sdk/identities.py +1037 -0
  13. orq_ai_sdk/images.py +28 -0
  14. orq_ai_sdk/models/__init__.py +5746 -737
  15. orq_ai_sdk/models/actionreviewedstreamingevent.py +18 -1
  16. orq_ai_sdk/models/actionreviewrequestedstreamingevent.py +44 -1
  17. orq_ai_sdk/models/agenterroredstreamingevent.py +18 -1
  18. orq_ai_sdk/models/agentinactivestreamingevent.py +168 -70
  19. orq_ai_sdk/models/agentmessagecreatedstreamingevent.py +18 -2
  20. orq_ai_sdk/models/agentresponsemessage.py +18 -2
  21. orq_ai_sdk/models/agentstartedstreamingevent.py +127 -2
  22. orq_ai_sdk/models/agentthoughtstreamingevent.py +178 -211
  23. orq_ai_sdk/models/conversationresponse.py +31 -20
  24. orq_ai_sdk/models/conversationwithmessagesresponse.py +31 -20
  25. orq_ai_sdk/models/createagentrequestop.py +1945 -383
  26. orq_ai_sdk/models/createagentresponse.py +147 -91
  27. orq_ai_sdk/models/createagentresponserequestop.py +111 -2
  28. orq_ai_sdk/models/createchatcompletionop.py +1381 -861
  29. orq_ai_sdk/models/createchunkop.py +46 -19
  30. orq_ai_sdk/models/createcompletionop.py +2078 -0
  31. orq_ai_sdk/models/createcontactop.py +45 -56
  32. orq_ai_sdk/models/createconversationop.py +61 -39
  33. orq_ai_sdk/models/createconversationresponseop.py +68 -4
  34. orq_ai_sdk/models/createdatasetitemop.py +424 -80
  35. orq_ai_sdk/models/createdatasetop.py +19 -2
  36. orq_ai_sdk/models/createdatasourceop.py +92 -26
  37. orq_ai_sdk/models/createembeddingop.py +579 -0
  38. orq_ai_sdk/models/createevalop.py +552 -24
  39. orq_ai_sdk/models/createidentityop.py +176 -0
  40. orq_ai_sdk/models/createimageeditop.py +715 -0
  41. orq_ai_sdk/models/createimageop.py +407 -128
  42. orq_ai_sdk/models/createimagevariationop.py +706 -0
  43. orq_ai_sdk/models/createknowledgeop.py +186 -121
  44. orq_ai_sdk/models/creatememorydocumentop.py +50 -1
  45. orq_ai_sdk/models/creatememoryop.py +34 -21
  46. orq_ai_sdk/models/creatememorystoreop.py +34 -1
  47. orq_ai_sdk/models/createmoderationop.py +521 -0
  48. orq_ai_sdk/models/createpromptop.py +2759 -1251
  49. orq_ai_sdk/models/creatererankop.py +608 -0
  50. orq_ai_sdk/models/createresponseop.py +2567 -0
  51. orq_ai_sdk/models/createspeechop.py +466 -0
  52. orq_ai_sdk/models/createtoolop.py +537 -12
  53. orq_ai_sdk/models/createtranscriptionop.py +732 -0
  54. orq_ai_sdk/models/createtranslationop.py +702 -0
  55. orq_ai_sdk/models/datapart.py +18 -1
  56. orq_ai_sdk/models/deletechunksop.py +34 -1
  57. orq_ai_sdk/models/{deletecontactop.py → deleteidentityop.py} +9 -9
  58. orq_ai_sdk/models/deletepromptop.py +26 -0
  59. orq_ai_sdk/models/deploymentcreatemetricop.py +362 -76
  60. orq_ai_sdk/models/deploymentgetconfigop.py +635 -194
  61. orq_ai_sdk/models/deploymentinvokeop.py +168 -173
  62. orq_ai_sdk/models/deploymentsop.py +195 -58
  63. orq_ai_sdk/models/deploymentstreamop.py +652 -304
  64. orq_ai_sdk/models/errorpart.py +18 -1
  65. orq_ai_sdk/models/filecontentpartschema.py +18 -1
  66. orq_ai_sdk/models/filegetop.py +19 -2
  67. orq_ai_sdk/models/filelistop.py +35 -2
  68. orq_ai_sdk/models/filepart.py +50 -1
  69. orq_ai_sdk/models/fileuploadop.py +51 -2
  70. orq_ai_sdk/models/generateconversationnameop.py +31 -20
  71. orq_ai_sdk/models/get_v2_evaluators_id_versionsop.py +34 -1
  72. orq_ai_sdk/models/get_v2_tools_tool_id_versions_version_id_op.py +18 -1
  73. orq_ai_sdk/models/get_v2_tools_tool_id_versionsop.py +34 -1
  74. orq_ai_sdk/models/getallmemoriesop.py +34 -21
  75. orq_ai_sdk/models/getallmemorydocumentsop.py +42 -1
  76. orq_ai_sdk/models/getallmemorystoresop.py +34 -1
  77. orq_ai_sdk/models/getallpromptsop.py +1696 -230
  78. orq_ai_sdk/models/getalltoolsop.py +325 -8
  79. orq_ai_sdk/models/getchunkscountop.py +34 -1
  80. orq_ai_sdk/models/getevalsop.py +395 -43
  81. orq_ai_sdk/models/getonechunkop.py +14 -19
  82. orq_ai_sdk/models/getoneknowledgeop.py +116 -96
  83. orq_ai_sdk/models/getonepromptop.py +1679 -230
  84. orq_ai_sdk/models/getpromptversionop.py +1676 -216
  85. orq_ai_sdk/models/imagecontentpartschema.py +50 -1
  86. orq_ai_sdk/models/internal/globals.py +18 -1
  87. orq_ai_sdk/models/invokeagentop.py +140 -2
  88. orq_ai_sdk/models/invokedeploymentrequest.py +418 -80
  89. orq_ai_sdk/models/invokeevalop.py +160 -131
  90. orq_ai_sdk/models/listagentsop.py +805 -166
  91. orq_ai_sdk/models/listchunksop.py +32 -19
  92. orq_ai_sdk/models/listchunkspaginatedop.py +46 -19
  93. orq_ai_sdk/models/listconversationsop.py +18 -1
  94. orq_ai_sdk/models/listdatasetdatapointsop.py +252 -42
  95. orq_ai_sdk/models/listdatasetsop.py +35 -2
  96. orq_ai_sdk/models/listdatasourcesop.py +35 -26
  97. orq_ai_sdk/models/{listcontactsop.py → listidentitiesop.py} +89 -79
  98. orq_ai_sdk/models/listknowledgebasesop.py +132 -96
  99. orq_ai_sdk/models/listmodelsop.py +1 -0
  100. orq_ai_sdk/models/listpromptversionsop.py +1690 -216
  101. orq_ai_sdk/models/parseop.py +161 -17
  102. orq_ai_sdk/models/partdoneevent.py +19 -2
  103. orq_ai_sdk/models/post_v2_router_ocrop.py +408 -0
  104. orq_ai_sdk/models/publiccontact.py +27 -4
  105. orq_ai_sdk/models/publicidentity.py +62 -0
  106. orq_ai_sdk/models/reasoningpart.py +19 -2
  107. orq_ai_sdk/models/refusalpartschema.py +18 -1
  108. orq_ai_sdk/models/remoteconfigsgetconfigop.py +34 -1
  109. orq_ai_sdk/models/responsedoneevent.py +114 -84
  110. orq_ai_sdk/models/responsestartedevent.py +18 -1
  111. orq_ai_sdk/models/retrieveagentrequestop.py +799 -166
  112. orq_ai_sdk/models/retrievedatapointop.py +236 -42
  113. orq_ai_sdk/models/retrievedatasetop.py +19 -2
  114. orq_ai_sdk/models/retrievedatasourceop.py +17 -26
  115. orq_ai_sdk/models/{retrievecontactop.py → retrieveidentityop.py} +38 -41
  116. orq_ai_sdk/models/retrievememorydocumentop.py +18 -1
  117. orq_ai_sdk/models/retrievememoryop.py +18 -21
  118. orq_ai_sdk/models/retrievememorystoreop.py +18 -1
  119. orq_ai_sdk/models/retrievetoolop.py +309 -8
  120. orq_ai_sdk/models/runagentop.py +1462 -196
  121. orq_ai_sdk/models/searchknowledgeop.py +108 -1
  122. orq_ai_sdk/models/security.py +18 -1
  123. orq_ai_sdk/models/streamagentop.py +93 -2
  124. orq_ai_sdk/models/streamrunagentop.py +1439 -194
  125. orq_ai_sdk/models/textcontentpartschema.py +34 -1
  126. orq_ai_sdk/models/thinkingconfigenabledschema.py +18 -1
  127. orq_ai_sdk/models/toolcallpart.py +18 -1
  128. orq_ai_sdk/models/tooldoneevent.py +18 -1
  129. orq_ai_sdk/models/toolexecutionfailedstreamingevent.py +50 -1
  130. orq_ai_sdk/models/toolexecutionfinishedstreamingevent.py +34 -1
  131. orq_ai_sdk/models/toolexecutionstartedstreamingevent.py +34 -1
  132. orq_ai_sdk/models/toolresultpart.py +18 -1
  133. orq_ai_sdk/models/toolreviewrequestedevent.py +18 -1
  134. orq_ai_sdk/models/toolstartedevent.py +18 -1
  135. orq_ai_sdk/models/updateagentop.py +1968 -397
  136. orq_ai_sdk/models/updatechunkop.py +46 -19
  137. orq_ai_sdk/models/updateconversationop.py +61 -39
  138. orq_ai_sdk/models/updatedatapointop.py +424 -80
  139. orq_ai_sdk/models/updatedatasetop.py +51 -2
  140. orq_ai_sdk/models/updatedatasourceop.py +17 -26
  141. orq_ai_sdk/models/updateevalop.py +577 -16
  142. orq_ai_sdk/models/{updatecontactop.py → updateidentityop.py} +78 -68
  143. orq_ai_sdk/models/updateknowledgeop.py +234 -190
  144. orq_ai_sdk/models/updatememorydocumentop.py +50 -1
  145. orq_ai_sdk/models/updatememoryop.py +50 -21
  146. orq_ai_sdk/models/updatememorystoreop.py +66 -1
  147. orq_ai_sdk/models/updatepromptop.py +2854 -1448
  148. orq_ai_sdk/models/updatetoolop.py +592 -9
  149. orq_ai_sdk/models/usermessagerequest.py +18 -2
  150. orq_ai_sdk/moderations.py +218 -0
  151. orq_ai_sdk/orq_completions.py +666 -0
  152. orq_ai_sdk/orq_responses.py +398 -0
  153. orq_ai_sdk/prompts.py +28 -36
  154. orq_ai_sdk/rerank.py +330 -0
  155. orq_ai_sdk/router.py +89 -641
  156. orq_ai_sdk/sdk.py +3 -0
  157. orq_ai_sdk/speech.py +333 -0
  158. orq_ai_sdk/transcriptions.py +416 -0
  159. orq_ai_sdk/translations.py +384 -0
  160. orq_ai_sdk/utils/__init__.py +13 -1
  161. orq_ai_sdk/variations.py +364 -0
  162. {orq_ai_sdk-4.2.0rc28.dist-info → orq_ai_sdk-4.3.0rc7.dist-info}/METADATA +169 -148
  163. orq_ai_sdk-4.3.0rc7.dist-info/RECORD +263 -0
  164. {orq_ai_sdk-4.2.0rc28.dist-info → orq_ai_sdk-4.3.0rc7.dist-info}/WHEEL +2 -1
  165. orq_ai_sdk-4.3.0rc7.dist-info/top_level.txt +1 -0
  166. orq_ai_sdk-4.2.0rc28.dist-info/RECORD +0 -233
@@ -17,6 +17,14 @@ from .redactedreasoningpartschema import (
17
17
  )
18
18
  from .refusalpartschema import RefusalPartSchema, RefusalPartSchemaTypedDict
19
19
  from .textcontentpartschema import TextContentPartSchema, TextContentPartSchemaTypedDict
20
+ from .thinkingconfigdisabledschema import (
21
+ ThinkingConfigDisabledSchema,
22
+ ThinkingConfigDisabledSchemaTypedDict,
23
+ )
24
+ from .thinkingconfigenabledschema import (
25
+ ThinkingConfigEnabledSchema,
26
+ ThinkingConfigEnabledSchemaTypedDict,
27
+ )
20
28
  from orq_ai_sdk.types import (
21
29
  BaseModel,
22
30
  Nullable,
@@ -89,1284 +97,1348 @@ class CreatePromptMetadata(BaseModel):
89
97
 
90
98
  @model_serializer(mode="wrap")
91
99
  def serialize_model(self, handler):
92
- optional_fields = ["use_cases", "language"]
93
- nullable_fields = ["language"]
94
- null_default_fields = []
95
-
100
+ optional_fields = set(["use_cases", "language"])
101
+ nullable_fields = set(["language"])
96
102
  serialized = handler(self)
97
-
98
103
  m = {}
99
104
 
100
105
  for n, f in type(self).model_fields.items():
101
106
  k = f.alias or n
102
107
  val = serialized.get(k)
103
- serialized.pop(k, None)
104
-
105
- optional_nullable = k in optional_fields and k in nullable_fields
106
- is_set = (
107
- self.__pydantic_fields_set__.intersection({n})
108
- or k in null_default_fields
109
- ) # pylint: disable=no-member
110
-
111
- if val is not None and val != UNSET_SENTINEL:
112
- m[k] = val
113
- elif val != UNSET_SENTINEL and (
114
- not k in optional_fields or (optional_nullable and is_set)
115
- ):
116
- m[k] = val
108
+ is_nullable_and_explicitly_set = (
109
+ k in nullable_fields
110
+ and (self.__pydantic_fields_set__.intersection({n})) # pylint: disable=no-member
111
+ )
112
+
113
+ if val != UNSET_SENTINEL:
114
+ if (
115
+ val is not None
116
+ or k not in optional_fields
117
+ or is_nullable_and_explicitly_set
118
+ ):
119
+ m[k] = val
117
120
 
118
121
  return m
119
122
 
120
123
 
121
- CreatePromptRole = Literal[
122
- "system",
123
- "assistant",
124
- "user",
125
- "exception",
126
- "tool",
127
- "prompt",
128
- "correction",
129
- "expected_output",
130
- ]
131
- r"""The role of the prompt message"""
124
+ CreatePromptMessagesPromptsRequestRequestBodyRole = Literal["tool",]
125
+ r"""The role of the messages author, in this case tool."""
132
126
 
133
127
 
134
- CreatePrompt2PromptsRequestType = Literal["file",]
135
- r"""The type of the content part. Always `file`."""
128
+ CreatePromptContentPromptsRequest2TypedDict = TextContentPartSchemaTypedDict
136
129
 
137
130
 
138
- class CreatePrompt2FileTypedDict(TypedDict):
139
- file_data: NotRequired[str]
140
- r"""The file data as a data URI string in the format 'data:<mime-type>;base64,<base64-encoded-data>'. Example: '...'"""
141
- uri: NotRequired[str]
142
- r"""URL to the file. Only supported by Anthropic Claude models for PDF files."""
143
- mime_type: NotRequired[str]
144
- r"""MIME type of the file (e.g., application/pdf, image/png)"""
145
- filename: NotRequired[str]
146
- r"""The name of the file, used when passing the file to the model as a string."""
131
+ CreatePromptContentPromptsRequest2 = TextContentPartSchema
147
132
 
148
133
 
149
- class CreatePrompt2File(BaseModel):
150
- file_data: Optional[str] = None
151
- r"""The file data as a data URI string in the format 'data:<mime-type>;base64,<base64-encoded-data>'. Example: '...'"""
134
+ CreatePromptMessagesPromptsRequestRequestBodyContentTypedDict = TypeAliasType(
135
+ "CreatePromptMessagesPromptsRequestRequestBodyContentTypedDict",
136
+ Union[str, List[CreatePromptContentPromptsRequest2TypedDict]],
137
+ )
138
+ r"""The contents of the tool message."""
152
139
 
153
- uri: Optional[str] = None
154
- r"""URL to the file. Only supported by Anthropic Claude models for PDF files."""
155
140
 
156
- mime_type: Annotated[Optional[str], pydantic.Field(alias="mimeType")] = None
157
- r"""MIME type of the file (e.g., application/pdf, image/png)"""
141
+ CreatePromptMessagesPromptsRequestRequestBodyContent = TypeAliasType(
142
+ "CreatePromptMessagesPromptsRequestRequestBodyContent",
143
+ Union[str, List[CreatePromptContentPromptsRequest2]],
144
+ )
145
+ r"""The contents of the tool message."""
158
146
 
159
- filename: Optional[str] = None
160
- r"""The name of the file, used when passing the file to the model as a string."""
161
147
 
148
+ CreatePromptMessagesPromptsType = Literal["ephemeral",]
149
+ r"""Create a cache control breakpoint at this content block. Accepts only the value \"ephemeral\"."""
162
150
 
163
- class Two3TypedDict(TypedDict):
164
- type: CreatePrompt2PromptsRequestType
165
- r"""The type of the content part. Always `file`."""
166
- file: CreatePrompt2FileTypedDict
167
151
 
152
+ CreatePromptMessagesTTL = Literal[
153
+ "5m",
154
+ "1h",
155
+ ]
156
+ r"""The time-to-live for the cache control breakpoint. This may be one of the following values:
168
157
 
169
- class Two3(BaseModel):
170
- type: CreatePrompt2PromptsRequestType
171
- r"""The type of the content part. Always `file`."""
158
+ - `5m`: 5 minutes
159
+ - `1h`: 1 hour
172
160
 
173
- file: CreatePrompt2File
161
+ Defaults to `5m`. Only supported by `Anthropic` Claude models.
162
+ """
174
163
 
175
164
 
176
- CreatePrompt2PromptsType = Literal["image_url",]
165
+ class CreatePromptMessagesCacheControlTypedDict(TypedDict):
166
+ type: CreatePromptMessagesPromptsType
167
+ r"""Create a cache control breakpoint at this content block. Accepts only the value \"ephemeral\"."""
168
+ ttl: NotRequired[CreatePromptMessagesTTL]
169
+ r"""The time-to-live for the cache control breakpoint. This may be one of the following values:
177
170
 
171
+ - `5m`: 5 minutes
172
+ - `1h`: 1 hour
178
173
 
179
- class CreatePrompt2ImageURLTypedDict(TypedDict):
180
- url: str
181
- r"""Either a URL of the image or the base64 encoded data URI."""
182
- detail: NotRequired[str]
183
- r"""Specifies the detail level of the image. Currently only supported with OpenAI models"""
174
+ Defaults to `5m`. Only supported by `Anthropic` Claude models.
175
+ """
184
176
 
185
177
 
186
- class CreatePrompt2ImageURL(BaseModel):
187
- url: str
188
- r"""Either a URL of the image or the base64 encoded data URI."""
178
+ class CreatePromptMessagesCacheControl(BaseModel):
179
+ type: CreatePromptMessagesPromptsType
180
+ r"""Create a cache control breakpoint at this content block. Accepts only the value \"ephemeral\"."""
189
181
 
190
- detail: Optional[str] = None
191
- r"""Specifies the detail level of the image. Currently only supported with OpenAI models"""
182
+ ttl: Optional[CreatePromptMessagesTTL] = "5m"
183
+ r"""The time-to-live for the cache control breakpoint. This may be one of the following values:
192
184
 
185
+ - `5m`: 5 minutes
186
+ - `1h`: 1 hour
193
187
 
194
- class CreatePrompt22TypedDict(TypedDict):
195
- r"""The image part of the prompt message. Only supported with vision models."""
188
+ Defaults to `5m`. Only supported by `Anthropic` Claude models.
189
+ """
196
190
 
197
- type: CreatePrompt2PromptsType
198
- image_url: CreatePrompt2ImageURLTypedDict
191
+ @model_serializer(mode="wrap")
192
+ def serialize_model(self, handler):
193
+ optional_fields = set(["ttl"])
194
+ serialized = handler(self)
195
+ m = {}
199
196
 
197
+ for n, f in type(self).model_fields.items():
198
+ k = f.alias or n
199
+ val = serialized.get(k)
200
200
 
201
- class CreatePrompt22(BaseModel):
202
- r"""The image part of the prompt message. Only supported with vision models."""
201
+ if val != UNSET_SENTINEL:
202
+ if val is not None or k not in optional_fields:
203
+ m[k] = val
203
204
 
204
- type: CreatePrompt2PromptsType
205
+ return m
205
206
 
206
- image_url: CreatePrompt2ImageURL
207
207
 
208
+ class CreatePromptMessagesToolMessageTypedDict(TypedDict):
209
+ role: CreatePromptMessagesPromptsRequestRequestBodyRole
210
+ r"""The role of the messages author, in this case tool."""
211
+ content: CreatePromptMessagesPromptsRequestRequestBodyContentTypedDict
212
+ r"""The contents of the tool message."""
213
+ tool_call_id: Nullable[str]
214
+ r"""Tool call that this message is responding to."""
215
+ cache_control: NotRequired[CreatePromptMessagesCacheControlTypedDict]
208
216
 
209
- CreatePrompt2Type = Literal["text",]
210
217
 
218
+ class CreatePromptMessagesToolMessage(BaseModel):
219
+ role: CreatePromptMessagesPromptsRequestRequestBodyRole
220
+ r"""The role of the messages author, in this case tool."""
211
221
 
212
- class CreatePrompt21TypedDict(TypedDict):
213
- r"""Text content part of a prompt message"""
222
+ content: CreatePromptMessagesPromptsRequestRequestBodyContent
223
+ r"""The contents of the tool message."""
214
224
 
215
- type: CreatePrompt2Type
216
- text: str
225
+ tool_call_id: Nullable[str]
226
+ r"""Tool call that this message is responding to."""
217
227
 
228
+ cache_control: Optional[CreatePromptMessagesCacheControl] = None
218
229
 
219
- class CreatePrompt21(BaseModel):
220
- r"""Text content part of a prompt message"""
230
+ @model_serializer(mode="wrap")
231
+ def serialize_model(self, handler):
232
+ optional_fields = set(["cache_control"])
233
+ nullable_fields = set(["tool_call_id"])
234
+ serialized = handler(self)
235
+ m = {}
221
236
 
222
- type: CreatePrompt2Type
237
+ for n, f in type(self).model_fields.items():
238
+ k = f.alias or n
239
+ val = serialized.get(k)
240
+ is_nullable_and_explicitly_set = (
241
+ k in nullable_fields
242
+ and (self.__pydantic_fields_set__.intersection({n})) # pylint: disable=no-member
243
+ )
244
+
245
+ if val != UNSET_SENTINEL:
246
+ if (
247
+ val is not None
248
+ or k not in optional_fields
249
+ or is_nullable_and_explicitly_set
250
+ ):
251
+ m[k] = val
223
252
 
224
- text: str
253
+ return m
225
254
 
226
255
 
227
- CreatePromptContent2TypedDict = TypeAliasType(
228
- "CreatePromptContent2TypedDict",
229
- Union[CreatePrompt21TypedDict, CreatePrompt22TypedDict, Two3TypedDict],
256
+ CreatePromptContentPrompts2TypedDict = TypeAliasType(
257
+ "CreatePromptContentPrompts2TypedDict",
258
+ Union[
259
+ RefusalPartSchemaTypedDict,
260
+ RedactedReasoningPartSchemaTypedDict,
261
+ TextContentPartSchemaTypedDict,
262
+ ReasoningPartSchemaTypedDict,
263
+ ],
230
264
  )
231
265
 
232
266
 
233
- CreatePromptContent2 = Annotated[
267
+ CreatePromptContentPrompts2 = Annotated[
234
268
  Union[
235
- Annotated[CreatePrompt21, Tag("text")],
236
- Annotated[CreatePrompt22, Tag("image_url")],
237
- Annotated[Two3, Tag("file")],
269
+ Annotated[TextContentPartSchema, Tag("text")],
270
+ Annotated[RefusalPartSchema, Tag("refusal")],
271
+ Annotated[ReasoningPartSchema, Tag("reasoning")],
272
+ Annotated[RedactedReasoningPartSchema, Tag("redacted_reasoning")],
238
273
  ],
239
274
  Discriminator(lambda m: get_discriminator(m, "type", "type")),
240
275
  ]
241
276
 
242
277
 
243
- CreatePromptContentTypedDict = TypeAliasType(
244
- "CreatePromptContentTypedDict", Union[str, List[CreatePromptContent2TypedDict]]
278
+ CreatePromptMessagesPromptsRequestContentTypedDict = TypeAliasType(
279
+ "CreatePromptMessagesPromptsRequestContentTypedDict",
280
+ Union[str, List[CreatePromptContentPrompts2TypedDict]],
245
281
  )
246
- r"""The contents of the user message. Either the text content of the message or an array of content parts with a defined type, each can be of type `text` or `image_url` when passing in images. You can pass multiple images by adding multiple `image_url` content parts. Can be null for tool messages in certain scenarios."""
282
+ r"""The contents of the assistant message. Required unless `tool_calls` or `function_call` is specified."""
247
283
 
248
284
 
249
- CreatePromptContent = TypeAliasType(
250
- "CreatePromptContent", Union[str, List[CreatePromptContent2]]
285
+ CreatePromptMessagesPromptsRequestContent = TypeAliasType(
286
+ "CreatePromptMessagesPromptsRequestContent",
287
+ Union[str, List[CreatePromptContentPrompts2]],
251
288
  )
252
- r"""The contents of the user message. Either the text content of the message or an array of content parts with a defined type, each can be of type `text` or `image_url` when passing in images. You can pass multiple images by adding multiple `image_url` content parts. Can be null for tool messages in certain scenarios."""
289
+ r"""The contents of the assistant message. Required unless `tool_calls` or `function_call` is specified."""
253
290
 
254
291
 
255
- CreatePromptType = Literal["function",]
292
+ CreatePromptMessagesPromptsRequestRole = Literal["assistant",]
293
+ r"""The role of the messages author, in this case `assistant`."""
256
294
 
257
295
 
258
- class CreatePromptFunctionTypedDict(TypedDict):
259
- name: str
260
- arguments: str
261
- r"""JSON string arguments for the functions"""
296
+ class CreatePromptMessagesAudioTypedDict(TypedDict):
297
+ r"""Data about a previous audio response from the model."""
262
298
 
299
+ id: str
300
+ r"""Unique identifier for a previous audio response from the model."""
263
301
 
264
- class CreatePromptFunction(BaseModel):
265
- name: str
266
302
 
267
- arguments: str
268
- r"""JSON string arguments for the functions"""
303
+ class CreatePromptMessagesAudio(BaseModel):
304
+ r"""Data about a previous audio response from the model."""
269
305
 
306
+ id: str
307
+ r"""Unique identifier for a previous audio response from the model."""
270
308
 
271
- class CreatePromptToolCallsTypedDict(TypedDict):
272
- type: CreatePromptType
273
- function: CreatePromptFunctionTypedDict
274
- id: NotRequired[str]
275
- index: NotRequired[float]
309
+
310
+ CreatePromptMessagesType = Literal["function",]
311
+ r"""The type of the tool. Currently, only `function` is supported."""
276
312
 
277
313
 
278
- class CreatePromptToolCalls(BaseModel):
279
- type: CreatePromptType
314
+ class CreatePromptMessagesFunctionTypedDict(TypedDict):
315
+ name: NotRequired[str]
316
+ r"""The name of the function to call."""
317
+ arguments: NotRequired[str]
318
+ r"""The arguments to call the function with, as generated by the model in JSON format. Note that the model does not always generate valid JSON, and may hallucinate parameters not defined by your function schema. Validate the arguments in your code before calling your function."""
280
319
 
281
- function: CreatePromptFunction
282
320
 
283
- id: Optional[str] = None
321
+ class CreatePromptMessagesFunction(BaseModel):
322
+ name: Optional[str] = None
323
+ r"""The name of the function to call."""
284
324
 
285
- index: Optional[float] = None
325
+ arguments: Optional[str] = None
326
+ r"""The arguments to call the function with, as generated by the model in JSON format. Note that the model does not always generate valid JSON, and may hallucinate parameters not defined by your function schema. Validate the arguments in your code before calling your function."""
286
327
 
328
+ @model_serializer(mode="wrap")
329
+ def serialize_model(self, handler):
330
+ optional_fields = set(["name", "arguments"])
331
+ serialized = handler(self)
332
+ m = {}
287
333
 
288
- class CreatePromptMessagesTypedDict(TypedDict):
289
- role: CreatePromptRole
290
- r"""The role of the prompt message"""
291
- content: Nullable[CreatePromptContentTypedDict]
292
- r"""The contents of the user message. Either the text content of the message or an array of content parts with a defined type, each can be of type `text` or `image_url` when passing in images. You can pass multiple images by adding multiple `image_url` content parts. Can be null for tool messages in certain scenarios."""
293
- tool_calls: NotRequired[List[CreatePromptToolCallsTypedDict]]
294
- tool_call_id: NotRequired[Nullable[str]]
334
+ for n, f in type(self).model_fields.items():
335
+ k = f.alias or n
336
+ val = serialized.get(k)
295
337
 
338
+ if val != UNSET_SENTINEL:
339
+ if val is not None or k not in optional_fields:
340
+ m[k] = val
296
341
 
297
- class CreatePromptMessages(BaseModel):
298
- role: CreatePromptRole
299
- r"""The role of the prompt message"""
342
+ return m
300
343
 
301
- content: Nullable[CreatePromptContent]
302
- r"""The contents of the user message. Either the text content of the message or an array of content parts with a defined type, each can be of type `text` or `image_url` when passing in images. You can pass multiple images by adding multiple `image_url` content parts. Can be null for tool messages in certain scenarios."""
303
344
 
304
- tool_calls: Optional[List[CreatePromptToolCalls]] = None
345
+ class CreatePromptMessagesToolCallsTypedDict(TypedDict):
346
+ id: str
347
+ r"""The ID of the tool call."""
348
+ type: CreatePromptMessagesType
349
+ r"""The type of the tool. Currently, only `function` is supported."""
350
+ function: CreatePromptMessagesFunctionTypedDict
351
+ thought_signature: NotRequired[str]
352
+ r"""Encrypted representation of the model internal reasoning state during function calling. Required by Gemini 3 models when continuing a conversation after a tool call."""
305
353
 
306
- tool_call_id: OptionalNullable[str] = UNSET
354
+
355
+ class CreatePromptMessagesToolCalls(BaseModel):
356
+ id: str
357
+ r"""The ID of the tool call."""
358
+
359
+ type: CreatePromptMessagesType
360
+ r"""The type of the tool. Currently, only `function` is supported."""
361
+
362
+ function: CreatePromptMessagesFunction
363
+
364
+ thought_signature: Optional[str] = None
365
+ r"""Encrypted representation of the model internal reasoning state during function calling. Required by Gemini 3 models when continuing a conversation after a tool call."""
307
366
 
308
367
  @model_serializer(mode="wrap")
309
368
  def serialize_model(self, handler):
310
- optional_fields = ["tool_calls", "tool_call_id"]
311
- nullable_fields = ["content", "tool_call_id"]
312
- null_default_fields = []
313
-
369
+ optional_fields = set(["thought_signature"])
314
370
  serialized = handler(self)
315
-
316
371
  m = {}
317
372
 
318
373
  for n, f in type(self).model_fields.items():
319
374
  k = f.alias or n
320
375
  val = serialized.get(k)
321
- serialized.pop(k, None)
322
-
323
- optional_nullable = k in optional_fields and k in nullable_fields
324
- is_set = (
325
- self.__pydantic_fields_set__.intersection({n})
326
- or k in null_default_fields
327
- ) # pylint: disable=no-member
328
376
 
329
- if val is not None and val != UNSET_SENTINEL:
330
- m[k] = val
331
- elif val != UNSET_SENTINEL and (
332
- not k in optional_fields or (optional_nullable and is_set)
333
- ):
334
- m[k] = val
377
+ if val != UNSET_SENTINEL:
378
+ if val is not None or k not in optional_fields:
379
+ m[k] = val
335
380
 
336
381
  return m
337
382
 
338
383
 
339
- CreatePromptFormat = Literal[
340
- "url",
341
- "b64_json",
342
- "text",
343
- "json_object",
344
- ]
345
- r"""Only supported on `image` models."""
384
+ class CreatePromptMessagesAssistantMessageTypedDict(TypedDict):
385
+ role: CreatePromptMessagesPromptsRequestRole
386
+ r"""The role of the messages author, in this case `assistant`."""
387
+ content: NotRequired[Nullable[CreatePromptMessagesPromptsRequestContentTypedDict]]
388
+ r"""The contents of the assistant message. Required unless `tool_calls` or `function_call` is specified."""
389
+ refusal: NotRequired[Nullable[str]]
390
+ r"""The refusal message by the assistant."""
391
+ name: NotRequired[str]
392
+ r"""An optional name for the participant. Provides the model information to differentiate between participants of the same role."""
393
+ audio: NotRequired[Nullable[CreatePromptMessagesAudioTypedDict]]
394
+ r"""Data about a previous audio response from the model."""
395
+ tool_calls: NotRequired[List[CreatePromptMessagesToolCallsTypedDict]]
396
+ r"""The tool calls generated by the model, such as function calls."""
346
397
 
347
398
 
348
- Six = Literal[
349
- "json",
350
- "text",
351
- "srt",
352
- "verbose_json",
353
- "vtt",
354
- ]
399
+ class CreatePromptMessagesAssistantMessage(BaseModel):
400
+ role: CreatePromptMessagesPromptsRequestRole
401
+ r"""The role of the messages author, in this case `assistant`."""
355
402
 
403
+ content: OptionalNullable[CreatePromptMessagesPromptsRequestContent] = UNSET
404
+ r"""The contents of the assistant message. Required unless `tool_calls` or `function_call` is specified."""
356
405
 
357
- Five = Literal[
358
- "url",
359
- "base64_json",
360
- ]
406
+ refusal: OptionalNullable[str] = UNSET
407
+ r"""The refusal message by the assistant."""
361
408
 
409
+ name: Optional[str] = None
410
+ r"""An optional name for the participant. Provides the model information to differentiate between participants of the same role."""
362
411
 
363
- ResponseFormat4 = Literal[
364
- "mp3",
365
- "opus",
366
- "aac",
367
- "flac",
368
- "wav",
369
- "pcm",
370
- ]
412
+ audio: OptionalNullable[CreatePromptMessagesAudio] = UNSET
413
+ r"""Data about a previous audio response from the model."""
371
414
 
415
+ tool_calls: Optional[List[CreatePromptMessagesToolCalls]] = None
416
+ r"""The tool calls generated by the model, such as function calls."""
372
417
 
373
- CreatePromptResponseFormatPromptsRequestType = Literal["text",]
418
+ @model_serializer(mode="wrap")
419
+ def serialize_model(self, handler):
420
+ optional_fields = set(["content", "refusal", "name", "audio", "tool_calls"])
421
+ nullable_fields = set(["content", "refusal", "audio"])
422
+ serialized = handler(self)
423
+ m = {}
374
424
 
425
+ for n, f in type(self).model_fields.items():
426
+ k = f.alias or n
427
+ val = serialized.get(k)
428
+ is_nullable_and_explicitly_set = (
429
+ k in nullable_fields
430
+ and (self.__pydantic_fields_set__.intersection({n})) # pylint: disable=no-member
431
+ )
432
+
433
+ if val != UNSET_SENTINEL:
434
+ if (
435
+ val is not None
436
+ or k not in optional_fields
437
+ or is_nullable_and_explicitly_set
438
+ ):
439
+ m[k] = val
375
440
 
376
- class ResponseFormat3TypedDict(TypedDict):
377
- type: CreatePromptResponseFormatPromptsRequestType
441
+ return m
378
442
 
379
443
 
380
- class ResponseFormat3(BaseModel):
381
- type: CreatePromptResponseFormatPromptsRequestType
444
+ CreatePromptMessagesPromptsRole = Literal["user",]
445
+ r"""The role of the messages author, in this case `user`."""
382
446
 
383
447
 
384
- CreatePromptResponseFormatPromptsType = Literal["json_object",]
448
+ CreatePrompt2Type = Literal["file",]
449
+ r"""The type of the content part. Always `file`."""
385
450
 
386
451
 
387
- class ResponseFormat2TypedDict(TypedDict):
388
- type: CreatePromptResponseFormatPromptsType
452
+ CreatePrompt2PromptsType = Literal["ephemeral",]
453
+ r"""Create a cache control breakpoint at this content block. Accepts only the value \"ephemeral\"."""
389
454
 
390
455
 
391
- class ResponseFormat2(BaseModel):
392
- type: CreatePromptResponseFormatPromptsType
456
+ CreatePrompt2TTL = Literal[
457
+ "5m",
458
+ "1h",
459
+ ]
460
+ r"""The time-to-live for the cache control breakpoint. This may be one of the following values:
393
461
 
462
+ - `5m`: 5 minutes
463
+ - `1h`: 1 hour
394
464
 
395
- CreatePromptResponseFormatType = Literal["json_schema",]
465
+ Defaults to `5m`. Only supported by `Anthropic` Claude models.
466
+ """
396
467
 
397
468
 
398
- class CreatePromptResponseFormatJSONSchemaTypedDict(TypedDict):
399
- name: str
400
- schema_: Dict[str, Any]
401
- description: NotRequired[str]
402
- strict: NotRequired[bool]
469
+ class CreatePrompt2CacheControlTypedDict(TypedDict):
470
+ type: CreatePrompt2PromptsType
471
+ r"""Create a cache control breakpoint at this content block. Accepts only the value \"ephemeral\"."""
472
+ ttl: NotRequired[CreatePrompt2TTL]
473
+ r"""The time-to-live for the cache control breakpoint. This may be one of the following values:
403
474
 
475
+ - `5m`: 5 minutes
476
+ - `1h`: 1 hour
404
477
 
405
- class CreatePromptResponseFormatJSONSchema(BaseModel):
406
- name: str
478
+ Defaults to `5m`. Only supported by `Anthropic` Claude models.
479
+ """
407
480
 
408
- schema_: Annotated[Dict[str, Any], pydantic.Field(alias="schema")]
409
481
 
410
- description: Optional[str] = None
482
+ class CreatePrompt2CacheControl(BaseModel):
483
+ type: CreatePrompt2PromptsType
484
+ r"""Create a cache control breakpoint at this content block. Accepts only the value \"ephemeral\"."""
411
485
 
412
- strict: Optional[bool] = None
486
+ ttl: Optional[CreatePrompt2TTL] = "5m"
487
+ r"""The time-to-live for the cache control breakpoint. This may be one of the following values:
413
488
 
489
+ - `5m`: 5 minutes
490
+ - `1h`: 1 hour
414
491
 
415
- class ResponseFormat1TypedDict(TypedDict):
416
- type: CreatePromptResponseFormatType
417
- json_schema: CreatePromptResponseFormatJSONSchemaTypedDict
418
- display_name: NotRequired[str]
492
+ Defaults to `5m`. Only supported by `Anthropic` Claude models.
493
+ """
419
494
 
495
+ @model_serializer(mode="wrap")
496
+ def serialize_model(self, handler):
497
+ optional_fields = set(["ttl"])
498
+ serialized = handler(self)
499
+ m = {}
420
500
 
421
- class ResponseFormat1(BaseModel):
422
- type: CreatePromptResponseFormatType
501
+ for n, f in type(self).model_fields.items():
502
+ k = f.alias or n
503
+ val = serialized.get(k)
423
504
 
424
- json_schema: CreatePromptResponseFormatJSONSchema
505
+ if val != UNSET_SENTINEL:
506
+ if val is not None or k not in optional_fields:
507
+ m[k] = val
425
508
 
426
- display_name: Optional[str] = None
509
+ return m
427
510
 
428
511
 
429
- CreatePromptResponseFormatTypedDict = TypeAliasType(
430
- "CreatePromptResponseFormatTypedDict",
431
- Union[
432
- ResponseFormat2TypedDict,
433
- ResponseFormat3TypedDict,
434
- ResponseFormat1TypedDict,
435
- ResponseFormat4,
436
- Five,
437
- Six,
438
- ],
439
- )
440
- r"""An object specifying the format that the model must output.
512
+ class CreatePrompt24TypedDict(TypedDict):
513
+ type: CreatePrompt2Type
514
+ r"""The type of the content part. Always `file`."""
515
+ file: FileContentPartSchemaTypedDict
516
+ r"""File data for the content part. Must contain either file_data or uri, but not both."""
517
+ cache_control: NotRequired[CreatePrompt2CacheControlTypedDict]
441
518
 
442
- Setting to `{ \"type\": \"json_schema\", \"json_schema\": {...} }` enables Structured Outputs which ensures the model will match your supplied JSON schema
443
519
 
444
- Setting to `{ \"type\": \"json_object\" }` enables JSON mode, which ensures the message the model generates is valid JSON.
520
+ class CreatePrompt24(BaseModel):
521
+ type: CreatePrompt2Type
522
+ r"""The type of the content part. Always `file`."""
445
523
 
446
- Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly \"stuck\" request. Also note that the message content may be partially cut off if finish_reason=\"length\", which indicates the generation exceeded max_tokens or the conversation exceeded the max context length.
447
- """
524
+ file: FileContentPartSchema
525
+ r"""File data for the content part. Must contain either file_data or uri, but not both."""
526
+
527
+ cache_control: Optional[CreatePrompt2CacheControl] = None
528
+
529
+ @model_serializer(mode="wrap")
530
+ def serialize_model(self, handler):
531
+ optional_fields = set(["cache_control"])
532
+ serialized = handler(self)
533
+ m = {}
534
+
535
+ for n, f in type(self).model_fields.items():
536
+ k = f.alias or n
537
+ val = serialized.get(k)
538
+
539
+ if val != UNSET_SENTINEL:
540
+ if val is not None or k not in optional_fields:
541
+ m[k] = val
542
+
543
+ return m
448
544
 
449
545
 
450
- CreatePromptResponseFormat = TypeAliasType(
451
- "CreatePromptResponseFormat",
546
+ CreatePromptContent2TypedDict = TypeAliasType(
547
+ "CreatePromptContent2TypedDict",
452
548
  Union[
453
- ResponseFormat2, ResponseFormat3, ResponseFormat1, ResponseFormat4, Five, Six
549
+ AudioContentPartSchemaTypedDict,
550
+ TextContentPartSchemaTypedDict,
551
+ ImageContentPartSchemaTypedDict,
552
+ CreatePrompt24TypedDict,
454
553
  ],
455
554
  )
456
- r"""An object specifying the format that the model must output.
457
555
 
458
- Setting to `{ \"type\": \"json_schema\", \"json_schema\": {...} }` enables Structured Outputs which ensures the model will match your supplied JSON schema
459
556
 
460
- Setting to `{ \"type\": \"json_object\" }` enables JSON mode, which ensures the message the model generates is valid JSON.
557
+ CreatePromptContent2 = Annotated[
558
+ Union[
559
+ Annotated[TextContentPartSchema, Tag("text")],
560
+ Annotated[ImageContentPartSchema, Tag("image_url")],
561
+ Annotated[AudioContentPartSchema, Tag("input_audio")],
562
+ Annotated[CreatePrompt24, Tag("file")],
563
+ ],
564
+ Discriminator(lambda m: get_discriminator(m, "type", "type")),
565
+ ]
461
566
 
462
- Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly \"stuck\" request. Also note that the message content may be partially cut off if finish_reason=\"length\", which indicates the generation exceeded max_tokens or the conversation exceeded the max context length.
463
- """
464
567
 
568
+ CreatePromptMessagesPromptsContentTypedDict = TypeAliasType(
569
+ "CreatePromptMessagesPromptsContentTypedDict",
570
+ Union[str, List[CreatePromptContent2TypedDict]],
571
+ )
572
+ r"""The contents of the user message."""
465
573
 
466
- PhotoRealVersion = Literal[
467
- "v1",
468
- "v2",
469
- ]
470
- r"""The version of photoReal to use. Must be v1 or v2. Only available for `leonardoai` provider"""
471
574
 
575
+ CreatePromptMessagesPromptsContent = TypeAliasType(
576
+ "CreatePromptMessagesPromptsContent", Union[str, List[CreatePromptContent2]]
577
+ )
578
+ r"""The contents of the user message."""
472
579
 
473
- EncodingFormat = Literal[
474
- "float",
475
- "base64",
476
- ]
477
- r"""The format to return the embeddings"""
478
580
 
581
+ class CreatePromptMessagesUserMessageTypedDict(TypedDict):
582
+ role: CreatePromptMessagesPromptsRole
583
+ r"""The role of the messages author, in this case `user`."""
584
+ content: CreatePromptMessagesPromptsContentTypedDict
585
+ r"""The contents of the user message."""
586
+ name: NotRequired[str]
587
+ r"""An optional name for the participant. Provides the model information to differentiate between participants of the same role."""
479
588
 
480
- CreatePromptReasoningEffort = Literal[
481
- "none",
482
- "disable",
483
- "minimal",
484
- "low",
485
- "medium",
486
- "high",
487
- ]
488
- r"""Constrains effort on reasoning for reasoning models. Reducing reasoning effort can result in faster responses and fewer tokens used on reasoning in a response."""
489
589
 
590
+ class CreatePromptMessagesUserMessage(BaseModel):
591
+ role: CreatePromptMessagesPromptsRole
592
+ r"""The role of the messages author, in this case `user`."""
490
593
 
491
- Verbosity = Literal[
492
- "low",
493
- "medium",
494
- "high",
495
- ]
496
- r"""Controls the verbosity of the model output."""
594
+ content: CreatePromptMessagesPromptsContent
595
+ r"""The contents of the user message."""
497
596
 
597
+ name: Optional[str] = None
598
+ r"""An optional name for the participant. Provides the model information to differentiate between participants of the same role."""
498
599
 
499
- CreatePromptThinkingLevel = Literal[
500
- "low",
501
- "high",
502
- ]
503
- r"""The level of thinking to use for the model. Only supported by `Google AI`"""
600
+ @model_serializer(mode="wrap")
601
+ def serialize_model(self, handler):
602
+ optional_fields = set(["name"])
603
+ serialized = handler(self)
604
+ m = {}
504
605
 
606
+ for n, f in type(self).model_fields.items():
607
+ k = f.alias or n
608
+ val = serialized.get(k)
505
609
 
506
- class ModelParametersTypedDict(TypedDict):
507
- r"""Optional model parameters like temperature and maxTokens."""
610
+ if val != UNSET_SENTINEL:
611
+ if val is not None or k not in optional_fields:
612
+ m[k] = val
508
613
 
509
- temperature: NotRequired[float]
510
- r"""Only supported on `chat` and `completion` models."""
511
- max_tokens: NotRequired[float]
512
- r"""Only supported on `chat` and `completion` models."""
513
- top_k: NotRequired[float]
514
- r"""Only supported on `chat` and `completion` models."""
515
- top_p: NotRequired[float]
516
- r"""Only supported on `chat` and `completion` models."""
517
- frequency_penalty: NotRequired[float]
518
- r"""Only supported on `chat` and `completion` models."""
519
- presence_penalty: NotRequired[float]
520
- r"""Only supported on `chat` and `completion` models."""
521
- num_images: NotRequired[float]
522
- r"""Only supported on `image` models."""
523
- seed: NotRequired[float]
524
- r"""Best effort deterministic seed for the model. Currently only OpenAI models support these"""
525
- format_: NotRequired[CreatePromptFormat]
526
- r"""Only supported on `image` models."""
527
- dimensions: NotRequired[str]
528
- r"""Only supported on `image` models."""
529
- quality: NotRequired[str]
530
- r"""Only supported on `image` models."""
531
- style: NotRequired[str]
532
- r"""Only supported on `image` models."""
533
- response_format: NotRequired[Nullable[CreatePromptResponseFormatTypedDict]]
534
- r"""An object specifying the format that the model must output.
614
+ return m
535
615
 
536
- Setting to `{ \"type\": \"json_schema\", \"json_schema\": {...} }` enables Structured Outputs which ensures the model will match your supplied JSON schema
537
616
 
538
- Setting to `{ \"type\": \"json_object\" }` enables JSON mode, which ensures the message the model generates is valid JSON.
617
+ CreatePromptMessagesRole = Literal["system",]
618
+ r"""The role of the messages author, in this case `system`."""
539
619
 
540
- Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly \"stuck\" request. Also note that the message content may be partially cut off if finish_reason=\"length\", which indicates the generation exceeded max_tokens or the conversation exceeded the max context length.
541
- """
542
- photo_real_version: NotRequired[PhotoRealVersion]
543
- r"""The version of photoReal to use. Must be v1 or v2. Only available for `leonardoai` provider"""
544
- encoding_format: NotRequired[EncodingFormat]
545
- r"""The format to return the embeddings"""
546
- reasoning_effort: NotRequired[CreatePromptReasoningEffort]
547
- r"""Constrains effort on reasoning for reasoning models. Reducing reasoning effort can result in faster responses and fewer tokens used on reasoning in a response."""
548
- budget_tokens: NotRequired[float]
549
- r"""Gives the model enhanced reasoning capabilities for complex tasks. A value of 0 disables thinking. The minimum budget tokens for thinking are 1024. The Budget Tokens should never exceed the Max Tokens parameter. Only supported by `Anthropic`"""
550
- verbosity: NotRequired[Verbosity]
551
- r"""Controls the verbosity of the model output."""
552
- thinking_level: NotRequired[CreatePromptThinkingLevel]
553
- r"""The level of thinking to use for the model. Only supported by `Google AI`"""
554
-
555
-
556
- class ModelParameters(BaseModel):
557
- r"""Optional model parameters like temperature and maxTokens."""
558
-
559
- temperature: Optional[float] = None
560
- r"""Only supported on `chat` and `completion` models."""
561
-
562
- max_tokens: Annotated[Optional[float], pydantic.Field(alias="maxTokens")] = None
563
- r"""Only supported on `chat` and `completion` models."""
564
-
565
- top_k: Annotated[Optional[float], pydantic.Field(alias="topK")] = None
566
- r"""Only supported on `chat` and `completion` models."""
567
-
568
- top_p: Annotated[Optional[float], pydantic.Field(alias="topP")] = None
569
- r"""Only supported on `chat` and `completion` models."""
570
-
571
- frequency_penalty: Annotated[
572
- Optional[float], pydantic.Field(alias="frequencyPenalty")
573
- ] = None
574
- r"""Only supported on `chat` and `completion` models."""
575
-
576
- presence_penalty: Annotated[
577
- Optional[float], pydantic.Field(alias="presencePenalty")
578
- ] = None
579
- r"""Only supported on `chat` and `completion` models."""
580
-
581
- num_images: Annotated[Optional[float], pydantic.Field(alias="numImages")] = None
582
- r"""Only supported on `image` models."""
583
-
584
- seed: Optional[float] = None
585
- r"""Best effort deterministic seed for the model. Currently only OpenAI models support these"""
586
-
587
- format_: Annotated[Optional[CreatePromptFormat], pydantic.Field(alias="format")] = (
588
- None
589
- )
590
- r"""Only supported on `image` models."""
591
-
592
- dimensions: Optional[str] = None
593
- r"""Only supported on `image` models."""
594
620
 
595
- quality: Optional[str] = None
596
- r"""Only supported on `image` models."""
597
-
598
- style: Optional[str] = None
599
- r"""Only supported on `image` models."""
621
+ CreatePromptMessagesContentTypedDict = TypeAliasType(
622
+ "CreatePromptMessagesContentTypedDict",
623
+ Union[str, List[TextContentPartSchemaTypedDict]],
624
+ )
625
+ r"""The contents of the system message."""
600
626
 
601
- response_format: Annotated[
602
- OptionalNullable[CreatePromptResponseFormat],
603
- pydantic.Field(alias="responseFormat"),
604
- ] = UNSET
605
- r"""An object specifying the format that the model must output.
606
627
 
607
- Setting to `{ \"type\": \"json_schema\", \"json_schema\": {...} }` enables Structured Outputs which ensures the model will match your supplied JSON schema
628
+ CreatePromptMessagesContent = TypeAliasType(
629
+ "CreatePromptMessagesContent", Union[str, List[TextContentPartSchema]]
630
+ )
631
+ r"""The contents of the system message."""
608
632
 
609
- Setting to `{ \"type\": \"json_object\" }` enables JSON mode, which ensures the message the model generates is valid JSON.
610
633
 
611
- Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly \"stuck\" request. Also note that the message content may be partially cut off if finish_reason=\"length\", which indicates the generation exceeded max_tokens or the conversation exceeded the max context length.
612
- """
634
+ class CreatePromptMessagesSystemMessageTypedDict(TypedDict):
635
+ r"""Developer-provided instructions that the model should follow, regardless of messages sent by the user."""
613
636
 
614
- photo_real_version: Annotated[
615
- Optional[PhotoRealVersion], pydantic.Field(alias="photoRealVersion")
616
- ] = None
617
- r"""The version of photoReal to use. Must be v1 or v2. Only available for `leonardoai` provider"""
637
+ role: CreatePromptMessagesRole
638
+ r"""The role of the messages author, in this case `system`."""
639
+ content: CreatePromptMessagesContentTypedDict
640
+ r"""The contents of the system message."""
641
+ name: NotRequired[str]
642
+ r"""An optional name for the participant. Provides the model information to differentiate between participants of the same role."""
618
643
 
619
- encoding_format: Optional[EncodingFormat] = None
620
- r"""The format to return the embeddings"""
621
644
 
622
- reasoning_effort: Annotated[
623
- Optional[CreatePromptReasoningEffort], pydantic.Field(alias="reasoningEffort")
624
- ] = None
625
- r"""Constrains effort on reasoning for reasoning models. Reducing reasoning effort can result in faster responses and fewer tokens used on reasoning in a response."""
645
+ class CreatePromptMessagesSystemMessage(BaseModel):
646
+ r"""Developer-provided instructions that the model should follow, regardless of messages sent by the user."""
626
647
 
627
- budget_tokens: Annotated[Optional[float], pydantic.Field(alias="budgetTokens")] = (
628
- None
629
- )
630
- r"""Gives the model enhanced reasoning capabilities for complex tasks. A value of 0 disables thinking. The minimum budget tokens for thinking are 1024. The Budget Tokens should never exceed the Max Tokens parameter. Only supported by `Anthropic`"""
648
+ role: CreatePromptMessagesRole
649
+ r"""The role of the messages author, in this case `system`."""
631
650
 
632
- verbosity: Optional[Verbosity] = None
633
- r"""Controls the verbosity of the model output."""
651
+ content: CreatePromptMessagesContent
652
+ r"""The contents of the system message."""
634
653
 
635
- thinking_level: Annotated[
636
- Optional[CreatePromptThinkingLevel], pydantic.Field(alias="thinkingLevel")
637
- ] = None
638
- r"""The level of thinking to use for the model. Only supported by `Google AI`"""
654
+ name: Optional[str] = None
655
+ r"""An optional name for the participant. Provides the model information to differentiate between participants of the same role."""
639
656
 
640
657
  @model_serializer(mode="wrap")
641
658
  def serialize_model(self, handler):
642
- optional_fields = [
643
- "temperature",
644
- "maxTokens",
645
- "topK",
646
- "topP",
647
- "frequencyPenalty",
648
- "presencePenalty",
649
- "numImages",
650
- "seed",
651
- "format",
652
- "dimensions",
653
- "quality",
654
- "style",
655
- "responseFormat",
656
- "photoRealVersion",
657
- "encoding_format",
658
- "reasoningEffort",
659
- "budgetTokens",
660
- "verbosity",
661
- "thinkingLevel",
662
- ]
663
- nullable_fields = ["responseFormat"]
664
- null_default_fields = []
665
-
659
+ optional_fields = set(["name"])
666
660
  serialized = handler(self)
667
-
668
661
  m = {}
669
662
 
670
663
  for n, f in type(self).model_fields.items():
671
664
  k = f.alias or n
672
665
  val = serialized.get(k)
673
- serialized.pop(k, None)
674
666
 
675
- optional_nullable = k in optional_fields and k in nullable_fields
676
- is_set = (
677
- self.__pydantic_fields_set__.intersection({n})
678
- or k in null_default_fields
679
- ) # pylint: disable=no-member
680
-
681
- if val is not None and val != UNSET_SENTINEL:
682
- m[k] = val
683
- elif val != UNSET_SENTINEL and (
684
- not k in optional_fields or (optional_nullable and is_set)
685
- ):
686
- m[k] = val
667
+ if val != UNSET_SENTINEL:
668
+ if val is not None or k not in optional_fields:
669
+ m[k] = val
687
670
 
688
671
  return m
689
672
 
690
673
 
691
- @deprecated(
692
- "warning: ** DEPRECATED ** - This will be removed in a future release, please migrate away from it as soon as possible."
674
+ CreatePromptMessagesTypedDict = TypeAliasType(
675
+ "CreatePromptMessagesTypedDict",
676
+ Union[
677
+ CreatePromptMessagesSystemMessageTypedDict,
678
+ CreatePromptMessagesUserMessageTypedDict,
679
+ CreatePromptMessagesToolMessageTypedDict,
680
+ CreatePromptMessagesAssistantMessageTypedDict,
681
+ ],
693
682
  )
694
- class PromptConfigurationTypedDict(TypedDict):
695
- r"""[DEPRECATED]. Please use the `prompt` property instead. The current `prompt_config` will keep working but it will be deprecated in future versions. Configuration for the prompt including model and messages."""
696
683
 
697
- messages: List[CreatePromptMessagesTypedDict]
698
- r"""Array of messages that make up the conversation."""
699
- model: NotRequired[str]
700
- r"""Model ID used to generate the response, like `openai/gpt-4o` or `google/gemini-2.5-pro`. The full list of models can be found at https://docs.orq.ai/docs/ai-gateway-supported-models. Only chat models are supported."""
701
- model_parameters: NotRequired[ModelParametersTypedDict]
702
- r"""Optional model parameters like temperature and maxTokens."""
703
684
 
685
+ CreatePromptMessages = Annotated[
686
+ Union[
687
+ Annotated[CreatePromptMessagesSystemMessage, Tag("system")],
688
+ Annotated[CreatePromptMessagesUserMessage, Tag("user")],
689
+ Annotated[CreatePromptMessagesAssistantMessage, Tag("assistant")],
690
+ Annotated[CreatePromptMessagesToolMessage, Tag("tool")],
691
+ ],
692
+ Discriminator(lambda m: get_discriminator(m, "role", "role")),
693
+ ]
704
694
 
705
- @deprecated(
706
- "warning: ** DEPRECATED ** - This will be removed in a future release, please migrate away from it as soon as possible."
707
- )
708
- class PromptConfiguration(BaseModel):
709
- r"""[DEPRECATED]. Please use the `prompt` property instead. The current `prompt_config` will keep working but it will be deprecated in future versions. Configuration for the prompt including model and messages."""
710
695
 
711
- messages: List[CreatePromptMessages]
712
- r"""Array of messages that make up the conversation."""
696
+ CreatePromptVoice = Literal[
697
+ "alloy",
698
+ "echo",
699
+ "fable",
700
+ "onyx",
701
+ "nova",
702
+ "shimmer",
703
+ ]
704
+ r"""The voice the model uses to respond. Supported voices are alloy, echo, fable, onyx, nova, and shimmer."""
713
705
 
714
- model: Optional[str] = None
715
- r"""Model ID used to generate the response, like `openai/gpt-4o` or `google/gemini-2.5-pro`. The full list of models can be found at https://docs.orq.ai/docs/ai-gateway-supported-models. Only chat models are supported."""
716
706
 
717
- model_parameters: Optional[ModelParameters] = None
718
- r"""Optional model parameters like temperature and maxTokens."""
707
+ CreatePromptFormat = Literal[
708
+ "wav",
709
+ "mp3",
710
+ "flac",
711
+ "opus",
712
+ "pcm16",
713
+ ]
714
+ r"""Specifies the output audio format. Must be one of wav, mp3, flac, opus, or pcm16."""
719
715
 
720
716
 
721
- CreatePromptMessagesPromptsRequestRequestBodyRole = Literal["tool",]
722
- r"""The role of the messages author, in this case tool."""
717
+ class CreatePromptAudioTypedDict(TypedDict):
718
+ r"""Parameters for audio output. Required when audio output is requested with modalities: [\"audio\"]. Learn more."""
723
719
 
720
+ voice: CreatePromptVoice
721
+ r"""The voice the model uses to respond. Supported voices are alloy, echo, fable, onyx, nova, and shimmer."""
722
+ format_: CreatePromptFormat
723
+ r"""Specifies the output audio format. Must be one of wav, mp3, flac, opus, or pcm16."""
724
724
 
725
- CreatePromptContentPromptsRequestRequestBody2TypedDict = TextContentPartSchemaTypedDict
726
725
 
726
+ class CreatePromptAudio(BaseModel):
727
+ r"""Parameters for audio output. Required when audio output is requested with modalities: [\"audio\"]. Learn more."""
727
728
 
728
- CreatePromptContentPromptsRequestRequestBody2 = TextContentPartSchema
729
+ voice: CreatePromptVoice
730
+ r"""The voice the model uses to respond. Supported voices are alloy, echo, fable, onyx, nova, and shimmer."""
729
731
 
732
+ format_: Annotated[CreatePromptFormat, pydantic.Field(alias="format")]
733
+ r"""Specifies the output audio format. Must be one of wav, mp3, flac, opus, or pcm16."""
730
734
 
731
- CreatePromptMessagesPromptsRequestRequestBodyContentTypedDict = TypeAliasType(
732
- "CreatePromptMessagesPromptsRequestRequestBodyContentTypedDict",
733
- Union[str, List[CreatePromptContentPromptsRequestRequestBody2TypedDict]],
734
- )
735
- r"""The contents of the tool message."""
736
735
 
736
+ CreatePromptResponseFormatPromptsRequestType = Literal["json_schema",]
737
737
 
738
- CreatePromptMessagesPromptsRequestRequestBodyContent = TypeAliasType(
739
- "CreatePromptMessagesPromptsRequestRequestBodyContent",
740
- Union[str, List[CreatePromptContentPromptsRequestRequestBody2]],
741
- )
742
- r"""The contents of the tool message."""
743
738
 
739
+ class CreatePromptResponseFormatPromptsJSONSchemaTypedDict(TypedDict):
740
+ name: str
741
+ r"""The name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64."""
742
+ description: NotRequired[str]
743
+ r"""A description of what the response format is for, used by the model to determine how to respond in the format."""
744
+ schema_: NotRequired[Any]
745
+ r"""The schema for the response format, described as a JSON Schema object."""
746
+ strict: NotRequired[bool]
747
+ r"""Whether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the schema field. Only a subset of JSON Schema is supported when strict is true."""
744
748
 
745
- CreatePromptMessagesPromptsType = Literal["ephemeral",]
746
- r"""Create a cache control breakpoint at this content block. Accepts only the value \"ephemeral\"."""
747
749
 
750
+ class CreatePromptResponseFormatPromptsJSONSchema(BaseModel):
751
+ name: str
752
+ r"""The name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64."""
748
753
 
749
- CreatePromptMessagesTTL = Literal[
750
- "5m",
751
- "1h",
752
- ]
753
- r"""The time-to-live for the cache control breakpoint. This may be one of the following values:
754
+ description: Optional[str] = None
755
+ r"""A description of what the response format is for, used by the model to determine how to respond in the format."""
754
756
 
755
- - `5m`: 5 minutes
756
- - `1h`: 1 hour
757
+ schema_: Annotated[Optional[Any], pydantic.Field(alias="schema")] = None
758
+ r"""The schema for the response format, described as a JSON Schema object."""
757
759
 
758
- Defaults to `5m`. Only supported by `Anthropic` Claude models.
759
- """
760
+ strict: Optional[bool] = False
761
+ r"""Whether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the schema field. Only a subset of JSON Schema is supported when strict is true."""
760
762
 
763
+ @model_serializer(mode="wrap")
764
+ def serialize_model(self, handler):
765
+ optional_fields = set(["description", "schema", "strict"])
766
+ serialized = handler(self)
767
+ m = {}
761
768
 
762
- class CreatePromptMessagesCacheControlTypedDict(TypedDict):
763
- type: CreatePromptMessagesPromptsType
764
- r"""Create a cache control breakpoint at this content block. Accepts only the value \"ephemeral\"."""
765
- ttl: NotRequired[CreatePromptMessagesTTL]
766
- r"""The time-to-live for the cache control breakpoint. This may be one of the following values:
769
+ for n, f in type(self).model_fields.items():
770
+ k = f.alias or n
771
+ val = serialized.get(k)
767
772
 
768
- - `5m`: 5 minutes
769
- - `1h`: 1 hour
773
+ if val != UNSET_SENTINEL:
774
+ if val is not None or k not in optional_fields:
775
+ m[k] = val
770
776
 
771
- Defaults to `5m`. Only supported by `Anthropic` Claude models.
772
- """
777
+ return m
773
778
 
774
779
 
775
- class CreatePromptMessagesCacheControl(BaseModel):
776
- type: CreatePromptMessagesPromptsType
777
- r"""Create a cache control breakpoint at this content block. Accepts only the value \"ephemeral\"."""
780
+ class CreatePromptResponseFormatJSONSchemaTypedDict(TypedDict):
781
+ r"""
778
782
 
779
- ttl: Optional[CreatePromptMessagesTTL] = "5m"
780
- r"""The time-to-live for the cache control breakpoint. This may be one of the following values:
783
+ JSON Schema response format. Used to generate structured JSON responses
784
+ """
781
785
 
782
- - `5m`: 5 minutes
783
- - `1h`: 1 hour
786
+ type: CreatePromptResponseFormatPromptsRequestType
787
+ json_schema: CreatePromptResponseFormatPromptsJSONSchemaTypedDict
784
788
 
785
- Defaults to `5m`. Only supported by `Anthropic` Claude models.
789
+
790
+ class CreatePromptResponseFormatJSONSchema(BaseModel):
791
+ r"""
792
+
793
+ JSON Schema response format. Used to generate structured JSON responses
786
794
  """
787
795
 
796
+ type: CreatePromptResponseFormatPromptsRequestType
788
797
 
789
- class CreatePromptMessagesToolMessageTypedDict(TypedDict):
790
- role: CreatePromptMessagesPromptsRequestRequestBodyRole
791
- r"""The role of the messages author, in this case tool."""
792
- content: CreatePromptMessagesPromptsRequestRequestBodyContentTypedDict
793
- r"""The contents of the tool message."""
794
- tool_call_id: Nullable[str]
795
- r"""Tool call that this message is responding to."""
796
- cache_control: NotRequired[CreatePromptMessagesCacheControlTypedDict]
798
+ json_schema: CreatePromptResponseFormatPromptsJSONSchema
797
799
 
798
800
 
799
- class CreatePromptMessagesToolMessage(BaseModel):
800
- role: CreatePromptMessagesPromptsRequestRequestBodyRole
801
- r"""The role of the messages author, in this case tool."""
801
+ CreatePromptResponseFormatPromptsType = Literal["json_object",]
802
802
 
803
- content: CreatePromptMessagesPromptsRequestRequestBodyContent
804
- r"""The contents of the tool message."""
805
803
 
806
- tool_call_id: Nullable[str]
807
- r"""Tool call that this message is responding to."""
804
+ class CreatePromptResponseFormatJSONObjectTypedDict(TypedDict):
805
+ r"""
808
806
 
809
- cache_control: Optional[CreatePromptMessagesCacheControl] = None
807
+ JSON object response format. An older method of generating JSON responses. Using `json_schema` is recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.
808
+ """
810
809
 
811
- @model_serializer(mode="wrap")
812
- def serialize_model(self, handler):
813
- optional_fields = ["cache_control"]
814
- nullable_fields = ["tool_call_id"]
815
- null_default_fields = []
810
+ type: CreatePromptResponseFormatPromptsType
816
811
 
817
- serialized = handler(self)
818
812
 
819
- m = {}
813
+ class CreatePromptResponseFormatJSONObject(BaseModel):
814
+ r"""
820
815
 
821
- for n, f in type(self).model_fields.items():
822
- k = f.alias or n
823
- val = serialized.get(k)
824
- serialized.pop(k, None)
816
+ JSON object response format. An older method of generating JSON responses. Using `json_schema` is recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.
817
+ """
825
818
 
826
- optional_nullable = k in optional_fields and k in nullable_fields
827
- is_set = (
828
- self.__pydantic_fields_set__.intersection({n})
829
- or k in null_default_fields
830
- ) # pylint: disable=no-member
819
+ type: CreatePromptResponseFormatPromptsType
831
820
 
832
- if val is not None and val != UNSET_SENTINEL:
833
- m[k] = val
834
- elif val != UNSET_SENTINEL and (
835
- not k in optional_fields or (optional_nullable and is_set)
836
- ):
837
- m[k] = val
838
821
 
839
- return m
822
+ CreatePromptResponseFormatType = Literal["text",]
840
823
 
841
824
 
842
- CreatePromptContentPromptsRequest2TypedDict = TypeAliasType(
843
- "CreatePromptContentPromptsRequest2TypedDict",
844
- Union[
845
- RefusalPartSchemaTypedDict,
846
- RedactedReasoningPartSchemaTypedDict,
847
- TextContentPartSchemaTypedDict,
848
- ReasoningPartSchemaTypedDict,
849
- ],
850
- )
825
+ class CreatePromptResponseFormatTextTypedDict(TypedDict):
826
+ r"""
851
827
 
828
+ Default response format. Used to generate text responses
829
+ """
852
830
 
853
- CreatePromptContentPromptsRequest2 = Annotated[
854
- Union[
855
- Annotated[TextContentPartSchema, Tag("text")],
856
- Annotated[RefusalPartSchema, Tag("refusal")],
857
- Annotated[ReasoningPartSchema, Tag("reasoning")],
858
- Annotated[RedactedReasoningPartSchema, Tag("redacted_reasoning")],
859
- ],
860
- Discriminator(lambda m: get_discriminator(m, "type", "type")),
861
- ]
831
+ type: CreatePromptResponseFormatType
862
832
 
863
833
 
864
- CreatePromptMessagesPromptsRequestContentTypedDict = TypeAliasType(
865
- "CreatePromptMessagesPromptsRequestContentTypedDict",
866
- Union[str, List[CreatePromptContentPromptsRequest2TypedDict]],
867
- )
868
- r"""The contents of the assistant message. Required unless `tool_calls` or `function_call` is specified."""
834
+ class CreatePromptResponseFormatText(BaseModel):
835
+ r"""
836
+
837
+ Default response format. Used to generate text responses
838
+ """
869
839
 
840
+ type: CreatePromptResponseFormatType
870
841
 
871
- CreatePromptMessagesPromptsRequestContent = TypeAliasType(
872
- "CreatePromptMessagesPromptsRequestContent",
873
- Union[str, List[CreatePromptContentPromptsRequest2]],
842
+
843
+ CreatePromptResponseFormatTypedDict = TypeAliasType(
844
+ "CreatePromptResponseFormatTypedDict",
845
+ Union[
846
+ CreatePromptResponseFormatTextTypedDict,
847
+ CreatePromptResponseFormatJSONObjectTypedDict,
848
+ CreatePromptResponseFormatJSONSchemaTypedDict,
849
+ ],
874
850
  )
875
- r"""The contents of the assistant message. Required unless `tool_calls` or `function_call` is specified."""
851
+ r"""An object specifying the format that the model must output"""
876
852
 
877
853
 
878
- CreatePromptMessagesPromptsRequestRole = Literal["assistant",]
879
- r"""The role of the messages author, in this case `assistant`."""
854
+ CreatePromptResponseFormat = Annotated[
855
+ Union[
856
+ Annotated[CreatePromptResponseFormatText, Tag("text")],
857
+ Annotated[CreatePromptResponseFormatJSONObject, Tag("json_object")],
858
+ Annotated[CreatePromptResponseFormatJSONSchema, Tag("json_schema")],
859
+ ],
860
+ Discriminator(lambda m: get_discriminator(m, "type", "type")),
861
+ ]
862
+ r"""An object specifying the format that the model must output"""
880
863
 
881
864
 
882
- class CreatePromptMessagesAudioTypedDict(TypedDict):
883
- r"""Data about a previous audio response from the model."""
865
+ CreatePromptReasoningEffort = Literal[
866
+ "none",
867
+ "minimal",
868
+ "low",
869
+ "medium",
870
+ "high",
871
+ "xhigh",
872
+ ]
873
+ r"""Constrains effort on reasoning for [reasoning models](https://platform.openai.com/docs/guides/reasoning). Currently supported values are `none`, `minimal`, `low`, `medium`, `high`, and `xhigh`. Reducing reasoning effort can result in faster responses and fewer tokens used on reasoning in a response.
884
874
 
885
- id: str
886
- r"""Unique identifier for a previous audio response from the model."""
875
+ - `gpt-5.1` defaults to `none`, which does not perform reasoning. The supported reasoning values for `gpt-5.1` are `none`, `low`, `medium`, and `high`. Tool calls are supported for all reasoning values in gpt-5.1.
876
+ - All models before `gpt-5.1` default to `medium` reasoning effort, and do not support `none`.
877
+ - The `gpt-5-pro` model defaults to (and only supports) `high` reasoning effort.
878
+ - `xhigh` is currently only supported for `gpt-5.1-codex-max`.
887
879
 
880
+ Any of \"none\", \"minimal\", \"low\", \"medium\", \"high\", \"xhigh\".
881
+ """
888
882
 
889
- class CreatePromptMessagesAudio(BaseModel):
890
- r"""Data about a previous audio response from the model."""
891
883
 
892
- id: str
893
- r"""Unique identifier for a previous audio response from the model."""
884
+ CreatePromptStopTypedDict = TypeAliasType(
885
+ "CreatePromptStopTypedDict", Union[str, List[str]]
886
+ )
887
+ r"""Up to 4 sequences where the API will stop generating further tokens."""
894
888
 
895
889
 
896
- CreatePromptMessagesType = Literal["function",]
897
- r"""The type of the tool. Currently, only `function` is supported."""
890
+ CreatePromptStop = TypeAliasType("CreatePromptStop", Union[str, List[str]])
891
+ r"""Up to 4 sequences where the API will stop generating further tokens."""
898
892
 
899
893
 
900
- class CreatePromptMessagesFunctionTypedDict(TypedDict):
901
- name: NotRequired[str]
902
- r"""The name of the function to call."""
903
- arguments: NotRequired[str]
904
- r"""The arguments to call the function with, as generated by the model in JSON format. Note that the model does not always generate valid JSON, and may hallucinate parameters not defined by your function schema. Validate the arguments in your code before calling your function."""
894
+ class CreatePromptStreamOptionsTypedDict(TypedDict):
895
+ r"""Options for streaming response. Only set this when you set stream: true."""
905
896
 
897
+ include_usage: NotRequired[bool]
898
+ r"""If set, an additional chunk will be streamed before the data: [DONE] message. The usage field on this chunk shows the token usage statistics for the entire request, and the choices field will always be an empty array. All other chunks will also include a usage field, but with a null value."""
906
899
 
907
- class CreatePromptMessagesFunction(BaseModel):
908
- name: Optional[str] = None
909
- r"""The name of the function to call."""
910
900
 
911
- arguments: Optional[str] = None
912
- r"""The arguments to call the function with, as generated by the model in JSON format. Note that the model does not always generate valid JSON, and may hallucinate parameters not defined by your function schema. Validate the arguments in your code before calling your function."""
901
+ class CreatePromptStreamOptions(BaseModel):
902
+ r"""Options for streaming response. Only set this when you set stream: true."""
913
903
 
904
+ include_usage: Optional[bool] = None
905
+ r"""If set, an additional chunk will be streamed before the data: [DONE] message. The usage field on this chunk shows the token usage statistics for the entire request, and the choices field will always be an empty array. All other chunks will also include a usage field, but with a null value."""
914
906
 
915
- class CreatePromptMessagesToolCallsTypedDict(TypedDict):
916
- id: str
917
- r"""The ID of the tool call."""
918
- type: CreatePromptMessagesType
919
- r"""The type of the tool. Currently, only `function` is supported."""
920
- function: CreatePromptMessagesFunctionTypedDict
921
- thought_signature: NotRequired[str]
922
- r"""Encrypted representation of the model internal reasoning state during function calling. Required by Gemini 3 models when continuing a conversation after a tool call."""
907
+ @model_serializer(mode="wrap")
908
+ def serialize_model(self, handler):
909
+ optional_fields = set(["include_usage"])
910
+ serialized = handler(self)
911
+ m = {}
923
912
 
913
+ for n, f in type(self).model_fields.items():
914
+ k = f.alias or n
915
+ val = serialized.get(k)
924
916
 
925
- class CreatePromptMessagesToolCalls(BaseModel):
926
- id: str
927
- r"""The ID of the tool call."""
917
+ if val != UNSET_SENTINEL:
918
+ if val is not None or k not in optional_fields:
919
+ m[k] = val
928
920
 
929
- type: CreatePromptMessagesType
930
- r"""The type of the tool. Currently, only `function` is supported."""
921
+ return m
931
922
 
932
- function: CreatePromptMessagesFunction
933
923
 
934
- thought_signature: Optional[str] = None
935
- r"""Encrypted representation of the model internal reasoning state during function calling. Required by Gemini 3 models when continuing a conversation after a tool call."""
924
+ CreatePromptThinkingTypedDict = TypeAliasType(
925
+ "CreatePromptThinkingTypedDict",
926
+ Union[ThinkingConfigDisabledSchemaTypedDict, ThinkingConfigEnabledSchemaTypedDict],
927
+ )
936
928
 
937
929
 
938
- class CreatePromptMessagesAssistantMessageTypedDict(TypedDict):
939
- role: CreatePromptMessagesPromptsRequestRole
940
- r"""The role of the messages author, in this case `assistant`."""
941
- content: NotRequired[Nullable[CreatePromptMessagesPromptsRequestContentTypedDict]]
942
- r"""The contents of the assistant message. Required unless `tool_calls` or `function_call` is specified."""
943
- refusal: NotRequired[Nullable[str]]
944
- r"""The refusal message by the assistant."""
945
- name: NotRequired[str]
946
- r"""An optional name for the participant. Provides the model information to differentiate between participants of the same role."""
947
- audio: NotRequired[Nullable[CreatePromptMessagesAudioTypedDict]]
948
- r"""Data about a previous audio response from the model."""
949
- tool_calls: NotRequired[List[CreatePromptMessagesToolCallsTypedDict]]
950
- r"""The tool calls generated by the model, such as function calls."""
930
+ CreatePromptThinking = Annotated[
931
+ Union[
932
+ Annotated[ThinkingConfigDisabledSchema, Tag("disabled")],
933
+ Annotated[ThinkingConfigEnabledSchema, Tag("enabled")],
934
+ ],
935
+ Discriminator(lambda m: get_discriminator(m, "type", "type")),
936
+ ]
951
937
 
952
938
 
953
- class CreatePromptMessagesAssistantMessage(BaseModel):
954
- role: CreatePromptMessagesPromptsRequestRole
955
- r"""The role of the messages author, in this case `assistant`."""
939
+ CreatePromptToolChoiceType = Literal["function",]
940
+ r"""The type of the tool. Currently, only function is supported."""
956
941
 
957
- content: OptionalNullable[CreatePromptMessagesPromptsRequestContent] = UNSET
958
- r"""The contents of the assistant message. Required unless `tool_calls` or `function_call` is specified."""
959
942
 
960
- refusal: OptionalNullable[str] = UNSET
961
- r"""The refusal message by the assistant."""
943
+ class CreatePromptToolChoiceFunctionTypedDict(TypedDict):
944
+ name: str
945
+ r"""The name of the function to call."""
962
946
 
963
- name: Optional[str] = None
964
- r"""An optional name for the participant. Provides the model information to differentiate between participants of the same role."""
965
947
 
966
- audio: OptionalNullable[CreatePromptMessagesAudio] = UNSET
967
- r"""Data about a previous audio response from the model."""
948
+ class CreatePromptToolChoiceFunction(BaseModel):
949
+ name: str
950
+ r"""The name of the function to call."""
968
951
 
969
- tool_calls: Optional[List[CreatePromptMessagesToolCalls]] = None
970
- r"""The tool calls generated by the model, such as function calls."""
952
+
953
+ class CreatePromptToolChoice2TypedDict(TypedDict):
954
+ function: CreatePromptToolChoiceFunctionTypedDict
955
+ type: NotRequired[CreatePromptToolChoiceType]
956
+ r"""The type of the tool. Currently, only function is supported."""
957
+
958
+
959
+ class CreatePromptToolChoice2(BaseModel):
960
+ function: CreatePromptToolChoiceFunction
961
+
962
+ type: Optional[CreatePromptToolChoiceType] = None
963
+ r"""The type of the tool. Currently, only function is supported."""
971
964
 
972
965
  @model_serializer(mode="wrap")
973
966
  def serialize_model(self, handler):
974
- optional_fields = ["content", "refusal", "name", "audio", "tool_calls"]
975
- nullable_fields = ["content", "refusal", "audio"]
976
- null_default_fields = []
977
-
967
+ optional_fields = set(["type"])
978
968
  serialized = handler(self)
979
-
980
969
  m = {}
981
970
 
982
971
  for n, f in type(self).model_fields.items():
983
972
  k = f.alias or n
984
973
  val = serialized.get(k)
985
- serialized.pop(k, None)
986
-
987
- optional_nullable = k in optional_fields and k in nullable_fields
988
- is_set = (
989
- self.__pydantic_fields_set__.intersection({n})
990
- or k in null_default_fields
991
- ) # pylint: disable=no-member
992
974
 
993
- if val is not None and val != UNSET_SENTINEL:
994
- m[k] = val
995
- elif val != UNSET_SENTINEL and (
996
- not k in optional_fields or (optional_nullable and is_set)
997
- ):
998
- m[k] = val
975
+ if val != UNSET_SENTINEL:
976
+ if val is not None or k not in optional_fields:
977
+ m[k] = val
999
978
 
1000
979
  return m
1001
980
 
1002
981
 
1003
- CreatePromptMessagesPromptsRole = Literal["user",]
1004
- r"""The role of the messages author, in this case `user`."""
982
+ CreatePromptToolChoice1 = Literal[
983
+ "none",
984
+ "auto",
985
+ "required",
986
+ ]
1005
987
 
1006
988
 
1007
- CreatePrompt2PromptsRequestRequestBodyType = Literal["file",]
1008
- r"""The type of the content part. Always `file`."""
989
+ CreatePromptToolChoiceTypedDict = TypeAliasType(
990
+ "CreatePromptToolChoiceTypedDict",
991
+ Union[CreatePromptToolChoice2TypedDict, CreatePromptToolChoice1],
992
+ )
993
+ r"""Controls which (if any) tool is called by the model."""
1009
994
 
1010
995
 
1011
- CreatePrompt2PromptsRequestRequestBodyPromptType = Literal["ephemeral",]
1012
- r"""Create a cache control breakpoint at this content block. Accepts only the value \"ephemeral\"."""
996
+ CreatePromptToolChoice = TypeAliasType(
997
+ "CreatePromptToolChoice", Union[CreatePromptToolChoice2, CreatePromptToolChoice1]
998
+ )
999
+ r"""Controls which (if any) tool is called by the model."""
1013
1000
 
1014
1001
 
1015
- CreatePrompt2TTL = Literal[
1016
- "5m",
1017
- "1h",
1002
+ CreatePromptModalities = Literal[
1003
+ "text",
1004
+ "audio",
1018
1005
  ]
1019
- r"""The time-to-live for the cache control breakpoint. This may be one of the following values:
1020
1006
 
1021
- - `5m`: 5 minutes
1022
- - `1h`: 1 hour
1023
1007
 
1024
- Defaults to `5m`. Only supported by `Anthropic` Claude models.
1025
- """
1008
+ CreatePromptID1 = Literal[
1009
+ "orq_pii_detection",
1010
+ "orq_sexual_moderation",
1011
+ "orq_harmful_moderation",
1012
+ ]
1013
+ r"""The key of the guardrail."""
1026
1014
 
1027
1015
 
1028
- class CreatePrompt2CacheControlTypedDict(TypedDict):
1029
- type: CreatePrompt2PromptsRequestRequestBodyPromptType
1030
- r"""Create a cache control breakpoint at this content block. Accepts only the value \"ephemeral\"."""
1031
- ttl: NotRequired[CreatePrompt2TTL]
1032
- r"""The time-to-live for the cache control breakpoint. This may be one of the following values:
1016
+ CreatePromptIDTypedDict = TypeAliasType(
1017
+ "CreatePromptIDTypedDict", Union[CreatePromptID1, str]
1018
+ )
1033
1019
 
1034
- - `5m`: 5 minutes
1035
- - `1h`: 1 hour
1036
1020
 
1037
- Defaults to `5m`. Only supported by `Anthropic` Claude models.
1038
- """
1021
+ CreatePromptID = TypeAliasType("CreatePromptID", Union[CreatePromptID1, str])
1039
1022
 
1040
1023
 
1041
- class CreatePrompt2CacheControl(BaseModel):
1042
- type: CreatePrompt2PromptsRequestRequestBodyPromptType
1043
- r"""Create a cache control breakpoint at this content block. Accepts only the value \"ephemeral\"."""
1024
+ CreatePromptExecuteOn = Literal[
1025
+ "input",
1026
+ "output",
1027
+ ]
1028
+ r"""Determines whether the guardrail runs on the input (user message) or output (model response)."""
1044
1029
 
1045
- ttl: Optional[CreatePrompt2TTL] = "5m"
1046
- r"""The time-to-live for the cache control breakpoint. This may be one of the following values:
1047
1030
 
1048
- - `5m`: 5 minutes
1049
- - `1h`: 1 hour
1031
+ class CreatePromptGuardrailsTypedDict(TypedDict):
1032
+ id: CreatePromptIDTypedDict
1033
+ execute_on: CreatePromptExecuteOn
1034
+ r"""Determines whether the guardrail runs on the input (user message) or output (model response)."""
1050
1035
 
1051
- Defaults to `5m`. Only supported by `Anthropic` Claude models.
1052
- """
1053
1036
 
1037
+ class CreatePromptGuardrails(BaseModel):
1038
+ id: CreatePromptID
1054
1039
 
1055
- class CreatePrompt24TypedDict(TypedDict):
1056
- type: CreatePrompt2PromptsRequestRequestBodyType
1057
- r"""The type of the content part. Always `file`."""
1058
- file: FileContentPartSchemaTypedDict
1059
- r"""File data for the content part. Must contain either file_data or uri, but not both."""
1060
- cache_control: NotRequired[CreatePrompt2CacheControlTypedDict]
1040
+ execute_on: CreatePromptExecuteOn
1041
+ r"""Determines whether the guardrail runs on the input (user message) or output (model response)."""
1061
1042
 
1062
1043
 
1063
- class CreatePrompt24(BaseModel):
1064
- type: CreatePrompt2PromptsRequestRequestBodyType
1065
- r"""The type of the content part. Always `file`."""
1044
+ class CreatePromptFallbacksTypedDict(TypedDict):
1045
+ model: str
1046
+ r"""Fallback model identifier"""
1066
1047
 
1067
- file: FileContentPartSchema
1068
- r"""File data for the content part. Must contain either file_data or uri, but not both."""
1069
1048
 
1070
- cache_control: Optional[CreatePrompt2CacheControl] = None
1049
+ class CreatePromptFallbacks(BaseModel):
1050
+ model: str
1051
+ r"""Fallback model identifier"""
1071
1052
 
1072
1053
 
1073
- CreatePromptContentPrompts2TypedDict = TypeAliasType(
1074
- "CreatePromptContentPrompts2TypedDict",
1075
- Union[
1076
- AudioContentPartSchemaTypedDict,
1077
- TextContentPartSchemaTypedDict,
1078
- ImageContentPartSchemaTypedDict,
1079
- CreatePrompt24TypedDict,
1080
- ],
1081
- )
1054
+ class CreatePromptRetryTypedDict(TypedDict):
1055
+ r"""Retry configuration for the request"""
1082
1056
 
1057
+ count: NotRequired[float]
1058
+ r"""Number of retry attempts (1-5)"""
1059
+ on_codes: NotRequired[List[float]]
1060
+ r"""HTTP status codes that trigger retry logic"""
1083
1061
 
1084
- CreatePromptContentPrompts2 = Annotated[
1085
- Union[
1086
- Annotated[TextContentPartSchema, Tag("text")],
1087
- Annotated[ImageContentPartSchema, Tag("image_url")],
1088
- Annotated[AudioContentPartSchema, Tag("input_audio")],
1089
- Annotated[CreatePrompt24, Tag("file")],
1090
- ],
1091
- Discriminator(lambda m: get_discriminator(m, "type", "type")),
1092
- ]
1093
1062
 
1063
+ class CreatePromptRetry(BaseModel):
1064
+ r"""Retry configuration for the request"""
1094
1065
 
1095
- CreatePromptMessagesPromptsContentTypedDict = TypeAliasType(
1096
- "CreatePromptMessagesPromptsContentTypedDict",
1097
- Union[str, List[CreatePromptContentPrompts2TypedDict]],
1098
- )
1099
- r"""The contents of the user message."""
1066
+ count: Optional[float] = 3
1067
+ r"""Number of retry attempts (1-5)"""
1100
1068
 
1069
+ on_codes: Optional[List[float]] = None
1070
+ r"""HTTP status codes that trigger retry logic"""
1101
1071
 
1102
- CreatePromptMessagesPromptsContent = TypeAliasType(
1103
- "CreatePromptMessagesPromptsContent", Union[str, List[CreatePromptContentPrompts2]]
1104
- )
1105
- r"""The contents of the user message."""
1072
+ @model_serializer(mode="wrap")
1073
+ def serialize_model(self, handler):
1074
+ optional_fields = set(["count", "on_codes"])
1075
+ serialized = handler(self)
1076
+ m = {}
1106
1077
 
1078
+ for n, f in type(self).model_fields.items():
1079
+ k = f.alias or n
1080
+ val = serialized.get(k)
1107
1081
 
1108
- class CreatePromptMessagesUserMessageTypedDict(TypedDict):
1109
- role: CreatePromptMessagesPromptsRole
1110
- r"""The role of the messages author, in this case `user`."""
1111
- content: CreatePromptMessagesPromptsContentTypedDict
1112
- r"""The contents of the user message."""
1113
- name: NotRequired[str]
1114
- r"""An optional name for the participant. Provides the model information to differentiate between participants of the same role."""
1082
+ if val != UNSET_SENTINEL:
1083
+ if val is not None or k not in optional_fields:
1084
+ m[k] = val
1115
1085
 
1086
+ return m
1116
1087
 
1117
- class CreatePromptMessagesUserMessage(BaseModel):
1118
- role: CreatePromptMessagesPromptsRole
1119
- r"""The role of the messages author, in this case `user`."""
1120
1088
 
1121
- content: CreatePromptMessagesPromptsContent
1122
- r"""The contents of the user message."""
1089
+ CreatePromptType = Literal["exact_match",]
1123
1090
 
1124
- name: Optional[str] = None
1125
- r"""An optional name for the participant. Provides the model information to differentiate between participants of the same role."""
1126
1091
 
1092
+ class CreatePromptCacheTypedDict(TypedDict):
1093
+ r"""Cache configuration for the request."""
1127
1094
 
1128
- CreatePromptMessagesRole = Literal["system",]
1129
- r"""The role of the messages author, in this case `system`."""
1095
+ type: CreatePromptType
1096
+ ttl: NotRequired[float]
1097
+ r"""Time to live for cached responses in seconds. Maximum 259200 seconds (3 days)."""
1130
1098
 
1131
1099
 
1132
- CreatePromptMessagesContentTypedDict = TypeAliasType(
1133
- "CreatePromptMessagesContentTypedDict",
1134
- Union[str, List[TextContentPartSchemaTypedDict]],
1135
- )
1136
- r"""The contents of the system message."""
1100
+ class CreatePromptCache(BaseModel):
1101
+ r"""Cache configuration for the request."""
1137
1102
 
1103
+ type: CreatePromptType
1138
1104
 
1139
- CreatePromptMessagesContent = TypeAliasType(
1140
- "CreatePromptMessagesContent", Union[str, List[TextContentPartSchema]]
1141
- )
1142
- r"""The contents of the system message."""
1105
+ ttl: Optional[float] = 1800
1106
+ r"""Time to live for cached responses in seconds. Maximum 259200 seconds (3 days)."""
1143
1107
 
1108
+ @model_serializer(mode="wrap")
1109
+ def serialize_model(self, handler):
1110
+ optional_fields = set(["ttl"])
1111
+ serialized = handler(self)
1112
+ m = {}
1144
1113
 
1145
- class CreatePromptMessagesSystemMessageTypedDict(TypedDict):
1146
- r"""Developer-provided instructions that the model should follow, regardless of messages sent by the user."""
1114
+ for n, f in type(self).model_fields.items():
1115
+ k = f.alias or n
1116
+ val = serialized.get(k)
1147
1117
 
1148
- role: CreatePromptMessagesRole
1149
- r"""The role of the messages author, in this case `system`."""
1150
- content: CreatePromptMessagesContentTypedDict
1151
- r"""The contents of the system message."""
1152
- name: NotRequired[str]
1153
- r"""An optional name for the participant. Provides the model information to differentiate between participants of the same role."""
1118
+ if val != UNSET_SENTINEL:
1119
+ if val is not None or k not in optional_fields:
1120
+ m[k] = val
1154
1121
 
1122
+ return m
1155
1123
 
1156
- class CreatePromptMessagesSystemMessage(BaseModel):
1157
- r"""Developer-provided instructions that the model should follow, regardless of messages sent by the user."""
1158
-
1159
- role: CreatePromptMessagesRole
1160
- r"""The role of the messages author, in this case `system`."""
1161
1124
 
1162
- content: CreatePromptMessagesContent
1163
- r"""The contents of the system message."""
1125
+ CreatePromptLoadBalancerType = Literal["weight_based",]
1164
1126
 
1165
- name: Optional[str] = None
1166
- r"""An optional name for the participant. Provides the model information to differentiate between participants of the same role."""
1167
1127
 
1128
+ class CreatePromptLoadBalancerModelsTypedDict(TypedDict):
1129
+ model: str
1130
+ r"""Model identifier for load balancing"""
1131
+ weight: NotRequired[float]
1132
+ r"""Weight assigned to this model for load balancing"""
1168
1133
 
1169
- CreatePromptPromptsMessagesTypedDict = TypeAliasType(
1170
- "CreatePromptPromptsMessagesTypedDict",
1171
- Union[
1172
- CreatePromptMessagesSystemMessageTypedDict,
1173
- CreatePromptMessagesUserMessageTypedDict,
1174
- CreatePromptMessagesToolMessageTypedDict,
1175
- CreatePromptMessagesAssistantMessageTypedDict,
1176
- ],
1177
- )
1178
1134
 
1135
+ class CreatePromptLoadBalancerModels(BaseModel):
1136
+ model: str
1137
+ r"""Model identifier for load balancing"""
1179
1138
 
1180
- CreatePromptPromptsMessages = Annotated[
1181
- Union[
1182
- Annotated[CreatePromptMessagesSystemMessage, Tag("system")],
1183
- Annotated[CreatePromptMessagesUserMessage, Tag("user")],
1184
- Annotated[CreatePromptMessagesAssistantMessage, Tag("assistant")],
1185
- Annotated[CreatePromptMessagesToolMessage, Tag("tool")],
1186
- ],
1187
- Discriminator(lambda m: get_discriminator(m, "role", "role")),
1188
- ]
1139
+ weight: Optional[float] = 0.5
1140
+ r"""Weight assigned to this model for load balancing"""
1189
1141
 
1142
+ @model_serializer(mode="wrap")
1143
+ def serialize_model(self, handler):
1144
+ optional_fields = set(["weight"])
1145
+ serialized = handler(self)
1146
+ m = {}
1190
1147
 
1191
- CreatePromptResponseFormatPromptsRequestRequestBodyPrompt3Type = Literal["json_schema",]
1148
+ for n, f in type(self).model_fields.items():
1149
+ k = f.alias or n
1150
+ val = serialized.get(k)
1192
1151
 
1152
+ if val != UNSET_SENTINEL:
1153
+ if val is not None or k not in optional_fields:
1154
+ m[k] = val
1193
1155
 
1194
- class CreatePromptResponseFormatPromptsRequestJSONSchemaTypedDict(TypedDict):
1195
- name: str
1196
- r"""The name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64."""
1197
- description: NotRequired[str]
1198
- r"""A description of what the response format is for, used by the model to determine how to respond in the format."""
1199
- schema_: NotRequired[Any]
1200
- r"""The schema for the response format, described as a JSON Schema object."""
1201
- strict: NotRequired[bool]
1202
- r"""Whether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the schema field. Only a subset of JSON Schema is supported when strict is true."""
1156
+ return m
1203
1157
 
1204
1158
 
1205
- class CreatePromptResponseFormatPromptsRequestJSONSchema(BaseModel):
1206
- name: str
1207
- r"""The name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64."""
1159
+ class CreatePromptLoadBalancer1TypedDict(TypedDict):
1160
+ type: CreatePromptLoadBalancerType
1161
+ models: List[CreatePromptLoadBalancerModelsTypedDict]
1208
1162
 
1209
- description: Optional[str] = None
1210
- r"""A description of what the response format is for, used by the model to determine how to respond in the format."""
1211
1163
 
1212
- schema_: Annotated[Optional[Any], pydantic.Field(alias="schema")] = None
1213
- r"""The schema for the response format, described as a JSON Schema object."""
1164
+ class CreatePromptLoadBalancer1(BaseModel):
1165
+ type: CreatePromptLoadBalancerType
1214
1166
 
1215
- strict: Optional[bool] = False
1216
- r"""Whether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the schema field. Only a subset of JSON Schema is supported when strict is true."""
1167
+ models: List[CreatePromptLoadBalancerModels]
1217
1168
 
1218
1169
 
1219
- class CreatePromptResponseFormatPromptsJSONSchemaTypedDict(TypedDict):
1220
- r"""
1170
+ CreatePromptLoadBalancerTypedDict = CreatePromptLoadBalancer1TypedDict
1171
+ r"""Load balancer configuration for the request."""
1221
1172
 
1222
- JSON Schema response format. Used to generate structured JSON responses
1223
- """
1224
1173
 
1225
- type: CreatePromptResponseFormatPromptsRequestRequestBodyPrompt3Type
1226
- json_schema: CreatePromptResponseFormatPromptsRequestJSONSchemaTypedDict
1174
+ CreatePromptLoadBalancer = CreatePromptLoadBalancer1
1175
+ r"""Load balancer configuration for the request."""
1227
1176
 
1228
1177
 
1229
- class CreatePromptResponseFormatPromptsJSONSchema(BaseModel):
1230
- r"""
1178
+ class CreatePromptTimeoutTypedDict(TypedDict):
1179
+ r"""Timeout configuration to apply to the request. If the request exceeds the timeout, it will be retried or fallback to the next model if configured."""
1231
1180
 
1232
- JSON Schema response format. Used to generate structured JSON responses
1233
- """
1181
+ call_timeout: float
1182
+ r"""Timeout value in milliseconds"""
1234
1183
 
1235
- type: CreatePromptResponseFormatPromptsRequestRequestBodyPrompt3Type
1236
1184
 
1237
- json_schema: CreatePromptResponseFormatPromptsRequestJSONSchema
1185
+ class CreatePromptTimeout(BaseModel):
1186
+ r"""Timeout configuration to apply to the request. If the request exceeds the timeout, it will be retried or fallback to the next model if configured."""
1238
1187
 
1188
+ call_timeout: float
1189
+ r"""Timeout value in milliseconds"""
1239
1190
 
1240
- CreatePromptResponseFormatPromptsRequestRequestBodyPromptType = Literal["json_object",]
1241
1191
 
1192
+ class PromptInputTypedDict(TypedDict):
1193
+ r"""Prompt configuration with model and messages."""
1242
1194
 
1243
- class CreatePromptResponseFormatJSONObjectTypedDict(TypedDict):
1244
- r"""
1195
+ messages: List[CreatePromptMessagesTypedDict]
1196
+ r"""Array of messages that make up the conversation. Each message has a role (system, user, assistant, or tool) and content."""
1197
+ model: NotRequired[str]
1198
+ r"""Model ID used to generate the response, like `openai/gpt-4o` or `anthropic/claude-3-5-sonnet-20241022`. For private models, use format: `{workspaceKey}@{provider}/{model}`. The full list of models can be found at https://docs.orq.ai/docs/ai-gateway-supported-models. Only chat models are supported."""
1199
+ name: NotRequired[str]
1200
+ r"""The name to display on the trace. If not specified, the default system name will be used."""
1201
+ audio: NotRequired[Nullable[CreatePromptAudioTypedDict]]
1202
+ r"""Parameters for audio output. Required when audio output is requested with modalities: [\"audio\"]. Learn more."""
1203
+ frequency_penalty: NotRequired[Nullable[float]]
1204
+ r"""Number between -2.0 and 2.0. Positive values penalize new tokens based on their existing frequency in the text so far, decreasing the model's likelihood to repeat the same line verbatim."""
1205
+ max_tokens: NotRequired[Nullable[int]]
1206
+ r"""`[Deprecated]`. The maximum number of tokens that can be generated in the chat completion. This value can be used to control costs for text generated via API.
1245
1207
 
1246
- JSON object response format. An older method of generating JSON responses. Using `json_schema` is recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.
1208
+ This value is now `deprecated` in favor of `max_completion_tokens`, and is not compatible with o1 series models.
1247
1209
  """
1210
+ max_completion_tokens: NotRequired[Nullable[int]]
1211
+ r"""An upper bound for the number of tokens that can be generated for a completion, including visible output tokens and reasoning tokens"""
1212
+ logprobs: NotRequired[Nullable[bool]]
1213
+ r"""Whether to return log probabilities of the output tokens or not. If true, returns the log probabilities of each output token returned in the content of message."""
1214
+ top_logprobs: NotRequired[Nullable[int]]
1215
+ r"""An integer between 0 and 20 specifying the number of most likely tokens to return at each token position, each with an associated log probability. logprobs must be set to true if this parameter is used."""
1216
+ n: NotRequired[Nullable[int]]
1217
+ r"""How many chat completion choices to generate for each input message. Note that you will be charged based on the number of generated tokens across all of the choices. Keep n as 1 to minimize costs."""
1218
+ presence_penalty: NotRequired[Nullable[float]]
1219
+ r"""Number between -2.0 and 2.0. Positive values penalize new tokens based on whether they appear in the text so far, increasing the model's likelihood to talk about new topics."""
1220
+ response_format: NotRequired[CreatePromptResponseFormatTypedDict]
1221
+ r"""An object specifying the format that the model must output"""
1222
+ reasoning_effort: NotRequired[CreatePromptReasoningEffort]
1223
+ r"""Constrains effort on reasoning for [reasoning models](https://platform.openai.com/docs/guides/reasoning). Currently supported values are `none`, `minimal`, `low`, `medium`, `high`, and `xhigh`. Reducing reasoning effort can result in faster responses and fewer tokens used on reasoning in a response.
1248
1224
 
1249
- type: CreatePromptResponseFormatPromptsRequestRequestBodyPromptType
1250
-
1251
-
1252
- class CreatePromptResponseFormatJSONObject(BaseModel):
1253
- r"""
1225
+ - `gpt-5.1` defaults to `none`, which does not perform reasoning. The supported reasoning values for `gpt-5.1` are `none`, `low`, `medium`, and `high`. Tool calls are supported for all reasoning values in gpt-5.1.
1226
+ - All models before `gpt-5.1` default to `medium` reasoning effort, and do not support `none`.
1227
+ - The `gpt-5-pro` model defaults to (and only supports) `high` reasoning effort.
1228
+ - `xhigh` is currently only supported for `gpt-5.1-codex-max`.
1254
1229
 
1255
- JSON object response format. An older method of generating JSON responses. Using `json_schema` is recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.
1230
+ Any of \"none\", \"minimal\", \"low\", \"medium\", \"high\", \"xhigh\".
1256
1231
  """
1257
-
1258
- type: CreatePromptResponseFormatPromptsRequestRequestBodyPromptType
1232
+ verbosity: NotRequired[str]
1233
+ r"""Adjusts response verbosity. Lower levels yield shorter answers."""
1234
+ seed: NotRequired[Nullable[float]]
1235
+ r"""If specified, our system will make a best effort to sample deterministically, such that repeated requests with the same seed and parameters should return the same result."""
1236
+ stop: NotRequired[Nullable[CreatePromptStopTypedDict]]
1237
+ r"""Up to 4 sequences where the API will stop generating further tokens."""
1238
+ stream_options: NotRequired[Nullable[CreatePromptStreamOptionsTypedDict]]
1239
+ r"""Options for streaming response. Only set this when you set stream: true."""
1240
+ thinking: NotRequired[CreatePromptThinkingTypedDict]
1241
+ temperature: NotRequired[Nullable[float]]
1242
+ r"""What sampling temperature to use, between 0 and 2. Higher values like 0.8 will make the output more random, while lower values like 0.2 will make it more focused and deterministic."""
1243
+ top_p: NotRequired[Nullable[float]]
1244
+ r"""An alternative to sampling with temperature, called nucleus sampling, where the model considers the results of the tokens with top_p probability mass."""
1245
+ top_k: NotRequired[Nullable[float]]
1246
+ r"""Limits the model to consider only the top k most likely tokens at each step."""
1247
+ tool_choice: NotRequired[CreatePromptToolChoiceTypedDict]
1248
+ r"""Controls which (if any) tool is called by the model."""
1249
+ parallel_tool_calls: NotRequired[bool]
1250
+ r"""Whether to enable parallel function calling during tool use."""
1251
+ modalities: NotRequired[Nullable[List[CreatePromptModalities]]]
1252
+ r"""Output types that you would like the model to generate. Most models are capable of generating text, which is the default: [\"text\"]. The gpt-4o-audio-preview model can also be used to generate audio. To request that this model generate both text and audio responses, you can use: [\"text\", \"audio\"]."""
1253
+ guardrails: NotRequired[List[CreatePromptGuardrailsTypedDict]]
1254
+ r"""A list of guardrails to apply to the request."""
1255
+ fallbacks: NotRequired[List[CreatePromptFallbacksTypedDict]]
1256
+ r"""Array of fallback models to use if primary model fails"""
1257
+ retry: NotRequired[CreatePromptRetryTypedDict]
1258
+ r"""Retry configuration for the request"""
1259
+ cache: NotRequired[CreatePromptCacheTypedDict]
1260
+ r"""Cache configuration for the request."""
1261
+ load_balancer: NotRequired[CreatePromptLoadBalancerTypedDict]
1262
+ r"""Load balancer configuration for the request."""
1263
+ timeout: NotRequired[CreatePromptTimeoutTypedDict]
1264
+ r"""Timeout configuration to apply to the request. If the request exceeds the timeout, it will be retried or fallback to the next model if configured."""
1259
1265
 
1260
1266
 
1261
- CreatePromptResponseFormatPromptsRequestRequestBodyType = Literal["text",]
1267
+ class PromptInput(BaseModel):
1268
+ r"""Prompt configuration with model and messages."""
1262
1269
 
1270
+ messages: List[CreatePromptMessages]
1271
+ r"""Array of messages that make up the conversation. Each message has a role (system, user, assistant, or tool) and content."""
1263
1272
 
1264
- class CreatePromptResponseFormatTextTypedDict(TypedDict):
1265
- r"""
1273
+ model: Optional[str] = None
1274
+ r"""Model ID used to generate the response, like `openai/gpt-4o` or `anthropic/claude-3-5-sonnet-20241022`. For private models, use format: `{workspaceKey}@{provider}/{model}`. The full list of models can be found at https://docs.orq.ai/docs/ai-gateway-supported-models. Only chat models are supported."""
1266
1275
 
1267
- Default response format. Used to generate text responses
1268
- """
1276
+ name: Optional[str] = None
1277
+ r"""The name to display on the trace. If not specified, the default system name will be used."""
1269
1278
 
1270
- type: CreatePromptResponseFormatPromptsRequestRequestBodyType
1279
+ audio: OptionalNullable[CreatePromptAudio] = UNSET
1280
+ r"""Parameters for audio output. Required when audio output is requested with modalities: [\"audio\"]. Learn more."""
1271
1281
 
1282
+ frequency_penalty: OptionalNullable[float] = UNSET
1283
+ r"""Number between -2.0 and 2.0. Positive values penalize new tokens based on their existing frequency in the text so far, decreasing the model's likelihood to repeat the same line verbatim."""
1272
1284
 
1273
- class CreatePromptResponseFormatText(BaseModel):
1274
- r"""
1285
+ max_tokens: OptionalNullable[int] = UNSET
1286
+ r"""`[Deprecated]`. The maximum number of tokens that can be generated in the chat completion. This value can be used to control costs for text generated via API.
1275
1287
 
1276
- Default response format. Used to generate text responses
1288
+ This value is now `deprecated` in favor of `max_completion_tokens`, and is not compatible with o1 series models.
1277
1289
  """
1278
1290
 
1279
- type: CreatePromptResponseFormatPromptsRequestRequestBodyType
1291
+ max_completion_tokens: OptionalNullable[int] = UNSET
1292
+ r"""An upper bound for the number of tokens that can be generated for a completion, including visible output tokens and reasoning tokens"""
1280
1293
 
1294
+ logprobs: OptionalNullable[bool] = UNSET
1295
+ r"""Whether to return log probabilities of the output tokens or not. If true, returns the log probabilities of each output token returned in the content of message."""
1281
1296
 
1282
- CreatePromptPromptsResponseFormatTypedDict = TypeAliasType(
1283
- "CreatePromptPromptsResponseFormatTypedDict",
1284
- Union[
1285
- CreatePromptResponseFormatTextTypedDict,
1286
- CreatePromptResponseFormatJSONObjectTypedDict,
1287
- CreatePromptResponseFormatPromptsJSONSchemaTypedDict,
1288
- ],
1289
- )
1290
- r"""An object specifying the format that the model must output"""
1297
+ top_logprobs: OptionalNullable[int] = UNSET
1298
+ r"""An integer between 0 and 20 specifying the number of most likely tokens to return at each token position, each with an associated log probability. logprobs must be set to true if this parameter is used."""
1291
1299
 
1300
+ n: OptionalNullable[int] = UNSET
1301
+ r"""How many chat completion choices to generate for each input message. Note that you will be charged based on the number of generated tokens across all of the choices. Keep n as 1 to minimize costs."""
1292
1302
 
1293
- CreatePromptPromptsResponseFormat = Annotated[
1294
- Union[
1295
- Annotated[CreatePromptResponseFormatText, Tag("text")],
1296
- Annotated[CreatePromptResponseFormatJSONObject, Tag("json_object")],
1297
- Annotated[CreatePromptResponseFormatPromptsJSONSchema, Tag("json_schema")],
1298
- ],
1299
- Discriminator(lambda m: get_discriminator(m, "type", "type")),
1300
- ]
1301
- r"""An object specifying the format that the model must output"""
1303
+ presence_penalty: OptionalNullable[float] = UNSET
1304
+ r"""Number between -2.0 and 2.0. Positive values penalize new tokens based on whether they appear in the text so far, increasing the model's likelihood to talk about new topics."""
1302
1305
 
1306
+ response_format: Optional[CreatePromptResponseFormat] = None
1307
+ r"""An object specifying the format that the model must output"""
1303
1308
 
1304
- class PromptInputTypedDict(TypedDict):
1305
- r"""Prompt configuration with model and messages. Either this field or `prompt_config` must be provided."""
1309
+ reasoning_effort: Optional[CreatePromptReasoningEffort] = None
1310
+ r"""Constrains effort on reasoning for [reasoning models](https://platform.openai.com/docs/guides/reasoning). Currently supported values are `none`, `minimal`, `low`, `medium`, `high`, and `xhigh`. Reducing reasoning effort can result in faster responses and fewer tokens used on reasoning in a response.
1306
1311
 
1307
- messages: List[CreatePromptPromptsMessagesTypedDict]
1308
- r"""Array of messages that make up the conversation. Each message has a role (system, user, assistant, or tool) and content."""
1309
- model: NotRequired[str]
1310
- r"""Model ID used to generate the response, like `openai/gpt-4o` or `anthropic/claude-3-5-sonnet-20241022`. The full list of models can be found at https://docs.orq.ai/docs/ai-gateway-supported-models. Only chat models are supported."""
1311
- temperature: NotRequired[Nullable[float]]
1312
- r"""What sampling temperature to use, between 0 and 2. Higher values like 0.8 will make the output more random, while lower values like 0.2 will make it more focused and deterministic."""
1313
- max_tokens: NotRequired[Nullable[int]]
1314
- r"""`[Deprecated]`. The maximum number of tokens that can be generated in the chat completion. This value can be used to control costs for text generated via API.
1312
+ - `gpt-5.1` defaults to `none`, which does not perform reasoning. The supported reasoning values for `gpt-5.1` are `none`, `low`, `medium`, and `high`. Tool calls are supported for all reasoning values in gpt-5.1.
1313
+ - All models before `gpt-5.1` default to `medium` reasoning effort, and do not support `none`.
1314
+ - The `gpt-5-pro` model defaults to (and only supports) `high` reasoning effort.
1315
+ - `xhigh` is currently only supported for `gpt-5.1-codex-max`.
1315
1316
 
1316
- This value is now `deprecated` in favor of `max_completion_tokens`, and is not compatible with o1 series models.
1317
+ Any of \"none\", \"minimal\", \"low\", \"medium\", \"high\", \"xhigh\".
1317
1318
  """
1318
- response_format: NotRequired[CreatePromptPromptsResponseFormatTypedDict]
1319
- r"""An object specifying the format that the model must output"""
1320
1319
 
1320
+ verbosity: Optional[str] = None
1321
+ r"""Adjusts response verbosity. Lower levels yield shorter answers."""
1321
1322
 
1322
- class PromptInput(BaseModel):
1323
- r"""Prompt configuration with model and messages. Either this field or `prompt_config` must be provided."""
1323
+ seed: OptionalNullable[float] = UNSET
1324
+ r"""If specified, our system will make a best effort to sample deterministically, such that repeated requests with the same seed and parameters should return the same result."""
1324
1325
 
1325
- messages: List[CreatePromptPromptsMessages]
1326
- r"""Array of messages that make up the conversation. Each message has a role (system, user, assistant, or tool) and content."""
1326
+ stop: OptionalNullable[CreatePromptStop] = UNSET
1327
+ r"""Up to 4 sequences where the API will stop generating further tokens."""
1327
1328
 
1328
- model: Optional[str] = None
1329
- r"""Model ID used to generate the response, like `openai/gpt-4o` or `anthropic/claude-3-5-sonnet-20241022`. The full list of models can be found at https://docs.orq.ai/docs/ai-gateway-supported-models. Only chat models are supported."""
1329
+ stream_options: OptionalNullable[CreatePromptStreamOptions] = UNSET
1330
+ r"""Options for streaming response. Only set this when you set stream: true."""
1331
+
1332
+ thinking: Optional[CreatePromptThinking] = None
1330
1333
 
1331
1334
  temperature: OptionalNullable[float] = UNSET
1332
1335
  r"""What sampling temperature to use, between 0 and 2. Higher values like 0.8 will make the output more random, while lower values like 0.2 will make it more focused and deterministic."""
1333
1336
 
1334
- max_tokens: OptionalNullable[int] = UNSET
1335
- r"""`[Deprecated]`. The maximum number of tokens that can be generated in the chat completion. This value can be used to control costs for text generated via API.
1337
+ top_p: OptionalNullable[float] = UNSET
1338
+ r"""An alternative to sampling with temperature, called nucleus sampling, where the model considers the results of the tokens with top_p probability mass."""
1336
1339
 
1337
- This value is now `deprecated` in favor of `max_completion_tokens`, and is not compatible with o1 series models.
1338
- """
1340
+ top_k: OptionalNullable[float] = UNSET
1341
+ r"""Limits the model to consider only the top k most likely tokens at each step."""
1339
1342
 
1340
- response_format: Optional[CreatePromptPromptsResponseFormat] = None
1341
- r"""An object specifying the format that the model must output"""
1343
+ tool_choice: Optional[CreatePromptToolChoice] = None
1344
+ r"""Controls which (if any) tool is called by the model."""
1345
+
1346
+ parallel_tool_calls: Optional[bool] = None
1347
+ r"""Whether to enable parallel function calling during tool use."""
1348
+
1349
+ modalities: OptionalNullable[List[CreatePromptModalities]] = UNSET
1350
+ r"""Output types that you would like the model to generate. Most models are capable of generating text, which is the default: [\"text\"]. The gpt-4o-audio-preview model can also be used to generate audio. To request that this model generate both text and audio responses, you can use: [\"text\", \"audio\"]."""
1351
+
1352
+ guardrails: Optional[List[CreatePromptGuardrails]] = None
1353
+ r"""A list of guardrails to apply to the request."""
1354
+
1355
+ fallbacks: Optional[List[CreatePromptFallbacks]] = None
1356
+ r"""Array of fallback models to use if primary model fails"""
1357
+
1358
+ retry: Optional[CreatePromptRetry] = None
1359
+ r"""Retry configuration for the request"""
1360
+
1361
+ cache: Optional[CreatePromptCache] = None
1362
+ r"""Cache configuration for the request."""
1363
+
1364
+ load_balancer: Optional[CreatePromptLoadBalancer] = None
1365
+ r"""Load balancer configuration for the request."""
1366
+
1367
+ timeout: Optional[CreatePromptTimeout] = None
1368
+ r"""Timeout configuration to apply to the request. If the request exceeds the timeout, it will be retried or fallback to the next model if configured."""
1342
1369
 
1343
1370
  @model_serializer(mode="wrap")
1344
1371
  def serialize_model(self, handler):
1345
- optional_fields = ["model", "temperature", "max_tokens", "response_format"]
1346
- nullable_fields = ["temperature", "max_tokens"]
1347
- null_default_fields = []
1348
-
1372
+ optional_fields = set(
1373
+ [
1374
+ "model",
1375
+ "name",
1376
+ "audio",
1377
+ "frequency_penalty",
1378
+ "max_tokens",
1379
+ "max_completion_tokens",
1380
+ "logprobs",
1381
+ "top_logprobs",
1382
+ "n",
1383
+ "presence_penalty",
1384
+ "response_format",
1385
+ "reasoning_effort",
1386
+ "verbosity",
1387
+ "seed",
1388
+ "stop",
1389
+ "stream_options",
1390
+ "thinking",
1391
+ "temperature",
1392
+ "top_p",
1393
+ "top_k",
1394
+ "tool_choice",
1395
+ "parallel_tool_calls",
1396
+ "modalities",
1397
+ "guardrails",
1398
+ "fallbacks",
1399
+ "retry",
1400
+ "cache",
1401
+ "load_balancer",
1402
+ "timeout",
1403
+ ]
1404
+ )
1405
+ nullable_fields = set(
1406
+ [
1407
+ "audio",
1408
+ "frequency_penalty",
1409
+ "max_tokens",
1410
+ "max_completion_tokens",
1411
+ "logprobs",
1412
+ "top_logprobs",
1413
+ "n",
1414
+ "presence_penalty",
1415
+ "seed",
1416
+ "stop",
1417
+ "stream_options",
1418
+ "temperature",
1419
+ "top_p",
1420
+ "top_k",
1421
+ "modalities",
1422
+ ]
1423
+ )
1349
1424
  serialized = handler(self)
1350
-
1351
1425
  m = {}
1352
1426
 
1353
1427
  for n, f in type(self).model_fields.items():
1354
1428
  k = f.alias or n
1355
1429
  val = serialized.get(k)
1356
- serialized.pop(k, None)
1357
-
1358
- optional_nullable = k in optional_fields and k in nullable_fields
1359
- is_set = (
1360
- self.__pydantic_fields_set__.intersection({n})
1361
- or k in null_default_fields
1362
- ) # pylint: disable=no-member
1363
-
1364
- if val is not None and val != UNSET_SENTINEL:
1365
- m[k] = val
1366
- elif val != UNSET_SENTINEL and (
1367
- not k in optional_fields or (optional_nullable and is_set)
1368
- ):
1369
- m[k] = val
1430
+ is_nullable_and_explicitly_set = (
1431
+ k in nullable_fields
1432
+ and (self.__pydantic_fields_set__.intersection({n})) # pylint: disable=no-member
1433
+ )
1434
+
1435
+ if val != UNSET_SENTINEL:
1436
+ if (
1437
+ val is not None
1438
+ or k not in optional_fields
1439
+ or is_nullable_and_explicitly_set
1440
+ ):
1441
+ m[k] = val
1370
1442
 
1371
1443
  return m
1372
1444
 
@@ -1384,10 +1456,8 @@ class CreatePromptRequestBodyTypedDict(TypedDict):
1384
1456
  description: NotRequired[Nullable[str]]
1385
1457
  r"""The prompt’s description, meant to be displayable in the UI. Use this field to optionally store a long form explanation of the prompt for your own purpose"""
1386
1458
  metadata: NotRequired[CreatePromptMetadataTypedDict]
1387
- prompt_config: NotRequired[PromptConfigurationTypedDict]
1388
- r"""[DEPRECATED]. Please use the `prompt` property instead. The current `prompt_config` will keep working but it will be deprecated in future versions. Configuration for the prompt including model and messages."""
1389
1459
  prompt: NotRequired[PromptInputTypedDict]
1390
- r"""Prompt configuration with model and messages. Either this field or `prompt_config` must be provided."""
1460
+ r"""Prompt configuration with model and messages."""
1391
1461
 
1392
1462
 
1393
1463
  class CreatePromptRequestBody(BaseModel):
@@ -1407,44 +1477,31 @@ class CreatePromptRequestBody(BaseModel):
1407
1477
 
1408
1478
  metadata: Optional[CreatePromptMetadata] = None
1409
1479
 
1410
- prompt_config: Annotated[
1411
- Optional[PromptConfiguration],
1412
- pydantic.Field(
1413
- deprecated="warning: ** DEPRECATED ** - This will be removed in a future release, please migrate away from it as soon as possible."
1414
- ),
1415
- ] = None
1416
- r"""[DEPRECATED]. Please use the `prompt` property instead. The current `prompt_config` will keep working but it will be deprecated in future versions. Configuration for the prompt including model and messages."""
1417
-
1418
1480
  prompt: Optional[PromptInput] = None
1419
- r"""Prompt configuration with model and messages. Either this field or `prompt_config` must be provided."""
1481
+ r"""Prompt configuration with model and messages."""
1420
1482
 
1421
1483
  @model_serializer(mode="wrap")
1422
1484
  def serialize_model(self, handler):
1423
- optional_fields = ["description", "metadata", "prompt_config", "prompt"]
1424
- nullable_fields = ["description"]
1425
- null_default_fields = []
1426
-
1485
+ optional_fields = set(["description", "metadata", "prompt"])
1486
+ nullable_fields = set(["description"])
1427
1487
  serialized = handler(self)
1428
-
1429
1488
  m = {}
1430
1489
 
1431
1490
  for n, f in type(self).model_fields.items():
1432
1491
  k = f.alias or n
1433
1492
  val = serialized.get(k)
1434
- serialized.pop(k, None)
1435
-
1436
- optional_nullable = k in optional_fields and k in nullable_fields
1437
- is_set = (
1438
- self.__pydantic_fields_set__.intersection({n})
1439
- or k in null_default_fields
1440
- ) # pylint: disable=no-member
1441
-
1442
- if val is not None and val != UNSET_SENTINEL:
1443
- m[k] = val
1444
- elif val != UNSET_SENTINEL and (
1445
- not k in optional_fields or (optional_nullable and is_set)
1446
- ):
1447
- m[k] = val
1493
+ is_nullable_and_explicitly_set = (
1494
+ k in nullable_fields
1495
+ and (self.__pydantic_fields_set__.intersection({n})) # pylint: disable=no-member
1496
+ )
1497
+
1498
+ if val != UNSET_SENTINEL:
1499
+ if (
1500
+ val is not None
1501
+ or k not in optional_fields
1502
+ or is_nullable_and_explicitly_set
1503
+ ):
1504
+ m[k] = val
1448
1505
 
1449
1506
  return m
1450
1507
 
@@ -1452,7 +1509,7 @@ class CreatePromptRequestBody(BaseModel):
1452
1509
  CreatePromptPromptsType = Literal["prompt",]
1453
1510
 
1454
1511
 
1455
- CreatePromptModelType = Literal[
1512
+ ModelType = Literal[
1456
1513
  "chat",
1457
1514
  "completion",
1458
1515
  "embedding",
@@ -1460,6 +1517,7 @@ CreatePromptModelType = Literal[
1460
1517
  "tts",
1461
1518
  "stt",
1462
1519
  "rerank",
1520
+ "ocr",
1463
1521
  "moderation",
1464
1522
  "vision",
1465
1523
  ]
@@ -1500,39 +1558,47 @@ CreatePromptResponseFormat4 = Literal[
1500
1558
  ]
1501
1559
 
1502
1560
 
1503
- CreatePromptResponseFormatPromptsResponse200ApplicationJSONType = Literal["text",]
1561
+ CreatePromptResponseFormatPromptsResponse200ApplicationJSONResponseBodyPromptConfigModelParametersType = Literal[
1562
+ "text",
1563
+ ]
1504
1564
 
1505
1565
 
1506
1566
  class CreatePromptResponseFormat3TypedDict(TypedDict):
1507
- type: CreatePromptResponseFormatPromptsResponse200ApplicationJSONType
1567
+ type: CreatePromptResponseFormatPromptsResponse200ApplicationJSONResponseBodyPromptConfigModelParametersType
1508
1568
 
1509
1569
 
1510
1570
  class CreatePromptResponseFormat3(BaseModel):
1511
- type: CreatePromptResponseFormatPromptsResponse200ApplicationJSONType
1571
+ type: CreatePromptResponseFormatPromptsResponse200ApplicationJSONResponseBodyPromptConfigModelParametersType
1512
1572
 
1513
1573
 
1514
- CreatePromptResponseFormatPromptsResponse200Type = Literal["json_object",]
1574
+ CreatePromptResponseFormatPromptsResponse200ApplicationJSONResponseBodyPromptConfigType = Literal[
1575
+ "json_object",
1576
+ ]
1515
1577
 
1516
1578
 
1517
1579
  class CreatePromptResponseFormat2TypedDict(TypedDict):
1518
- type: CreatePromptResponseFormatPromptsResponse200Type
1580
+ type: CreatePromptResponseFormatPromptsResponse200ApplicationJSONResponseBodyPromptConfigType
1519
1581
 
1520
1582
 
1521
1583
  class CreatePromptResponseFormat2(BaseModel):
1522
- type: CreatePromptResponseFormatPromptsResponse200Type
1584
+ type: CreatePromptResponseFormatPromptsResponse200ApplicationJSONResponseBodyPromptConfigType
1523
1585
 
1524
1586
 
1525
- CreatePromptResponseFormatPromptsResponseType = Literal["json_schema",]
1587
+ CreatePromptResponseFormatPromptsResponse200ApplicationJSONResponseBodyType = Literal[
1588
+ "json_schema",
1589
+ ]
1526
1590
 
1527
1591
 
1528
- class CreatePromptResponseFormatPromptsResponseJSONSchemaTypedDict(TypedDict):
1592
+ class CreatePromptResponseFormatPromptsResponse200ApplicationJSONJSONSchemaTypedDict(
1593
+ TypedDict
1594
+ ):
1529
1595
  name: str
1530
1596
  schema_: Dict[str, Any]
1531
1597
  description: NotRequired[str]
1532
1598
  strict: NotRequired[bool]
1533
1599
 
1534
1600
 
1535
- class CreatePromptResponseFormatPromptsResponseJSONSchema(BaseModel):
1601
+ class CreatePromptResponseFormatPromptsResponse200ApplicationJSONJSONSchema(BaseModel):
1536
1602
  name: str
1537
1603
 
1538
1604
  schema_: Annotated[Dict[str, Any], pydantic.Field(alias="schema")]
@@ -1541,20 +1607,54 @@ class CreatePromptResponseFormatPromptsResponseJSONSchema(BaseModel):
1541
1607
 
1542
1608
  strict: Optional[bool] = None
1543
1609
 
1610
+ @model_serializer(mode="wrap")
1611
+ def serialize_model(self, handler):
1612
+ optional_fields = set(["description", "strict"])
1613
+ serialized = handler(self)
1614
+ m = {}
1615
+
1616
+ for n, f in type(self).model_fields.items():
1617
+ k = f.alias or n
1618
+ val = serialized.get(k)
1619
+
1620
+ if val != UNSET_SENTINEL:
1621
+ if val is not None or k not in optional_fields:
1622
+ m[k] = val
1623
+
1624
+ return m
1625
+
1544
1626
 
1545
1627
  class CreatePromptResponseFormat1TypedDict(TypedDict):
1546
- type: CreatePromptResponseFormatPromptsResponseType
1547
- json_schema: CreatePromptResponseFormatPromptsResponseJSONSchemaTypedDict
1628
+ type: CreatePromptResponseFormatPromptsResponse200ApplicationJSONResponseBodyType
1629
+ json_schema: (
1630
+ CreatePromptResponseFormatPromptsResponse200ApplicationJSONJSONSchemaTypedDict
1631
+ )
1548
1632
  display_name: NotRequired[str]
1549
1633
 
1550
1634
 
1551
1635
  class CreatePromptResponseFormat1(BaseModel):
1552
- type: CreatePromptResponseFormatPromptsResponseType
1636
+ type: CreatePromptResponseFormatPromptsResponse200ApplicationJSONResponseBodyType
1553
1637
 
1554
- json_schema: CreatePromptResponseFormatPromptsResponseJSONSchema
1638
+ json_schema: CreatePromptResponseFormatPromptsResponse200ApplicationJSONJSONSchema
1555
1639
 
1556
1640
  display_name: Optional[str] = None
1557
1641
 
1642
+ @model_serializer(mode="wrap")
1643
+ def serialize_model(self, handler):
1644
+ optional_fields = set(["display_name"])
1645
+ serialized = handler(self)
1646
+ m = {}
1647
+
1648
+ for n, f in type(self).model_fields.items():
1649
+ k = f.alias or n
1650
+ val = serialized.get(k)
1651
+
1652
+ if val != UNSET_SENTINEL:
1653
+ if val is not None or k not in optional_fields:
1654
+ m[k] = val
1655
+
1656
+ return m
1657
+
1558
1658
 
1559
1659
  CreatePromptPromptsResponseResponseFormatTypedDict = TypeAliasType(
1560
1660
  "CreatePromptPromptsResponseResponseFormatTypedDict",
@@ -1612,7 +1712,7 @@ CreatePromptEncodingFormat = Literal[
1612
1712
  r"""The format to return the embeddings"""
1613
1713
 
1614
1714
 
1615
- CreatePromptPromptsReasoningEffort = Literal[
1715
+ CreatePromptPromptsResponseReasoningEffort = Literal[
1616
1716
  "none",
1617
1717
  "disable",
1618
1718
  "minimal",
@@ -1631,14 +1731,14 @@ CreatePromptVerbosity = Literal[
1631
1731
  r"""Controls the verbosity of the model output."""
1632
1732
 
1633
1733
 
1634
- CreatePromptPromptsThinkingLevel = Literal[
1734
+ CreatePromptThinkingLevel = Literal[
1635
1735
  "low",
1636
1736
  "high",
1637
1737
  ]
1638
1738
  r"""The level of thinking to use for the model. Only supported by `Google AI`"""
1639
1739
 
1640
1740
 
1641
- class CreatePromptModelParametersTypedDict(TypedDict):
1741
+ class ModelParametersTypedDict(TypedDict):
1642
1742
  r"""Model Parameters: Not all parameters apply to every model"""
1643
1743
 
1644
1744
  temperature: NotRequired[float]
@@ -1680,17 +1780,17 @@ class CreatePromptModelParametersTypedDict(TypedDict):
1680
1780
  r"""The version of photoReal to use. Must be v1 or v2. Only available for `leonardoai` provider"""
1681
1781
  encoding_format: NotRequired[CreatePromptEncodingFormat]
1682
1782
  r"""The format to return the embeddings"""
1683
- reasoning_effort: NotRequired[CreatePromptPromptsReasoningEffort]
1783
+ reasoning_effort: NotRequired[CreatePromptPromptsResponseReasoningEffort]
1684
1784
  r"""Constrains effort on reasoning for reasoning models. Reducing reasoning effort can result in faster responses and fewer tokens used on reasoning in a response."""
1685
1785
  budget_tokens: NotRequired[float]
1686
1786
  r"""Gives the model enhanced reasoning capabilities for complex tasks. A value of 0 disables thinking. The minimum budget tokens for thinking are 1024. The Budget Tokens should never exceed the Max Tokens parameter. Only supported by `Anthropic`"""
1687
1787
  verbosity: NotRequired[CreatePromptVerbosity]
1688
1788
  r"""Controls the verbosity of the model output."""
1689
- thinking_level: NotRequired[CreatePromptPromptsThinkingLevel]
1789
+ thinking_level: NotRequired[CreatePromptThinkingLevel]
1690
1790
  r"""The level of thinking to use for the model. Only supported by `Google AI`"""
1691
1791
 
1692
1792
 
1693
- class CreatePromptModelParameters(BaseModel):
1793
+ class ModelParameters(BaseModel):
1694
1794
  r"""Model Parameters: Not all parameters apply to every model"""
1695
1795
 
1696
1796
  temperature: Optional[float] = None
@@ -1757,7 +1857,7 @@ class CreatePromptModelParameters(BaseModel):
1757
1857
  r"""The format to return the embeddings"""
1758
1858
 
1759
1859
  reasoning_effort: Annotated[
1760
- Optional[CreatePromptPromptsReasoningEffort],
1860
+ Optional[CreatePromptPromptsResponseReasoningEffort],
1761
1861
  pydantic.Field(alias="reasoningEffort"),
1762
1862
  ] = None
1763
1863
  r"""Constrains effort on reasoning for reasoning models. Reducing reasoning effort can result in faster responses and fewer tokens used on reasoning in a response."""
@@ -1767,403 +1867,1803 @@ class CreatePromptModelParameters(BaseModel):
1767
1867
  )
1768
1868
  r"""Gives the model enhanced reasoning capabilities for complex tasks. A value of 0 disables thinking. The minimum budget tokens for thinking are 1024. The Budget Tokens should never exceed the Max Tokens parameter. Only supported by `Anthropic`"""
1769
1869
 
1770
- verbosity: Optional[CreatePromptVerbosity] = None
1771
- r"""Controls the verbosity of the model output."""
1870
+ verbosity: Optional[CreatePromptVerbosity] = None
1871
+ r"""Controls the verbosity of the model output."""
1872
+
1873
+ thinking_level: Annotated[
1874
+ Optional[CreatePromptThinkingLevel], pydantic.Field(alias="thinkingLevel")
1875
+ ] = None
1876
+ r"""The level of thinking to use for the model. Only supported by `Google AI`"""
1877
+
1878
+ @model_serializer(mode="wrap")
1879
+ def serialize_model(self, handler):
1880
+ optional_fields = set(
1881
+ [
1882
+ "temperature",
1883
+ "maxTokens",
1884
+ "topK",
1885
+ "topP",
1886
+ "frequencyPenalty",
1887
+ "presencePenalty",
1888
+ "numImages",
1889
+ "seed",
1890
+ "format",
1891
+ "dimensions",
1892
+ "quality",
1893
+ "style",
1894
+ "responseFormat",
1895
+ "photoRealVersion",
1896
+ "encoding_format",
1897
+ "reasoningEffort",
1898
+ "budgetTokens",
1899
+ "verbosity",
1900
+ "thinkingLevel",
1901
+ ]
1902
+ )
1903
+ nullable_fields = set(["responseFormat"])
1904
+ serialized = handler(self)
1905
+ m = {}
1906
+
1907
+ for n, f in type(self).model_fields.items():
1908
+ k = f.alias or n
1909
+ val = serialized.get(k)
1910
+ is_nullable_and_explicitly_set = (
1911
+ k in nullable_fields
1912
+ and (self.__pydantic_fields_set__.intersection({n})) # pylint: disable=no-member
1913
+ )
1914
+
1915
+ if val != UNSET_SENTINEL:
1916
+ if (
1917
+ val is not None
1918
+ or k not in optional_fields
1919
+ or is_nullable_and_explicitly_set
1920
+ ):
1921
+ m[k] = val
1922
+
1923
+ return m
1924
+
1925
+
1926
+ CreatePromptProvider = Literal[
1927
+ "openai",
1928
+ "groq",
1929
+ "cohere",
1930
+ "azure",
1931
+ "aws",
1932
+ "google",
1933
+ "google-ai",
1934
+ "huggingface",
1935
+ "togetherai",
1936
+ "perplexity",
1937
+ "anthropic",
1938
+ "leonardoai",
1939
+ "fal",
1940
+ "nvidia",
1941
+ "jina",
1942
+ "elevenlabs",
1943
+ "litellm",
1944
+ "cerebras",
1945
+ "openailike",
1946
+ "bytedance",
1947
+ "mistral",
1948
+ "deepseek",
1949
+ "contextualai",
1950
+ "moonshotai",
1951
+ "zai",
1952
+ "slack",
1953
+ ]
1954
+
1955
+
1956
+ CreatePromptRole = Literal[
1957
+ "system",
1958
+ "assistant",
1959
+ "user",
1960
+ "exception",
1961
+ "tool",
1962
+ "prompt",
1963
+ "correction",
1964
+ "expected_output",
1965
+ ]
1966
+ r"""The role of the prompt message"""
1967
+
1968
+
1969
+ CreatePrompt2PromptsResponse200ApplicationJSONType = Literal["file",]
1970
+ r"""The type of the content part. Always `file`."""
1971
+
1972
+
1973
+ class CreatePrompt2FileTypedDict(TypedDict):
1974
+ file_data: NotRequired[str]
1975
+ r"""The file data as a data URI string in the format 'data:<mime-type>;base64,<base64-encoded-data>'. Example: '...'"""
1976
+ uri: NotRequired[str]
1977
+ r"""URL to the file. Only supported by Anthropic Claude models for PDF files."""
1978
+ mime_type: NotRequired[str]
1979
+ r"""MIME type of the file (e.g., application/pdf, image/png)"""
1980
+ filename: NotRequired[str]
1981
+ r"""The name of the file, used when passing the file to the model as a string."""
1982
+
1983
+
1984
+ class CreatePrompt2File(BaseModel):
1985
+ file_data: Optional[str] = None
1986
+ r"""The file data as a data URI string in the format 'data:<mime-type>;base64,<base64-encoded-data>'. Example: '...'"""
1987
+
1988
+ uri: Optional[str] = None
1989
+ r"""URL to the file. Only supported by Anthropic Claude models for PDF files."""
1990
+
1991
+ mime_type: Annotated[Optional[str], pydantic.Field(alias="mimeType")] = None
1992
+ r"""MIME type of the file (e.g., application/pdf, image/png)"""
1993
+
1994
+ filename: Optional[str] = None
1995
+ r"""The name of the file, used when passing the file to the model as a string."""
1996
+
1997
+ @model_serializer(mode="wrap")
1998
+ def serialize_model(self, handler):
1999
+ optional_fields = set(["file_data", "uri", "mimeType", "filename"])
2000
+ serialized = handler(self)
2001
+ m = {}
2002
+
2003
+ for n, f in type(self).model_fields.items():
2004
+ k = f.alias or n
2005
+ val = serialized.get(k)
2006
+
2007
+ if val != UNSET_SENTINEL:
2008
+ if val is not None or k not in optional_fields:
2009
+ m[k] = val
2010
+
2011
+ return m
2012
+
2013
+
2014
+ class CreatePrompt23TypedDict(TypedDict):
2015
+ type: CreatePrompt2PromptsResponse200ApplicationJSONType
2016
+ r"""The type of the content part. Always `file`."""
2017
+ file: CreatePrompt2FileTypedDict
2018
+
2019
+
2020
+ class CreatePrompt23(BaseModel):
2021
+ type: CreatePrompt2PromptsResponse200ApplicationJSONType
2022
+ r"""The type of the content part. Always `file`."""
2023
+
2024
+ file: CreatePrompt2File
2025
+
2026
+
2027
+ CreatePrompt2PromptsResponse200Type = Literal["image_url",]
2028
+
2029
+
2030
+ class CreatePrompt2ImageURLTypedDict(TypedDict):
2031
+ url: str
2032
+ r"""Either a URL of the image or the base64 encoded data URI."""
2033
+ id: NotRequired[str]
2034
+ r"""The orq.ai id of the image"""
2035
+ detail: NotRequired[str]
2036
+ r"""Specifies the detail level of the image. Currently only supported with OpenAI models"""
2037
+
2038
+
2039
+ class CreatePrompt2ImageURL(BaseModel):
2040
+ url: str
2041
+ r"""Either a URL of the image or the base64 encoded data URI."""
2042
+
2043
+ id: Optional[str] = None
2044
+ r"""The orq.ai id of the image"""
2045
+
2046
+ detail: Optional[str] = None
2047
+ r"""Specifies the detail level of the image. Currently only supported with OpenAI models"""
2048
+
2049
+ @model_serializer(mode="wrap")
2050
+ def serialize_model(self, handler):
2051
+ optional_fields = set(["id", "detail"])
2052
+ serialized = handler(self)
2053
+ m = {}
2054
+
2055
+ for n, f in type(self).model_fields.items():
2056
+ k = f.alias or n
2057
+ val = serialized.get(k)
2058
+
2059
+ if val != UNSET_SENTINEL:
2060
+ if val is not None or k not in optional_fields:
2061
+ m[k] = val
2062
+
2063
+ return m
2064
+
2065
+
2066
+ class CreatePrompt22TypedDict(TypedDict):
2067
+ r"""The image part of the prompt message. Only supported with vision models."""
2068
+
2069
+ type: CreatePrompt2PromptsResponse200Type
2070
+ image_url: CreatePrompt2ImageURLTypedDict
2071
+
2072
+
2073
+ class CreatePrompt22(BaseModel):
2074
+ r"""The image part of the prompt message. Only supported with vision models."""
2075
+
2076
+ type: CreatePrompt2PromptsResponse200Type
2077
+
2078
+ image_url: CreatePrompt2ImageURL
2079
+
2080
+
2081
+ CreatePrompt2PromptsResponseType = Literal["text",]
2082
+
2083
+
2084
+ class CreatePrompt21TypedDict(TypedDict):
2085
+ r"""Text content part of a prompt message"""
2086
+
2087
+ type: CreatePrompt2PromptsResponseType
2088
+ text: str
2089
+
2090
+
2091
+ class CreatePrompt21(BaseModel):
2092
+ r"""Text content part of a prompt message"""
2093
+
2094
+ type: CreatePrompt2PromptsResponseType
2095
+
2096
+ text: str
2097
+
2098
+
2099
+ CreatePromptContentPromptsResponse2TypedDict = TypeAliasType(
2100
+ "CreatePromptContentPromptsResponse2TypedDict",
2101
+ Union[CreatePrompt21TypedDict, CreatePrompt22TypedDict, CreatePrompt23TypedDict],
2102
+ )
2103
+
2104
+
2105
+ CreatePromptContentPromptsResponse2 = Annotated[
2106
+ Union[
2107
+ Annotated[CreatePrompt21, Tag("text")],
2108
+ Annotated[CreatePrompt22, Tag("image_url")],
2109
+ Annotated[CreatePrompt23, Tag("file")],
2110
+ ],
2111
+ Discriminator(lambda m: get_discriminator(m, "type", "type")),
2112
+ ]
2113
+
2114
+
2115
+ CreatePromptContentTypedDict = TypeAliasType(
2116
+ "CreatePromptContentTypedDict",
2117
+ Union[str, List[CreatePromptContentPromptsResponse2TypedDict]],
2118
+ )
2119
+ r"""The contents of the user message. Either the text content of the message or an array of content parts with a defined type, each can be of type `text` or `image_url` when passing in images. You can pass multiple images by adding multiple `image_url` content parts. Can be null for tool messages in certain scenarios."""
2120
+
2121
+
2122
+ CreatePromptContent = TypeAliasType(
2123
+ "CreatePromptContent", Union[str, List[CreatePromptContentPromptsResponse2]]
2124
+ )
2125
+ r"""The contents of the user message. Either the text content of the message or an array of content parts with a defined type, each can be of type `text` or `image_url` when passing in images. You can pass multiple images by adding multiple `image_url` content parts. Can be null for tool messages in certain scenarios."""
2126
+
2127
+
2128
+ CreatePromptPromptsResponse200Type = Literal["function",]
2129
+
2130
+
2131
+ class CreatePromptFunctionTypedDict(TypedDict):
2132
+ name: str
2133
+ arguments: str
2134
+ r"""JSON string arguments for the functions"""
2135
+
2136
+
2137
+ class CreatePromptFunction(BaseModel):
2138
+ name: str
2139
+
2140
+ arguments: str
2141
+ r"""JSON string arguments for the functions"""
2142
+
2143
+
2144
+ class CreatePromptToolCallsTypedDict(TypedDict):
2145
+ type: CreatePromptPromptsResponse200Type
2146
+ function: CreatePromptFunctionTypedDict
2147
+ id: NotRequired[str]
2148
+ index: NotRequired[float]
2149
+
2150
+
2151
+ class CreatePromptToolCalls(BaseModel):
2152
+ type: CreatePromptPromptsResponse200Type
2153
+
2154
+ function: CreatePromptFunction
2155
+
2156
+ id: Optional[str] = None
2157
+
2158
+ index: Optional[float] = None
2159
+
2160
+ @model_serializer(mode="wrap")
2161
+ def serialize_model(self, handler):
2162
+ optional_fields = set(["id", "index"])
2163
+ serialized = handler(self)
2164
+ m = {}
2165
+
2166
+ for n, f in type(self).model_fields.items():
2167
+ k = f.alias or n
2168
+ val = serialized.get(k)
2169
+
2170
+ if val != UNSET_SENTINEL:
2171
+ if val is not None or k not in optional_fields:
2172
+ m[k] = val
2173
+
2174
+ return m
2175
+
2176
+
2177
+ class CreatePromptPromptsMessagesTypedDict(TypedDict):
2178
+ role: CreatePromptRole
2179
+ r"""The role of the prompt message"""
2180
+ content: Nullable[CreatePromptContentTypedDict]
2181
+ r"""The contents of the user message. Either the text content of the message or an array of content parts with a defined type, each can be of type `text` or `image_url` when passing in images. You can pass multiple images by adding multiple `image_url` content parts. Can be null for tool messages in certain scenarios."""
2182
+ tool_calls: NotRequired[List[CreatePromptToolCallsTypedDict]]
2183
+ tool_call_id: NotRequired[Nullable[str]]
2184
+
2185
+
2186
+ class CreatePromptPromptsMessages(BaseModel):
2187
+ role: CreatePromptRole
2188
+ r"""The role of the prompt message"""
2189
+
2190
+ content: Nullable[CreatePromptContent]
2191
+ r"""The contents of the user message. Either the text content of the message or an array of content parts with a defined type, each can be of type `text` or `image_url` when passing in images. You can pass multiple images by adding multiple `image_url` content parts. Can be null for tool messages in certain scenarios."""
2192
+
2193
+ tool_calls: Optional[List[CreatePromptToolCalls]] = None
2194
+
2195
+ tool_call_id: OptionalNullable[str] = UNSET
2196
+
2197
+ @model_serializer(mode="wrap")
2198
+ def serialize_model(self, handler):
2199
+ optional_fields = set(["tool_calls", "tool_call_id"])
2200
+ nullable_fields = set(["content", "tool_call_id"])
2201
+ serialized = handler(self)
2202
+ m = {}
2203
+
2204
+ for n, f in type(self).model_fields.items():
2205
+ k = f.alias or n
2206
+ val = serialized.get(k)
2207
+ is_nullable_and_explicitly_set = (
2208
+ k in nullable_fields
2209
+ and (self.__pydantic_fields_set__.intersection({n})) # pylint: disable=no-member
2210
+ )
2211
+
2212
+ if val != UNSET_SENTINEL:
2213
+ if (
2214
+ val is not None
2215
+ or k not in optional_fields
2216
+ or is_nullable_and_explicitly_set
2217
+ ):
2218
+ m[k] = val
2219
+
2220
+ return m
2221
+
2222
+
2223
+ @deprecated(
2224
+ "warning: ** DEPRECATED ** - This will be removed in a future release, please migrate away from it as soon as possible."
2225
+ )
2226
+ class PromptConfigTypedDict(TypedDict):
2227
+ r"""[DEPRECATED] Use the `prompt` property instead. A list of messages compatible with the openAI schema."""
2228
+
2229
+ messages: List[CreatePromptPromptsMessagesTypedDict]
2230
+ stream: NotRequired[bool]
2231
+ model: NotRequired[Nullable[str]]
2232
+ model_db_id: NotRequired[Nullable[str]]
2233
+ r"""The id of the resource"""
2234
+ model_type: NotRequired[Nullable[ModelType]]
2235
+ r"""The modality of the model"""
2236
+ model_parameters: NotRequired[ModelParametersTypedDict]
2237
+ r"""Model Parameters: Not all parameters apply to every model"""
2238
+ provider: NotRequired[Nullable[CreatePromptProvider]]
2239
+ integration_id: NotRequired[Nullable[str]]
2240
+ r"""The ID of the integration to use"""
2241
+ version: NotRequired[str]
2242
+
2243
+
2244
+ @deprecated(
2245
+ "warning: ** DEPRECATED ** - This will be removed in a future release, please migrate away from it as soon as possible."
2246
+ )
2247
+ class PromptConfig(BaseModel):
2248
+ r"""[DEPRECATED] Use the `prompt` property instead. A list of messages compatible with the openAI schema."""
2249
+
2250
+ messages: List[CreatePromptPromptsMessages]
2251
+
2252
+ stream: Optional[bool] = None
2253
+
2254
+ model: OptionalNullable[str] = UNSET
2255
+
2256
+ model_db_id: OptionalNullable[str] = UNSET
2257
+ r"""The id of the resource"""
2258
+
2259
+ model_type: OptionalNullable[ModelType] = UNSET
2260
+ r"""The modality of the model"""
2261
+
2262
+ model_parameters: Optional[ModelParameters] = None
2263
+ r"""Model Parameters: Not all parameters apply to every model"""
2264
+
2265
+ provider: OptionalNullable[CreatePromptProvider] = UNSET
2266
+
2267
+ integration_id: OptionalNullable[str] = UNSET
2268
+ r"""The ID of the integration to use"""
2269
+
2270
+ version: Optional[str] = None
2271
+
2272
+ @model_serializer(mode="wrap")
2273
+ def serialize_model(self, handler):
2274
+ optional_fields = set(
2275
+ [
2276
+ "stream",
2277
+ "model",
2278
+ "model_db_id",
2279
+ "model_type",
2280
+ "model_parameters",
2281
+ "provider",
2282
+ "integration_id",
2283
+ "version",
2284
+ ]
2285
+ )
2286
+ nullable_fields = set(
2287
+ ["model", "model_db_id", "model_type", "provider", "integration_id"]
2288
+ )
2289
+ serialized = handler(self)
2290
+ m = {}
2291
+
2292
+ for n, f in type(self).model_fields.items():
2293
+ k = f.alias or n
2294
+ val = serialized.get(k)
2295
+ is_nullable_and_explicitly_set = (
2296
+ k in nullable_fields
2297
+ and (self.__pydantic_fields_set__.intersection({n})) # pylint: disable=no-member
2298
+ )
2299
+
2300
+ if val != UNSET_SENTINEL:
2301
+ if (
2302
+ val is not None
2303
+ or k not in optional_fields
2304
+ or is_nullable_and_explicitly_set
2305
+ ):
2306
+ m[k] = val
2307
+
2308
+ return m
2309
+
2310
+
2311
+ CreatePromptPromptsVoice = Literal[
2312
+ "alloy",
2313
+ "echo",
2314
+ "fable",
2315
+ "onyx",
2316
+ "nova",
2317
+ "shimmer",
2318
+ ]
2319
+ r"""The voice the model uses to respond. Supported voices are alloy, echo, fable, onyx, nova, and shimmer."""
2320
+
2321
+
2322
+ CreatePromptPromptsResponse200Format = Literal[
2323
+ "wav",
2324
+ "mp3",
2325
+ "flac",
2326
+ "opus",
2327
+ "pcm16",
2328
+ ]
2329
+ r"""Specifies the output audio format. Must be one of wav, mp3, flac, opus, or pcm16."""
2330
+
2331
+
2332
+ class CreatePromptPromptsAudioTypedDict(TypedDict):
2333
+ r"""Parameters for audio output. Required when audio output is requested with modalities: [\"audio\"]. Learn more."""
2334
+
2335
+ voice: CreatePromptPromptsVoice
2336
+ r"""The voice the model uses to respond. Supported voices are alloy, echo, fable, onyx, nova, and shimmer."""
2337
+ format_: CreatePromptPromptsResponse200Format
2338
+ r"""Specifies the output audio format. Must be one of wav, mp3, flac, opus, or pcm16."""
2339
+
2340
+
2341
+ class CreatePromptPromptsAudio(BaseModel):
2342
+ r"""Parameters for audio output. Required when audio output is requested with modalities: [\"audio\"]. Learn more."""
2343
+
2344
+ voice: CreatePromptPromptsVoice
2345
+ r"""The voice the model uses to respond. Supported voices are alloy, echo, fable, onyx, nova, and shimmer."""
2346
+
2347
+ format_: Annotated[
2348
+ CreatePromptPromptsResponse200Format, pydantic.Field(alias="format")
2349
+ ]
2350
+ r"""Specifies the output audio format. Must be one of wav, mp3, flac, opus, or pcm16."""
2351
+
2352
+
2353
+ CreatePromptResponseFormatPromptsResponse200ApplicationJSONType = Literal[
2354
+ "json_schema",
2355
+ ]
2356
+
2357
+
2358
+ class CreatePromptResponseFormatPromptsResponseJSONSchemaTypedDict(TypedDict):
2359
+ name: str
2360
+ r"""The name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64."""
2361
+ description: NotRequired[str]
2362
+ r"""A description of what the response format is for, used by the model to determine how to respond in the format."""
2363
+ schema_: NotRequired[Any]
2364
+ r"""The schema for the response format, described as a JSON Schema object."""
2365
+ strict: NotRequired[bool]
2366
+ r"""Whether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the schema field. Only a subset of JSON Schema is supported when strict is true."""
2367
+
2368
+
2369
+ class CreatePromptResponseFormatPromptsResponseJSONSchema(BaseModel):
2370
+ name: str
2371
+ r"""The name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64."""
2372
+
2373
+ description: Optional[str] = None
2374
+ r"""A description of what the response format is for, used by the model to determine how to respond in the format."""
2375
+
2376
+ schema_: Annotated[Optional[Any], pydantic.Field(alias="schema")] = None
2377
+ r"""The schema for the response format, described as a JSON Schema object."""
2378
+
2379
+ strict: Optional[bool] = False
2380
+ r"""Whether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the schema field. Only a subset of JSON Schema is supported when strict is true."""
2381
+
2382
+ @model_serializer(mode="wrap")
2383
+ def serialize_model(self, handler):
2384
+ optional_fields = set(["description", "schema", "strict"])
2385
+ serialized = handler(self)
2386
+ m = {}
2387
+
2388
+ for n, f in type(self).model_fields.items():
2389
+ k = f.alias or n
2390
+ val = serialized.get(k)
2391
+
2392
+ if val != UNSET_SENTINEL:
2393
+ if val is not None or k not in optional_fields:
2394
+ m[k] = val
2395
+
2396
+ return m
2397
+
2398
+
2399
+ class CreatePromptResponseFormatPromptsResponse200JSONSchemaTypedDict(TypedDict):
2400
+ r"""
2401
+
2402
+ JSON Schema response format. Used to generate structured JSON responses
2403
+ """
2404
+
2405
+ type: CreatePromptResponseFormatPromptsResponse200ApplicationJSONType
2406
+ json_schema: CreatePromptResponseFormatPromptsResponseJSONSchemaTypedDict
2407
+
2408
+
2409
+ class CreatePromptResponseFormatPromptsResponse200JSONSchema(BaseModel):
2410
+ r"""
2411
+
2412
+ JSON Schema response format. Used to generate structured JSON responses
2413
+ """
2414
+
2415
+ type: CreatePromptResponseFormatPromptsResponse200ApplicationJSONType
2416
+
2417
+ json_schema: CreatePromptResponseFormatPromptsResponseJSONSchema
2418
+
2419
+
2420
+ CreatePromptResponseFormatPromptsResponse200Type = Literal["json_object",]
2421
+
2422
+
2423
+ class CreatePromptResponseFormatPromptsJSONObjectTypedDict(TypedDict):
2424
+ r"""
2425
+
2426
+ JSON object response format. An older method of generating JSON responses. Using `json_schema` is recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.
2427
+ """
2428
+
2429
+ type: CreatePromptResponseFormatPromptsResponse200Type
2430
+
2431
+
2432
+ class CreatePromptResponseFormatPromptsJSONObject(BaseModel):
2433
+ r"""
2434
+
2435
+ JSON object response format. An older method of generating JSON responses. Using `json_schema` is recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.
2436
+ """
2437
+
2438
+ type: CreatePromptResponseFormatPromptsResponse200Type
2439
+
2440
+
2441
+ CreatePromptResponseFormatPromptsResponseType = Literal["text",]
2442
+
2443
+
2444
+ class CreatePromptResponseFormatPromptsTextTypedDict(TypedDict):
2445
+ r"""
2446
+
2447
+ Default response format. Used to generate text responses
2448
+ """
2449
+
2450
+ type: CreatePromptResponseFormatPromptsResponseType
2451
+
2452
+
2453
+ class CreatePromptResponseFormatPromptsText(BaseModel):
2454
+ r"""
2455
+
2456
+ Default response format. Used to generate text responses
2457
+ """
2458
+
2459
+ type: CreatePromptResponseFormatPromptsResponseType
2460
+
2461
+
2462
+ CreatePromptPromptsResponseFormatTypedDict = TypeAliasType(
2463
+ "CreatePromptPromptsResponseFormatTypedDict",
2464
+ Union[
2465
+ CreatePromptResponseFormatPromptsTextTypedDict,
2466
+ CreatePromptResponseFormatPromptsJSONObjectTypedDict,
2467
+ CreatePromptResponseFormatPromptsResponse200JSONSchemaTypedDict,
2468
+ ],
2469
+ )
2470
+ r"""An object specifying the format that the model must output"""
2471
+
2472
+
2473
+ CreatePromptPromptsResponseFormat = Annotated[
2474
+ Union[
2475
+ Annotated[CreatePromptResponseFormatPromptsText, Tag("text")],
2476
+ Annotated[CreatePromptResponseFormatPromptsJSONObject, Tag("json_object")],
2477
+ Annotated[
2478
+ CreatePromptResponseFormatPromptsResponse200JSONSchema, Tag("json_schema")
2479
+ ],
2480
+ ],
2481
+ Discriminator(lambda m: get_discriminator(m, "type", "type")),
2482
+ ]
2483
+ r"""An object specifying the format that the model must output"""
2484
+
2485
+
2486
+ CreatePromptPromptsReasoningEffort = Literal[
2487
+ "none",
2488
+ "minimal",
2489
+ "low",
2490
+ "medium",
2491
+ "high",
2492
+ "xhigh",
2493
+ ]
2494
+ r"""Constrains effort on reasoning for [reasoning models](https://platform.openai.com/docs/guides/reasoning). Currently supported values are `none`, `minimal`, `low`, `medium`, `high`, and `xhigh`. Reducing reasoning effort can result in faster responses and fewer tokens used on reasoning in a response.
2495
+
2496
+ - `gpt-5.1` defaults to `none`, which does not perform reasoning. The supported reasoning values for `gpt-5.1` are `none`, `low`, `medium`, and `high`. Tool calls are supported for all reasoning values in gpt-5.1.
2497
+ - All models before `gpt-5.1` default to `medium` reasoning effort, and do not support `none`.
2498
+ - The `gpt-5-pro` model defaults to (and only supports) `high` reasoning effort.
2499
+ - `xhigh` is currently only supported for `gpt-5.1-codex-max`.
2500
+
2501
+ Any of \"none\", \"minimal\", \"low\", \"medium\", \"high\", \"xhigh\".
2502
+ """
2503
+
2504
+
2505
+ CreatePromptPromptsStopTypedDict = TypeAliasType(
2506
+ "CreatePromptPromptsStopTypedDict", Union[str, List[str]]
2507
+ )
2508
+ r"""Up to 4 sequences where the API will stop generating further tokens."""
2509
+
2510
+
2511
+ CreatePromptPromptsStop = TypeAliasType(
2512
+ "CreatePromptPromptsStop", Union[str, List[str]]
2513
+ )
2514
+ r"""Up to 4 sequences where the API will stop generating further tokens."""
2515
+
2516
+
2517
+ class CreatePromptPromptsStreamOptionsTypedDict(TypedDict):
2518
+ r"""Options for streaming response. Only set this when you set stream: true."""
2519
+
2520
+ include_usage: NotRequired[bool]
2521
+ r"""If set, an additional chunk will be streamed before the data: [DONE] message. The usage field on this chunk shows the token usage statistics for the entire request, and the choices field will always be an empty array. All other chunks will also include a usage field, but with a null value."""
2522
+
2523
+
2524
+ class CreatePromptPromptsStreamOptions(BaseModel):
2525
+ r"""Options for streaming response. Only set this when you set stream: true."""
2526
+
2527
+ include_usage: Optional[bool] = None
2528
+ r"""If set, an additional chunk will be streamed before the data: [DONE] message. The usage field on this chunk shows the token usage statistics for the entire request, and the choices field will always be an empty array. All other chunks will also include a usage field, but with a null value."""
2529
+
2530
+ @model_serializer(mode="wrap")
2531
+ def serialize_model(self, handler):
2532
+ optional_fields = set(["include_usage"])
2533
+ serialized = handler(self)
2534
+ m = {}
2535
+
2536
+ for n, f in type(self).model_fields.items():
2537
+ k = f.alias or n
2538
+ val = serialized.get(k)
2539
+
2540
+ if val != UNSET_SENTINEL:
2541
+ if val is not None or k not in optional_fields:
2542
+ m[k] = val
2543
+
2544
+ return m
2545
+
2546
+
2547
+ CreatePromptPromptsThinkingTypedDict = TypeAliasType(
2548
+ "CreatePromptPromptsThinkingTypedDict",
2549
+ Union[ThinkingConfigDisabledSchemaTypedDict, ThinkingConfigEnabledSchemaTypedDict],
2550
+ )
2551
+
2552
+
2553
+ CreatePromptPromptsThinking = Annotated[
2554
+ Union[
2555
+ Annotated[ThinkingConfigDisabledSchema, Tag("disabled")],
2556
+ Annotated[ThinkingConfigEnabledSchema, Tag("enabled")],
2557
+ ],
2558
+ Discriminator(lambda m: get_discriminator(m, "type", "type")),
2559
+ ]
2560
+
2561
+
2562
+ CreatePromptToolChoicePromptsType = Literal["function",]
2563
+ r"""The type of the tool. Currently, only function is supported."""
2564
+
2565
+
2566
+ class CreatePromptToolChoicePromptsFunctionTypedDict(TypedDict):
2567
+ name: str
2568
+ r"""The name of the function to call."""
2569
+
2570
+
2571
+ class CreatePromptToolChoicePromptsFunction(BaseModel):
2572
+ name: str
2573
+ r"""The name of the function to call."""
2574
+
2575
+
2576
+ class CreatePromptToolChoicePrompts2TypedDict(TypedDict):
2577
+ function: CreatePromptToolChoicePromptsFunctionTypedDict
2578
+ type: NotRequired[CreatePromptToolChoicePromptsType]
2579
+ r"""The type of the tool. Currently, only function is supported."""
2580
+
2581
+
2582
+ class CreatePromptToolChoicePrompts2(BaseModel):
2583
+ function: CreatePromptToolChoicePromptsFunction
2584
+
2585
+ type: Optional[CreatePromptToolChoicePromptsType] = None
2586
+ r"""The type of the tool. Currently, only function is supported."""
2587
+
2588
+ @model_serializer(mode="wrap")
2589
+ def serialize_model(self, handler):
2590
+ optional_fields = set(["type"])
2591
+ serialized = handler(self)
2592
+ m = {}
2593
+
2594
+ for n, f in type(self).model_fields.items():
2595
+ k = f.alias or n
2596
+ val = serialized.get(k)
2597
+
2598
+ if val != UNSET_SENTINEL:
2599
+ if val is not None or k not in optional_fields:
2600
+ m[k] = val
2601
+
2602
+ return m
2603
+
2604
+
2605
+ CreatePromptToolChoicePrompts1 = Literal[
2606
+ "none",
2607
+ "auto",
2608
+ "required",
2609
+ ]
2610
+
2611
+
2612
+ CreatePromptPromptsToolChoiceTypedDict = TypeAliasType(
2613
+ "CreatePromptPromptsToolChoiceTypedDict",
2614
+ Union[CreatePromptToolChoicePrompts2TypedDict, CreatePromptToolChoicePrompts1],
2615
+ )
2616
+ r"""Controls which (if any) tool is called by the model."""
2617
+
2618
+
2619
+ CreatePromptPromptsToolChoice = TypeAliasType(
2620
+ "CreatePromptPromptsToolChoice",
2621
+ Union[CreatePromptToolChoicePrompts2, CreatePromptToolChoicePrompts1],
2622
+ )
2623
+ r"""Controls which (if any) tool is called by the model."""
2624
+
2625
+
2626
+ CreatePromptPromptsModalities = Literal[
2627
+ "text",
2628
+ "audio",
2629
+ ]
2630
+
2631
+
2632
+ CreatePromptIDPrompts1 = Literal[
2633
+ "orq_pii_detection",
2634
+ "orq_sexual_moderation",
2635
+ "orq_harmful_moderation",
2636
+ ]
2637
+ r"""The key of the guardrail."""
2638
+
2639
+
2640
+ CreatePromptPromptsIDTypedDict = TypeAliasType(
2641
+ "CreatePromptPromptsIDTypedDict", Union[CreatePromptIDPrompts1, str]
2642
+ )
2643
+
2644
+
2645
+ CreatePromptPromptsID = TypeAliasType(
2646
+ "CreatePromptPromptsID", Union[CreatePromptIDPrompts1, str]
2647
+ )
2648
+
2649
+
2650
+ CreatePromptPromptsExecuteOn = Literal[
2651
+ "input",
2652
+ "output",
2653
+ ]
2654
+ r"""Determines whether the guardrail runs on the input (user message) or output (model response)."""
2655
+
2656
+
2657
+ class CreatePromptPromptsGuardrailsTypedDict(TypedDict):
2658
+ id: CreatePromptPromptsIDTypedDict
2659
+ execute_on: CreatePromptPromptsExecuteOn
2660
+ r"""Determines whether the guardrail runs on the input (user message) or output (model response)."""
2661
+
2662
+
2663
+ class CreatePromptPromptsGuardrails(BaseModel):
2664
+ id: CreatePromptPromptsID
2665
+
2666
+ execute_on: CreatePromptPromptsExecuteOn
2667
+ r"""Determines whether the guardrail runs on the input (user message) or output (model response)."""
2668
+
2669
+
2670
+ class CreatePromptPromptsFallbacksTypedDict(TypedDict):
2671
+ model: str
2672
+ r"""Fallback model identifier"""
2673
+
2674
+
2675
+ class CreatePromptPromptsFallbacks(BaseModel):
2676
+ model: str
2677
+ r"""Fallback model identifier"""
2678
+
2679
+
2680
+ class CreatePromptPromptsRetryTypedDict(TypedDict):
2681
+ r"""Retry configuration for the request"""
2682
+
2683
+ count: NotRequired[float]
2684
+ r"""Number of retry attempts (1-5)"""
2685
+ on_codes: NotRequired[List[float]]
2686
+ r"""HTTP status codes that trigger retry logic"""
2687
+
2688
+
2689
+ class CreatePromptPromptsRetry(BaseModel):
2690
+ r"""Retry configuration for the request"""
2691
+
2692
+ count: Optional[float] = 3
2693
+ r"""Number of retry attempts (1-5)"""
2694
+
2695
+ on_codes: Optional[List[float]] = None
2696
+ r"""HTTP status codes that trigger retry logic"""
2697
+
2698
+ @model_serializer(mode="wrap")
2699
+ def serialize_model(self, handler):
2700
+ optional_fields = set(["count", "on_codes"])
2701
+ serialized = handler(self)
2702
+ m = {}
2703
+
2704
+ for n, f in type(self).model_fields.items():
2705
+ k = f.alias or n
2706
+ val = serialized.get(k)
2707
+
2708
+ if val != UNSET_SENTINEL:
2709
+ if val is not None or k not in optional_fields:
2710
+ m[k] = val
2711
+
2712
+ return m
2713
+
2714
+
2715
+ CreatePromptPromptsResponseType = Literal["exact_match",]
2716
+
2717
+
2718
+ class CreatePromptPromptsCacheTypedDict(TypedDict):
2719
+ r"""Cache configuration for the request."""
2720
+
2721
+ type: CreatePromptPromptsResponseType
2722
+ ttl: NotRequired[float]
2723
+ r"""Time to live for cached responses in seconds. Maximum 259200 seconds (3 days)."""
2724
+
2725
+
2726
+ class CreatePromptPromptsCache(BaseModel):
2727
+ r"""Cache configuration for the request."""
2728
+
2729
+ type: CreatePromptPromptsResponseType
2730
+
2731
+ ttl: Optional[float] = 1800
2732
+ r"""Time to live for cached responses in seconds. Maximum 259200 seconds (3 days)."""
2733
+
2734
+ @model_serializer(mode="wrap")
2735
+ def serialize_model(self, handler):
2736
+ optional_fields = set(["ttl"])
2737
+ serialized = handler(self)
2738
+ m = {}
2739
+
2740
+ for n, f in type(self).model_fields.items():
2741
+ k = f.alias or n
2742
+ val = serialized.get(k)
2743
+
2744
+ if val != UNSET_SENTINEL:
2745
+ if val is not None or k not in optional_fields:
2746
+ m[k] = val
2747
+
2748
+ return m
2749
+
2750
+
2751
+ CreatePromptLoadBalancerPromptsType = Literal["weight_based",]
2752
+
2753
+
2754
+ class CreatePromptLoadBalancerPromptsModelsTypedDict(TypedDict):
2755
+ model: str
2756
+ r"""Model identifier for load balancing"""
2757
+ weight: NotRequired[float]
2758
+ r"""Weight assigned to this model for load balancing"""
2759
+
2760
+
2761
+ class CreatePromptLoadBalancerPromptsModels(BaseModel):
2762
+ model: str
2763
+ r"""Model identifier for load balancing"""
2764
+
2765
+ weight: Optional[float] = 0.5
2766
+ r"""Weight assigned to this model for load balancing"""
2767
+
2768
+ @model_serializer(mode="wrap")
2769
+ def serialize_model(self, handler):
2770
+ optional_fields = set(["weight"])
2771
+ serialized = handler(self)
2772
+ m = {}
2773
+
2774
+ for n, f in type(self).model_fields.items():
2775
+ k = f.alias or n
2776
+ val = serialized.get(k)
2777
+
2778
+ if val != UNSET_SENTINEL:
2779
+ if val is not None or k not in optional_fields:
2780
+ m[k] = val
2781
+
2782
+ return m
2783
+
2784
+
2785
+ class CreatePromptLoadBalancerPrompts1TypedDict(TypedDict):
2786
+ type: CreatePromptLoadBalancerPromptsType
2787
+ models: List[CreatePromptLoadBalancerPromptsModelsTypedDict]
2788
+
2789
+
2790
+ class CreatePromptLoadBalancerPrompts1(BaseModel):
2791
+ type: CreatePromptLoadBalancerPromptsType
2792
+
2793
+ models: List[CreatePromptLoadBalancerPromptsModels]
2794
+
2795
+
2796
+ CreatePromptPromptsLoadBalancerTypedDict = CreatePromptLoadBalancerPrompts1TypedDict
2797
+ r"""Load balancer configuration for the request."""
2798
+
2799
+
2800
+ CreatePromptPromptsLoadBalancer = CreatePromptLoadBalancerPrompts1
2801
+ r"""Load balancer configuration for the request."""
2802
+
2803
+
2804
+ class CreatePromptPromptsTimeoutTypedDict(TypedDict):
2805
+ r"""Timeout configuration to apply to the request. If the request exceeds the timeout, it will be retried or fallback to the next model if configured."""
2806
+
2807
+ call_timeout: float
2808
+ r"""Timeout value in milliseconds"""
2809
+
2810
+
2811
+ class CreatePromptPromptsTimeout(BaseModel):
2812
+ r"""Timeout configuration to apply to the request. If the request exceeds the timeout, it will be retried or fallback to the next model if configured."""
2813
+
2814
+ call_timeout: float
2815
+ r"""Timeout value in milliseconds"""
2816
+
2817
+
2818
+ CreatePromptMessagesPromptsResponse200ApplicationJSONResponseBodyRole = Literal["tool",]
2819
+ r"""The role of the messages author, in this case tool."""
2820
+
2821
+
2822
+ CreatePromptContentPromptsResponse200ApplicationJSONResponseBody2TypedDict = (
2823
+ TextContentPartSchemaTypedDict
2824
+ )
2825
+
2826
+
2827
+ CreatePromptContentPromptsResponse200ApplicationJSONResponseBody2 = (
2828
+ TextContentPartSchema
2829
+ )
2830
+
2831
+
2832
+ CreatePromptMessagesPromptsResponse200ApplicationJSONResponseBodyContentTypedDict = TypeAliasType(
2833
+ "CreatePromptMessagesPromptsResponse200ApplicationJSONResponseBodyContentTypedDict",
2834
+ Union[
2835
+ str,
2836
+ List[
2837
+ CreatePromptContentPromptsResponse200ApplicationJSONResponseBody2TypedDict
2838
+ ],
2839
+ ],
2840
+ )
2841
+ r"""The contents of the tool message."""
2842
+
2843
+
2844
+ CreatePromptMessagesPromptsResponse200ApplicationJSONResponseBodyContent = (
2845
+ TypeAliasType(
2846
+ "CreatePromptMessagesPromptsResponse200ApplicationJSONResponseBodyContent",
2847
+ Union[
2848
+ str, List[CreatePromptContentPromptsResponse200ApplicationJSONResponseBody2]
2849
+ ],
2850
+ )
2851
+ )
2852
+ r"""The contents of the tool message."""
2853
+
2854
+
2855
+ CreatePromptMessagesPromptsResponse200Type = Literal["ephemeral",]
2856
+ r"""Create a cache control breakpoint at this content block. Accepts only the value \"ephemeral\"."""
2857
+
2858
+
2859
+ CreatePromptMessagesPromptsTTL = Literal[
2860
+ "5m",
2861
+ "1h",
2862
+ ]
2863
+ r"""The time-to-live for the cache control breakpoint. This may be one of the following values:
2864
+
2865
+ - `5m`: 5 minutes
2866
+ - `1h`: 1 hour
2867
+
2868
+ Defaults to `5m`. Only supported by `Anthropic` Claude models.
2869
+ """
2870
+
2871
+
2872
+ class CreatePromptMessagesPromptsCacheControlTypedDict(TypedDict):
2873
+ type: CreatePromptMessagesPromptsResponse200Type
2874
+ r"""Create a cache control breakpoint at this content block. Accepts only the value \"ephemeral\"."""
2875
+ ttl: NotRequired[CreatePromptMessagesPromptsTTL]
2876
+ r"""The time-to-live for the cache control breakpoint. This may be one of the following values:
2877
+
2878
+ - `5m`: 5 minutes
2879
+ - `1h`: 1 hour
2880
+
2881
+ Defaults to `5m`. Only supported by `Anthropic` Claude models.
2882
+ """
2883
+
2884
+
2885
+ class CreatePromptMessagesPromptsCacheControl(BaseModel):
2886
+ type: CreatePromptMessagesPromptsResponse200Type
2887
+ r"""Create a cache control breakpoint at this content block. Accepts only the value \"ephemeral\"."""
2888
+
2889
+ ttl: Optional[CreatePromptMessagesPromptsTTL] = "5m"
2890
+ r"""The time-to-live for the cache control breakpoint. This may be one of the following values:
2891
+
2892
+ - `5m`: 5 minutes
2893
+ - `1h`: 1 hour
2894
+
2895
+ Defaults to `5m`. Only supported by `Anthropic` Claude models.
2896
+ """
2897
+
2898
+ @model_serializer(mode="wrap")
2899
+ def serialize_model(self, handler):
2900
+ optional_fields = set(["ttl"])
2901
+ serialized = handler(self)
2902
+ m = {}
2903
+
2904
+ for n, f in type(self).model_fields.items():
2905
+ k = f.alias or n
2906
+ val = serialized.get(k)
2907
+
2908
+ if val != UNSET_SENTINEL:
2909
+ if val is not None or k not in optional_fields:
2910
+ m[k] = val
2911
+
2912
+ return m
2913
+
2914
+
2915
+ class CreatePromptMessagesPromptsToolMessageTypedDict(TypedDict):
2916
+ role: CreatePromptMessagesPromptsResponse200ApplicationJSONResponseBodyRole
2917
+ r"""The role of the messages author, in this case tool."""
2918
+ content: CreatePromptMessagesPromptsResponse200ApplicationJSONResponseBodyContentTypedDict
2919
+ r"""The contents of the tool message."""
2920
+ tool_call_id: Nullable[str]
2921
+ r"""Tool call that this message is responding to."""
2922
+ cache_control: NotRequired[CreatePromptMessagesPromptsCacheControlTypedDict]
2923
+
2924
+
2925
+ class CreatePromptMessagesPromptsToolMessage(BaseModel):
2926
+ role: CreatePromptMessagesPromptsResponse200ApplicationJSONResponseBodyRole
2927
+ r"""The role of the messages author, in this case tool."""
2928
+
2929
+ content: CreatePromptMessagesPromptsResponse200ApplicationJSONResponseBodyContent
2930
+ r"""The contents of the tool message."""
2931
+
2932
+ tool_call_id: Nullable[str]
2933
+ r"""Tool call that this message is responding to."""
2934
+
2935
+ cache_control: Optional[CreatePromptMessagesPromptsCacheControl] = None
2936
+
2937
+ @model_serializer(mode="wrap")
2938
+ def serialize_model(self, handler):
2939
+ optional_fields = set(["cache_control"])
2940
+ nullable_fields = set(["tool_call_id"])
2941
+ serialized = handler(self)
2942
+ m = {}
2943
+
2944
+ for n, f in type(self).model_fields.items():
2945
+ k = f.alias or n
2946
+ val = serialized.get(k)
2947
+ is_nullable_and_explicitly_set = (
2948
+ k in nullable_fields
2949
+ and (self.__pydantic_fields_set__.intersection({n})) # pylint: disable=no-member
2950
+ )
2951
+
2952
+ if val != UNSET_SENTINEL:
2953
+ if (
2954
+ val is not None
2955
+ or k not in optional_fields
2956
+ or is_nullable_and_explicitly_set
2957
+ ):
2958
+ m[k] = val
2959
+
2960
+ return m
2961
+
2962
+
2963
+ CreatePromptContentPromptsResponse200ApplicationJSON2TypedDict = TypeAliasType(
2964
+ "CreatePromptContentPromptsResponse200ApplicationJSON2TypedDict",
2965
+ Union[
2966
+ RefusalPartSchemaTypedDict,
2967
+ RedactedReasoningPartSchemaTypedDict,
2968
+ TextContentPartSchemaTypedDict,
2969
+ ReasoningPartSchemaTypedDict,
2970
+ ],
2971
+ )
2972
+
2973
+
2974
+ CreatePromptContentPromptsResponse200ApplicationJSON2 = Annotated[
2975
+ Union[
2976
+ Annotated[TextContentPartSchema, Tag("text")],
2977
+ Annotated[RefusalPartSchema, Tag("refusal")],
2978
+ Annotated[ReasoningPartSchema, Tag("reasoning")],
2979
+ Annotated[RedactedReasoningPartSchema, Tag("redacted_reasoning")],
2980
+ ],
2981
+ Discriminator(lambda m: get_discriminator(m, "type", "type")),
2982
+ ]
2983
+
2984
+
2985
+ CreatePromptMessagesPromptsResponse200ApplicationJSONContentTypedDict = TypeAliasType(
2986
+ "CreatePromptMessagesPromptsResponse200ApplicationJSONContentTypedDict",
2987
+ Union[str, List[CreatePromptContentPromptsResponse200ApplicationJSON2TypedDict]],
2988
+ )
2989
+ r"""The contents of the assistant message. Required unless `tool_calls` or `function_call` is specified."""
2990
+
2991
+
2992
+ CreatePromptMessagesPromptsResponse200ApplicationJSONContent = TypeAliasType(
2993
+ "CreatePromptMessagesPromptsResponse200ApplicationJSONContent",
2994
+ Union[str, List[CreatePromptContentPromptsResponse200ApplicationJSON2]],
2995
+ )
2996
+ r"""The contents of the assistant message. Required unless `tool_calls` or `function_call` is specified."""
2997
+
2998
+
2999
+ CreatePromptMessagesPromptsResponse200ApplicationJSONRole = Literal["assistant",]
3000
+ r"""The role of the messages author, in this case `assistant`."""
3001
+
3002
+
3003
+ class CreatePromptMessagesPromptsAudioTypedDict(TypedDict):
3004
+ r"""Data about a previous audio response from the model."""
3005
+
3006
+ id: str
3007
+ r"""Unique identifier for a previous audio response from the model."""
3008
+
3009
+
3010
+ class CreatePromptMessagesPromptsAudio(BaseModel):
3011
+ r"""Data about a previous audio response from the model."""
3012
+
3013
+ id: str
3014
+ r"""Unique identifier for a previous audio response from the model."""
3015
+
3016
+
3017
+ CreatePromptMessagesPromptsResponseType = Literal["function",]
3018
+ r"""The type of the tool. Currently, only `function` is supported."""
3019
+
3020
+
3021
+ class CreatePromptMessagesPromptsFunctionTypedDict(TypedDict):
3022
+ name: NotRequired[str]
3023
+ r"""The name of the function to call."""
3024
+ arguments: NotRequired[str]
3025
+ r"""The arguments to call the function with, as generated by the model in JSON format. Note that the model does not always generate valid JSON, and may hallucinate parameters not defined by your function schema. Validate the arguments in your code before calling your function."""
3026
+
3027
+
3028
+ class CreatePromptMessagesPromptsFunction(BaseModel):
3029
+ name: Optional[str] = None
3030
+ r"""The name of the function to call."""
3031
+
3032
+ arguments: Optional[str] = None
3033
+ r"""The arguments to call the function with, as generated by the model in JSON format. Note that the model does not always generate valid JSON, and may hallucinate parameters not defined by your function schema. Validate the arguments in your code before calling your function."""
3034
+
3035
+ @model_serializer(mode="wrap")
3036
+ def serialize_model(self, handler):
3037
+ optional_fields = set(["name", "arguments"])
3038
+ serialized = handler(self)
3039
+ m = {}
3040
+
3041
+ for n, f in type(self).model_fields.items():
3042
+ k = f.alias or n
3043
+ val = serialized.get(k)
3044
+
3045
+ if val != UNSET_SENTINEL:
3046
+ if val is not None or k not in optional_fields:
3047
+ m[k] = val
3048
+
3049
+ return m
3050
+
3051
+
3052
+ class CreatePromptMessagesPromptsToolCallsTypedDict(TypedDict):
3053
+ id: str
3054
+ r"""The ID of the tool call."""
3055
+ type: CreatePromptMessagesPromptsResponseType
3056
+ r"""The type of the tool. Currently, only `function` is supported."""
3057
+ function: CreatePromptMessagesPromptsFunctionTypedDict
3058
+ thought_signature: NotRequired[str]
3059
+ r"""Encrypted representation of the model internal reasoning state during function calling. Required by Gemini 3 models when continuing a conversation after a tool call."""
3060
+
3061
+
3062
+ class CreatePromptMessagesPromptsToolCalls(BaseModel):
3063
+ id: str
3064
+ r"""The ID of the tool call."""
3065
+
3066
+ type: CreatePromptMessagesPromptsResponseType
3067
+ r"""The type of the tool. Currently, only `function` is supported."""
3068
+
3069
+ function: CreatePromptMessagesPromptsFunction
3070
+
3071
+ thought_signature: Optional[str] = None
3072
+ r"""Encrypted representation of the model internal reasoning state during function calling. Required by Gemini 3 models when continuing a conversation after a tool call."""
3073
+
3074
+ @model_serializer(mode="wrap")
3075
+ def serialize_model(self, handler):
3076
+ optional_fields = set(["thought_signature"])
3077
+ serialized = handler(self)
3078
+ m = {}
3079
+
3080
+ for n, f in type(self).model_fields.items():
3081
+ k = f.alias or n
3082
+ val = serialized.get(k)
3083
+
3084
+ if val != UNSET_SENTINEL:
3085
+ if val is not None or k not in optional_fields:
3086
+ m[k] = val
3087
+
3088
+ return m
3089
+
3090
+
3091
+ class CreatePromptMessagesPromptsAssistantMessageTypedDict(TypedDict):
3092
+ role: CreatePromptMessagesPromptsResponse200ApplicationJSONRole
3093
+ r"""The role of the messages author, in this case `assistant`."""
3094
+ content: NotRequired[
3095
+ Nullable[CreatePromptMessagesPromptsResponse200ApplicationJSONContentTypedDict]
3096
+ ]
3097
+ r"""The contents of the assistant message. Required unless `tool_calls` or `function_call` is specified."""
3098
+ refusal: NotRequired[Nullable[str]]
3099
+ r"""The refusal message by the assistant."""
3100
+ name: NotRequired[str]
3101
+ r"""An optional name for the participant. Provides the model information to differentiate between participants of the same role."""
3102
+ audio: NotRequired[Nullable[CreatePromptMessagesPromptsAudioTypedDict]]
3103
+ r"""Data about a previous audio response from the model."""
3104
+ tool_calls: NotRequired[List[CreatePromptMessagesPromptsToolCallsTypedDict]]
3105
+ r"""The tool calls generated by the model, such as function calls."""
3106
+
3107
+
3108
+ class CreatePromptMessagesPromptsAssistantMessage(BaseModel):
3109
+ role: CreatePromptMessagesPromptsResponse200ApplicationJSONRole
3110
+ r"""The role of the messages author, in this case `assistant`."""
3111
+
3112
+ content: OptionalNullable[
3113
+ CreatePromptMessagesPromptsResponse200ApplicationJSONContent
3114
+ ] = UNSET
3115
+ r"""The contents of the assistant message. Required unless `tool_calls` or `function_call` is specified."""
3116
+
3117
+ refusal: OptionalNullable[str] = UNSET
3118
+ r"""The refusal message by the assistant."""
3119
+
3120
+ name: Optional[str] = None
3121
+ r"""An optional name for the participant. Provides the model information to differentiate between participants of the same role."""
3122
+
3123
+ audio: OptionalNullable[CreatePromptMessagesPromptsAudio] = UNSET
3124
+ r"""Data about a previous audio response from the model."""
3125
+
3126
+ tool_calls: Optional[List[CreatePromptMessagesPromptsToolCalls]] = None
3127
+ r"""The tool calls generated by the model, such as function calls."""
3128
+
3129
+ @model_serializer(mode="wrap")
3130
+ def serialize_model(self, handler):
3131
+ optional_fields = set(["content", "refusal", "name", "audio", "tool_calls"])
3132
+ nullable_fields = set(["content", "refusal", "audio"])
3133
+ serialized = handler(self)
3134
+ m = {}
3135
+
3136
+ for n, f in type(self).model_fields.items():
3137
+ k = f.alias or n
3138
+ val = serialized.get(k)
3139
+ is_nullable_and_explicitly_set = (
3140
+ k in nullable_fields
3141
+ and (self.__pydantic_fields_set__.intersection({n})) # pylint: disable=no-member
3142
+ )
3143
+
3144
+ if val != UNSET_SENTINEL:
3145
+ if (
3146
+ val is not None
3147
+ or k not in optional_fields
3148
+ or is_nullable_and_explicitly_set
3149
+ ):
3150
+ m[k] = val
3151
+
3152
+ return m
3153
+
3154
+
3155
+ CreatePromptMessagesPromptsResponse200Role = Literal["user",]
3156
+ r"""The role of the messages author, in this case `user`."""
3157
+
3158
+
3159
+ CreatePrompt2PromptsResponse200ApplicationJSONResponseBodyType = Literal["file",]
3160
+ r"""The type of the content part. Always `file`."""
3161
+
3162
+
3163
+ CreatePrompt2PromptsResponse200ApplicationJSONResponseBodyPromptType = Literal[
3164
+ "ephemeral",
3165
+ ]
3166
+ r"""Create a cache control breakpoint at this content block. Accepts only the value \"ephemeral\"."""
3167
+
3168
+
3169
+ CreatePrompt2PromptsTTL = Literal[
3170
+ "5m",
3171
+ "1h",
3172
+ ]
3173
+ r"""The time-to-live for the cache control breakpoint. This may be one of the following values:
3174
+
3175
+ - `5m`: 5 minutes
3176
+ - `1h`: 1 hour
3177
+
3178
+ Defaults to `5m`. Only supported by `Anthropic` Claude models.
3179
+ """
3180
+
3181
+
3182
+ class CreatePrompt2PromptsCacheControlTypedDict(TypedDict):
3183
+ type: CreatePrompt2PromptsResponse200ApplicationJSONResponseBodyPromptType
3184
+ r"""Create a cache control breakpoint at this content block. Accepts only the value \"ephemeral\"."""
3185
+ ttl: NotRequired[CreatePrompt2PromptsTTL]
3186
+ r"""The time-to-live for the cache control breakpoint. This may be one of the following values:
3187
+
3188
+ - `5m`: 5 minutes
3189
+ - `1h`: 1 hour
3190
+
3191
+ Defaults to `5m`. Only supported by `Anthropic` Claude models.
3192
+ """
3193
+
3194
+
3195
+ class CreatePrompt2PromptsCacheControl(BaseModel):
3196
+ type: CreatePrompt2PromptsResponse200ApplicationJSONResponseBodyPromptType
3197
+ r"""Create a cache control breakpoint at this content block. Accepts only the value \"ephemeral\"."""
3198
+
3199
+ ttl: Optional[CreatePrompt2PromptsTTL] = "5m"
3200
+ r"""The time-to-live for the cache control breakpoint. This may be one of the following values:
3201
+
3202
+ - `5m`: 5 minutes
3203
+ - `1h`: 1 hour
3204
+
3205
+ Defaults to `5m`. Only supported by `Anthropic` Claude models.
3206
+ """
3207
+
3208
+ @model_serializer(mode="wrap")
3209
+ def serialize_model(self, handler):
3210
+ optional_fields = set(["ttl"])
3211
+ serialized = handler(self)
3212
+ m = {}
3213
+
3214
+ for n, f in type(self).model_fields.items():
3215
+ k = f.alias or n
3216
+ val = serialized.get(k)
3217
+
3218
+ if val != UNSET_SENTINEL:
3219
+ if val is not None or k not in optional_fields:
3220
+ m[k] = val
3221
+
3222
+ return m
3223
+
3224
+
3225
+ class CreatePrompt2Prompts4TypedDict(TypedDict):
3226
+ type: CreatePrompt2PromptsResponse200ApplicationJSONResponseBodyType
3227
+ r"""The type of the content part. Always `file`."""
3228
+ file: FileContentPartSchemaTypedDict
3229
+ r"""File data for the content part. Must contain either file_data or uri, but not both."""
3230
+ cache_control: NotRequired[CreatePrompt2PromptsCacheControlTypedDict]
3231
+
3232
+
3233
+ class CreatePrompt2Prompts4(BaseModel):
3234
+ type: CreatePrompt2PromptsResponse200ApplicationJSONResponseBodyType
3235
+ r"""The type of the content part. Always `file`."""
3236
+
3237
+ file: FileContentPartSchema
3238
+ r"""File data for the content part. Must contain either file_data or uri, but not both."""
1772
3239
 
1773
- thinking_level: Annotated[
1774
- Optional[CreatePromptPromptsThinkingLevel],
1775
- pydantic.Field(alias="thinkingLevel"),
1776
- ] = None
1777
- r"""The level of thinking to use for the model. Only supported by `Google AI`"""
3240
+ cache_control: Optional[CreatePrompt2PromptsCacheControl] = None
1778
3241
 
1779
3242
  @model_serializer(mode="wrap")
1780
3243
  def serialize_model(self, handler):
1781
- optional_fields = [
1782
- "temperature",
1783
- "maxTokens",
1784
- "topK",
1785
- "topP",
1786
- "frequencyPenalty",
1787
- "presencePenalty",
1788
- "numImages",
1789
- "seed",
1790
- "format",
1791
- "dimensions",
1792
- "quality",
1793
- "style",
1794
- "responseFormat",
1795
- "photoRealVersion",
1796
- "encoding_format",
1797
- "reasoningEffort",
1798
- "budgetTokens",
1799
- "verbosity",
1800
- "thinkingLevel",
1801
- ]
1802
- nullable_fields = ["responseFormat"]
1803
- null_default_fields = []
1804
-
3244
+ optional_fields = set(["cache_control"])
1805
3245
  serialized = handler(self)
1806
-
1807
3246
  m = {}
1808
3247
 
1809
3248
  for n, f in type(self).model_fields.items():
1810
3249
  k = f.alias or n
1811
3250
  val = serialized.get(k)
1812
- serialized.pop(k, None)
1813
3251
 
1814
- optional_nullable = k in optional_fields and k in nullable_fields
1815
- is_set = (
1816
- self.__pydantic_fields_set__.intersection({n})
1817
- or k in null_default_fields
1818
- ) # pylint: disable=no-member
1819
-
1820
- if val is not None and val != UNSET_SENTINEL:
1821
- m[k] = val
1822
- elif val != UNSET_SENTINEL and (
1823
- not k in optional_fields or (optional_nullable and is_set)
1824
- ):
1825
- m[k] = val
3252
+ if val != UNSET_SENTINEL:
3253
+ if val is not None or k not in optional_fields:
3254
+ m[k] = val
1826
3255
 
1827
3256
  return m
1828
3257
 
1829
3258
 
1830
- CreatePromptProvider = Literal[
1831
- "openai",
1832
- "groq",
1833
- "cohere",
1834
- "azure",
1835
- "aws",
1836
- "google",
1837
- "google-ai",
1838
- "huggingface",
1839
- "togetherai",
1840
- "perplexity",
1841
- "anthropic",
1842
- "leonardoai",
1843
- "fal",
1844
- "nvidia",
1845
- "jina",
1846
- "elevenlabs",
1847
- "litellm",
1848
- "cerebras",
1849
- "openailike",
1850
- "bytedance",
1851
- "mistral",
1852
- "deepseek",
1853
- "contextualai",
1854
- "moonshotai",
1855
- "zai",
1856
- "slack",
1857
- ]
3259
+ CreatePromptContentPromptsResponse2002TypedDict = TypeAliasType(
3260
+ "CreatePromptContentPromptsResponse2002TypedDict",
3261
+ Union[
3262
+ AudioContentPartSchemaTypedDict,
3263
+ TextContentPartSchemaTypedDict,
3264
+ ImageContentPartSchemaTypedDict,
3265
+ CreatePrompt2Prompts4TypedDict,
3266
+ ],
3267
+ )
1858
3268
 
1859
3269
 
1860
- CreatePromptPromptsRole = Literal[
1861
- "system",
1862
- "assistant",
1863
- "user",
1864
- "exception",
1865
- "tool",
1866
- "prompt",
1867
- "correction",
1868
- "expected_output",
3270
+ CreatePromptContentPromptsResponse2002 = Annotated[
3271
+ Union[
3272
+ Annotated[TextContentPartSchema, Tag("text")],
3273
+ Annotated[ImageContentPartSchema, Tag("image_url")],
3274
+ Annotated[AudioContentPartSchema, Tag("input_audio")],
3275
+ Annotated[CreatePrompt2Prompts4, Tag("file")],
3276
+ ],
3277
+ Discriminator(lambda m: get_discriminator(m, "type", "type")),
1869
3278
  ]
1870
- r"""The role of the prompt message"""
1871
-
1872
-
1873
- CreatePrompt2PromptsResponse200ApplicationJSONType = Literal["file",]
1874
- r"""The type of the content part. Always `file`."""
1875
3279
 
1876
3280
 
1877
- class CreatePrompt2PromptsFileTypedDict(TypedDict):
1878
- file_data: NotRequired[str]
1879
- r"""The file data as a data URI string in the format 'data:<mime-type>;base64,<base64-encoded-data>'. Example: '...'"""
1880
- uri: NotRequired[str]
1881
- r"""URL to the file. Only supported by Anthropic Claude models for PDF files."""
1882
- mime_type: NotRequired[str]
1883
- r"""MIME type of the file (e.g., application/pdf, image/png)"""
1884
- filename: NotRequired[str]
1885
- r"""The name of the file, used when passing the file to the model as a string."""
1886
-
1887
-
1888
- class CreatePrompt2PromptsFile(BaseModel):
1889
- file_data: Optional[str] = None
1890
- r"""The file data as a data URI string in the format 'data:<mime-type>;base64,<base64-encoded-data>'. Example: '...'"""
1891
-
1892
- uri: Optional[str] = None
1893
- r"""URL to the file. Only supported by Anthropic Claude models for PDF files."""
1894
-
1895
- mime_type: Annotated[Optional[str], pydantic.Field(alias="mimeType")] = None
1896
- r"""MIME type of the file (e.g., application/pdf, image/png)"""
3281
+ CreatePromptMessagesPromptsResponse200ContentTypedDict = TypeAliasType(
3282
+ "CreatePromptMessagesPromptsResponse200ContentTypedDict",
3283
+ Union[str, List[CreatePromptContentPromptsResponse2002TypedDict]],
3284
+ )
3285
+ r"""The contents of the user message."""
1897
3286
 
1898
- filename: Optional[str] = None
1899
- r"""The name of the file, used when passing the file to the model as a string."""
1900
3287
 
3288
+ CreatePromptMessagesPromptsResponse200Content = TypeAliasType(
3289
+ "CreatePromptMessagesPromptsResponse200Content",
3290
+ Union[str, List[CreatePromptContentPromptsResponse2002]],
3291
+ )
3292
+ r"""The contents of the user message."""
1901
3293
 
1902
- class CreatePrompt23TypedDict(TypedDict):
1903
- type: CreatePrompt2PromptsResponse200ApplicationJSONType
1904
- r"""The type of the content part. Always `file`."""
1905
- file: CreatePrompt2PromptsFileTypedDict
1906
3294
 
3295
+ class CreatePromptMessagesPromptsUserMessageTypedDict(TypedDict):
3296
+ role: CreatePromptMessagesPromptsResponse200Role
3297
+ r"""The role of the messages author, in this case `user`."""
3298
+ content: CreatePromptMessagesPromptsResponse200ContentTypedDict
3299
+ r"""The contents of the user message."""
3300
+ name: NotRequired[str]
3301
+ r"""An optional name for the participant. Provides the model information to differentiate between participants of the same role."""
1907
3302
 
1908
- class CreatePrompt23(BaseModel):
1909
- type: CreatePrompt2PromptsResponse200ApplicationJSONType
1910
- r"""The type of the content part. Always `file`."""
1911
3303
 
1912
- file: CreatePrompt2PromptsFile
3304
+ class CreatePromptMessagesPromptsUserMessage(BaseModel):
3305
+ role: CreatePromptMessagesPromptsResponse200Role
3306
+ r"""The role of the messages author, in this case `user`."""
1913
3307
 
3308
+ content: CreatePromptMessagesPromptsResponse200Content
3309
+ r"""The contents of the user message."""
1914
3310
 
1915
- CreatePrompt2PromptsResponse200Type = Literal["image_url",]
3311
+ name: Optional[str] = None
3312
+ r"""An optional name for the participant. Provides the model information to differentiate between participants of the same role."""
1916
3313
 
3314
+ @model_serializer(mode="wrap")
3315
+ def serialize_model(self, handler):
3316
+ optional_fields = set(["name"])
3317
+ serialized = handler(self)
3318
+ m = {}
1917
3319
 
1918
- class CreatePrompt2PromptsImageURLTypedDict(TypedDict):
1919
- url: str
1920
- r"""Either a URL of the image or the base64 encoded data URI."""
1921
- id: NotRequired[str]
1922
- r"""The orq.ai id of the image"""
1923
- detail: NotRequired[str]
1924
- r"""Specifies the detail level of the image. Currently only supported with OpenAI models"""
3320
+ for n, f in type(self).model_fields.items():
3321
+ k = f.alias or n
3322
+ val = serialized.get(k)
1925
3323
 
3324
+ if val != UNSET_SENTINEL:
3325
+ if val is not None or k not in optional_fields:
3326
+ m[k] = val
1926
3327
 
1927
- class CreatePrompt2PromptsImageURL(BaseModel):
1928
- url: str
1929
- r"""Either a URL of the image or the base64 encoded data URI."""
3328
+ return m
1930
3329
 
1931
- id: Optional[str] = None
1932
- r"""The orq.ai id of the image"""
1933
3330
 
1934
- detail: Optional[str] = None
1935
- r"""Specifies the detail level of the image. Currently only supported with OpenAI models"""
3331
+ CreatePromptMessagesPromptsResponseRole = Literal["system",]
3332
+ r"""The role of the messages author, in this case `system`."""
1936
3333
 
1937
3334
 
1938
- class CreatePrompt2Prompts2TypedDict(TypedDict):
1939
- r"""The image part of the prompt message. Only supported with vision models."""
3335
+ CreatePromptMessagesPromptsResponseContentTypedDict = TypeAliasType(
3336
+ "CreatePromptMessagesPromptsResponseContentTypedDict",
3337
+ Union[str, List[TextContentPartSchemaTypedDict]],
3338
+ )
3339
+ r"""The contents of the system message."""
1940
3340
 
1941
- type: CreatePrompt2PromptsResponse200Type
1942
- image_url: CreatePrompt2PromptsImageURLTypedDict
1943
3341
 
3342
+ CreatePromptMessagesPromptsResponseContent = TypeAliasType(
3343
+ "CreatePromptMessagesPromptsResponseContent",
3344
+ Union[str, List[TextContentPartSchema]],
3345
+ )
3346
+ r"""The contents of the system message."""
1944
3347
 
1945
- class CreatePrompt2Prompts2(BaseModel):
1946
- r"""The image part of the prompt message. Only supported with vision models."""
1947
3348
 
1948
- type: CreatePrompt2PromptsResponse200Type
3349
+ class CreatePromptMessagesPromptsSystemMessageTypedDict(TypedDict):
3350
+ r"""Developer-provided instructions that the model should follow, regardless of messages sent by the user."""
1949
3351
 
1950
- image_url: CreatePrompt2PromptsImageURL
3352
+ role: CreatePromptMessagesPromptsResponseRole
3353
+ r"""The role of the messages author, in this case `system`."""
3354
+ content: CreatePromptMessagesPromptsResponseContentTypedDict
3355
+ r"""The contents of the system message."""
3356
+ name: NotRequired[str]
3357
+ r"""An optional name for the participant. Provides the model information to differentiate between participants of the same role."""
1951
3358
 
1952
3359
 
1953
- CreatePrompt2PromptsResponseType = Literal["text",]
3360
+ class CreatePromptMessagesPromptsSystemMessage(BaseModel):
3361
+ r"""Developer-provided instructions that the model should follow, regardless of messages sent by the user."""
1954
3362
 
3363
+ role: CreatePromptMessagesPromptsResponseRole
3364
+ r"""The role of the messages author, in this case `system`."""
1955
3365
 
1956
- class CreatePrompt2Prompts1TypedDict(TypedDict):
1957
- r"""Text content part of a prompt message"""
3366
+ content: CreatePromptMessagesPromptsResponseContent
3367
+ r"""The contents of the system message."""
1958
3368
 
1959
- type: CreatePrompt2PromptsResponseType
1960
- text: str
3369
+ name: Optional[str] = None
3370
+ r"""An optional name for the participant. Provides the model information to differentiate between participants of the same role."""
1961
3371
 
3372
+ @model_serializer(mode="wrap")
3373
+ def serialize_model(self, handler):
3374
+ optional_fields = set(["name"])
3375
+ serialized = handler(self)
3376
+ m = {}
1962
3377
 
1963
- class CreatePrompt2Prompts1(BaseModel):
1964
- r"""Text content part of a prompt message"""
3378
+ for n, f in type(self).model_fields.items():
3379
+ k = f.alias or n
3380
+ val = serialized.get(k)
1965
3381
 
1966
- type: CreatePrompt2PromptsResponseType
3382
+ if val != UNSET_SENTINEL:
3383
+ if val is not None or k not in optional_fields:
3384
+ m[k] = val
1967
3385
 
1968
- text: str
3386
+ return m
1969
3387
 
1970
3388
 
1971
- CreatePromptContentPromptsResponse2TypedDict = TypeAliasType(
1972
- "CreatePromptContentPromptsResponse2TypedDict",
3389
+ CreatePromptPromptsResponseMessagesTypedDict = TypeAliasType(
3390
+ "CreatePromptPromptsResponseMessagesTypedDict",
1973
3391
  Union[
1974
- CreatePrompt2Prompts1TypedDict,
1975
- CreatePrompt2Prompts2TypedDict,
1976
- CreatePrompt23TypedDict,
3392
+ CreatePromptMessagesPromptsSystemMessageTypedDict,
3393
+ CreatePromptMessagesPromptsUserMessageTypedDict,
3394
+ CreatePromptMessagesPromptsToolMessageTypedDict,
3395
+ CreatePromptMessagesPromptsAssistantMessageTypedDict,
1977
3396
  ],
1978
3397
  )
1979
3398
 
1980
3399
 
1981
- CreatePromptContentPromptsResponse2 = Annotated[
3400
+ CreatePromptPromptsResponseMessages = Annotated[
1982
3401
  Union[
1983
- Annotated[CreatePrompt2Prompts1, Tag("text")],
1984
- Annotated[CreatePrompt2Prompts2, Tag("image_url")],
1985
- Annotated[CreatePrompt23, Tag("file")],
3402
+ Annotated[CreatePromptMessagesPromptsSystemMessage, Tag("system")],
3403
+ Annotated[CreatePromptMessagesPromptsUserMessage, Tag("user")],
3404
+ Annotated[CreatePromptMessagesPromptsAssistantMessage, Tag("assistant")],
3405
+ Annotated[CreatePromptMessagesPromptsToolMessage, Tag("tool")],
1986
3406
  ],
1987
- Discriminator(lambda m: get_discriminator(m, "type", "type")),
3407
+ Discriminator(lambda m: get_discriminator(m, "role", "role")),
1988
3408
  ]
1989
3409
 
1990
3410
 
1991
- CreatePromptPromptsContentTypedDict = TypeAliasType(
1992
- "CreatePromptPromptsContentTypedDict",
1993
- Union[str, List[CreatePromptContentPromptsResponse2TypedDict]],
1994
- )
1995
- r"""The contents of the user message. Either the text content of the message or an array of content parts with a defined type, each can be of type `text` or `image_url` when passing in images. You can pass multiple images by adding multiple `image_url` content parts. Can be null for tool messages in certain scenarios."""
1996
-
1997
-
1998
- CreatePromptPromptsContent = TypeAliasType(
1999
- "CreatePromptPromptsContent", Union[str, List[CreatePromptContentPromptsResponse2]]
2000
- )
2001
- r"""The contents of the user message. Either the text content of the message or an array of content parts with a defined type, each can be of type `text` or `image_url` when passing in images. You can pass multiple images by adding multiple `image_url` content parts. Can be null for tool messages in certain scenarios."""
2002
-
2003
-
2004
- CreatePromptPromptsResponseType = Literal["function",]
3411
+ class PromptFieldTypedDict(TypedDict):
3412
+ r"""Prompt configuration with model and messages. Use this instead of prompt_config."""
2005
3413
 
3414
+ name: NotRequired[str]
3415
+ r"""The name to display on the trace. If not specified, the default system name will be used."""
3416
+ audio: NotRequired[Nullable[CreatePromptPromptsAudioTypedDict]]
3417
+ r"""Parameters for audio output. Required when audio output is requested with modalities: [\"audio\"]. Learn more."""
3418
+ frequency_penalty: NotRequired[Nullable[float]]
3419
+ r"""Number between -2.0 and 2.0. Positive values penalize new tokens based on their existing frequency in the text so far, decreasing the model's likelihood to repeat the same line verbatim."""
3420
+ max_tokens: NotRequired[Nullable[int]]
3421
+ r"""`[Deprecated]`. The maximum number of tokens that can be generated in the chat completion. This value can be used to control costs for text generated via API.
2006
3422
 
2007
- class CreatePromptPromptsFunctionTypedDict(TypedDict):
2008
- name: str
2009
- arguments: str
2010
- r"""JSON string arguments for the functions"""
3423
+ This value is now `deprecated` in favor of `max_completion_tokens`, and is not compatible with o1 series models.
3424
+ """
3425
+ max_completion_tokens: NotRequired[Nullable[int]]
3426
+ r"""An upper bound for the number of tokens that can be generated for a completion, including visible output tokens and reasoning tokens"""
3427
+ logprobs: NotRequired[Nullable[bool]]
3428
+ r"""Whether to return log probabilities of the output tokens or not. If true, returns the log probabilities of each output token returned in the content of message."""
3429
+ top_logprobs: NotRequired[Nullable[int]]
3430
+ r"""An integer between 0 and 20 specifying the number of most likely tokens to return at each token position, each with an associated log probability. logprobs must be set to true if this parameter is used."""
3431
+ n: NotRequired[Nullable[int]]
3432
+ r"""How many chat completion choices to generate for each input message. Note that you will be charged based on the number of generated tokens across all of the choices. Keep n as 1 to minimize costs."""
3433
+ presence_penalty: NotRequired[Nullable[float]]
3434
+ r"""Number between -2.0 and 2.0. Positive values penalize new tokens based on whether they appear in the text so far, increasing the model's likelihood to talk about new topics."""
3435
+ response_format: NotRequired[CreatePromptPromptsResponseFormatTypedDict]
3436
+ r"""An object specifying the format that the model must output"""
3437
+ reasoning_effort: NotRequired[CreatePromptPromptsReasoningEffort]
3438
+ r"""Constrains effort on reasoning for [reasoning models](https://platform.openai.com/docs/guides/reasoning). Currently supported values are `none`, `minimal`, `low`, `medium`, `high`, and `xhigh`. Reducing reasoning effort can result in faster responses and fewer tokens used on reasoning in a response.
2011
3439
 
3440
+ - `gpt-5.1` defaults to `none`, which does not perform reasoning. The supported reasoning values for `gpt-5.1` are `none`, `low`, `medium`, and `high`. Tool calls are supported for all reasoning values in gpt-5.1.
3441
+ - All models before `gpt-5.1` default to `medium` reasoning effort, and do not support `none`.
3442
+ - The `gpt-5-pro` model defaults to (and only supports) `high` reasoning effort.
3443
+ - `xhigh` is currently only supported for `gpt-5.1-codex-max`.
2012
3444
 
2013
- class CreatePromptPromptsFunction(BaseModel):
2014
- name: str
3445
+ Any of \"none\", \"minimal\", \"low\", \"medium\", \"high\", \"xhigh\".
3446
+ """
3447
+ verbosity: NotRequired[str]
3448
+ r"""Adjusts response verbosity. Lower levels yield shorter answers."""
3449
+ seed: NotRequired[Nullable[float]]
3450
+ r"""If specified, our system will make a best effort to sample deterministically, such that repeated requests with the same seed and parameters should return the same result."""
3451
+ stop: NotRequired[Nullable[CreatePromptPromptsStopTypedDict]]
3452
+ r"""Up to 4 sequences where the API will stop generating further tokens."""
3453
+ stream_options: NotRequired[Nullable[CreatePromptPromptsStreamOptionsTypedDict]]
3454
+ r"""Options for streaming response. Only set this when you set stream: true."""
3455
+ thinking: NotRequired[CreatePromptPromptsThinkingTypedDict]
3456
+ temperature: NotRequired[Nullable[float]]
3457
+ r"""What sampling temperature to use, between 0 and 2. Higher values like 0.8 will make the output more random, while lower values like 0.2 will make it more focused and deterministic."""
3458
+ top_p: NotRequired[Nullable[float]]
3459
+ r"""An alternative to sampling with temperature, called nucleus sampling, where the model considers the results of the tokens with top_p probability mass."""
3460
+ top_k: NotRequired[Nullable[float]]
3461
+ r"""Limits the model to consider only the top k most likely tokens at each step."""
3462
+ tool_choice: NotRequired[CreatePromptPromptsToolChoiceTypedDict]
3463
+ r"""Controls which (if any) tool is called by the model."""
3464
+ parallel_tool_calls: NotRequired[bool]
3465
+ r"""Whether to enable parallel function calling during tool use."""
3466
+ modalities: NotRequired[Nullable[List[CreatePromptPromptsModalities]]]
3467
+ r"""Output types that you would like the model to generate. Most models are capable of generating text, which is the default: [\"text\"]. The gpt-4o-audio-preview model can also be used to generate audio. To request that this model generate both text and audio responses, you can use: [\"text\", \"audio\"]."""
3468
+ guardrails: NotRequired[List[CreatePromptPromptsGuardrailsTypedDict]]
3469
+ r"""A list of guardrails to apply to the request."""
3470
+ fallbacks: NotRequired[List[CreatePromptPromptsFallbacksTypedDict]]
3471
+ r"""Array of fallback models to use if primary model fails"""
3472
+ retry: NotRequired[CreatePromptPromptsRetryTypedDict]
3473
+ r"""Retry configuration for the request"""
3474
+ cache: NotRequired[CreatePromptPromptsCacheTypedDict]
3475
+ r"""Cache configuration for the request."""
3476
+ load_balancer: NotRequired[CreatePromptPromptsLoadBalancerTypedDict]
3477
+ r"""Load balancer configuration for the request."""
3478
+ timeout: NotRequired[CreatePromptPromptsTimeoutTypedDict]
3479
+ r"""Timeout configuration to apply to the request. If the request exceeds the timeout, it will be retried or fallback to the next model if configured."""
3480
+ messages: NotRequired[List[CreatePromptPromptsResponseMessagesTypedDict]]
3481
+ r"""Array of messages that make up the conversation. Each message has a role (system, user, assistant, or tool) and content."""
3482
+ model: NotRequired[Nullable[str]]
3483
+ r"""Model ID used to generate the response, like `openai/gpt-4o` or `anthropic/claude-3-5-sonnet-20241022`. For private models, use format: `{workspaceKey}@{provider}/{model}`."""
3484
+ version: NotRequired[str]
2015
3485
 
2016
- arguments: str
2017
- r"""JSON string arguments for the functions"""
2018
3486
 
3487
+ class PromptField(BaseModel):
3488
+ r"""Prompt configuration with model and messages. Use this instead of prompt_config."""
2019
3489
 
2020
- class CreatePromptPromptsToolCallsTypedDict(TypedDict):
2021
- type: CreatePromptPromptsResponseType
2022
- function: CreatePromptPromptsFunctionTypedDict
2023
- id: NotRequired[str]
2024
- index: NotRequired[float]
3490
+ name: Optional[str] = None
3491
+ r"""The name to display on the trace. If not specified, the default system name will be used."""
2025
3492
 
3493
+ audio: OptionalNullable[CreatePromptPromptsAudio] = UNSET
3494
+ r"""Parameters for audio output. Required when audio output is requested with modalities: [\"audio\"]. Learn more."""
2026
3495
 
2027
- class CreatePromptPromptsToolCalls(BaseModel):
2028
- type: CreatePromptPromptsResponseType
3496
+ frequency_penalty: OptionalNullable[float] = UNSET
3497
+ r"""Number between -2.0 and 2.0. Positive values penalize new tokens based on their existing frequency in the text so far, decreasing the model's likelihood to repeat the same line verbatim."""
2029
3498
 
2030
- function: CreatePromptPromptsFunction
3499
+ max_tokens: OptionalNullable[int] = UNSET
3500
+ r"""`[Deprecated]`. The maximum number of tokens that can be generated in the chat completion. This value can be used to control costs for text generated via API.
2031
3501
 
2032
- id: Optional[str] = None
3502
+ This value is now `deprecated` in favor of `max_completion_tokens`, and is not compatible with o1 series models.
3503
+ """
2033
3504
 
2034
- index: Optional[float] = None
3505
+ max_completion_tokens: OptionalNullable[int] = UNSET
3506
+ r"""An upper bound for the number of tokens that can be generated for a completion, including visible output tokens and reasoning tokens"""
2035
3507
 
3508
+ logprobs: OptionalNullable[bool] = UNSET
3509
+ r"""Whether to return log probabilities of the output tokens or not. If true, returns the log probabilities of each output token returned in the content of message."""
2036
3510
 
2037
- class CreatePromptPromptsResponseMessagesTypedDict(TypedDict):
2038
- role: CreatePromptPromptsRole
2039
- r"""The role of the prompt message"""
2040
- content: Nullable[CreatePromptPromptsContentTypedDict]
2041
- r"""The contents of the user message. Either the text content of the message or an array of content parts with a defined type, each can be of type `text` or `image_url` when passing in images. You can pass multiple images by adding multiple `image_url` content parts. Can be null for tool messages in certain scenarios."""
2042
- tool_calls: NotRequired[List[CreatePromptPromptsToolCallsTypedDict]]
2043
- tool_call_id: NotRequired[Nullable[str]]
3511
+ top_logprobs: OptionalNullable[int] = UNSET
3512
+ r"""An integer between 0 and 20 specifying the number of most likely tokens to return at each token position, each with an associated log probability. logprobs must be set to true if this parameter is used."""
2044
3513
 
3514
+ n: OptionalNullable[int] = UNSET
3515
+ r"""How many chat completion choices to generate for each input message. Note that you will be charged based on the number of generated tokens across all of the choices. Keep n as 1 to minimize costs."""
2045
3516
 
2046
- class CreatePromptPromptsResponseMessages(BaseModel):
2047
- role: CreatePromptPromptsRole
2048
- r"""The role of the prompt message"""
3517
+ presence_penalty: OptionalNullable[float] = UNSET
3518
+ r"""Number between -2.0 and 2.0. Positive values penalize new tokens based on whether they appear in the text so far, increasing the model's likelihood to talk about new topics."""
2049
3519
 
2050
- content: Nullable[CreatePromptPromptsContent]
2051
- r"""The contents of the user message. Either the text content of the message or an array of content parts with a defined type, each can be of type `text` or `image_url` when passing in images. You can pass multiple images by adding multiple `image_url` content parts. Can be null for tool messages in certain scenarios."""
3520
+ response_format: Optional[CreatePromptPromptsResponseFormat] = None
3521
+ r"""An object specifying the format that the model must output"""
2052
3522
 
2053
- tool_calls: Optional[List[CreatePromptPromptsToolCalls]] = None
3523
+ reasoning_effort: Optional[CreatePromptPromptsReasoningEffort] = None
3524
+ r"""Constrains effort on reasoning for [reasoning models](https://platform.openai.com/docs/guides/reasoning). Currently supported values are `none`, `minimal`, `low`, `medium`, `high`, and `xhigh`. Reducing reasoning effort can result in faster responses and fewer tokens used on reasoning in a response.
2054
3525
 
2055
- tool_call_id: OptionalNullable[str] = UNSET
3526
+ - `gpt-5.1` defaults to `none`, which does not perform reasoning. The supported reasoning values for `gpt-5.1` are `none`, `low`, `medium`, and `high`. Tool calls are supported for all reasoning values in gpt-5.1.
3527
+ - All models before `gpt-5.1` default to `medium` reasoning effort, and do not support `none`.
3528
+ - The `gpt-5-pro` model defaults to (and only supports) `high` reasoning effort.
3529
+ - `xhigh` is currently only supported for `gpt-5.1-codex-max`.
2056
3530
 
2057
- @model_serializer(mode="wrap")
2058
- def serialize_model(self, handler):
2059
- optional_fields = ["tool_calls", "tool_call_id"]
2060
- nullable_fields = ["content", "tool_call_id"]
2061
- null_default_fields = []
3531
+ Any of \"none\", \"minimal\", \"low\", \"medium\", \"high\", \"xhigh\".
3532
+ """
2062
3533
 
2063
- serialized = handler(self)
3534
+ verbosity: Optional[str] = None
3535
+ r"""Adjusts response verbosity. Lower levels yield shorter answers."""
2064
3536
 
2065
- m = {}
3537
+ seed: OptionalNullable[float] = UNSET
3538
+ r"""If specified, our system will make a best effort to sample deterministically, such that repeated requests with the same seed and parameters should return the same result."""
2066
3539
 
2067
- for n, f in type(self).model_fields.items():
2068
- k = f.alias or n
2069
- val = serialized.get(k)
2070
- serialized.pop(k, None)
3540
+ stop: OptionalNullable[CreatePromptPromptsStop] = UNSET
3541
+ r"""Up to 4 sequences where the API will stop generating further tokens."""
2071
3542
 
2072
- optional_nullable = k in optional_fields and k in nullable_fields
2073
- is_set = (
2074
- self.__pydantic_fields_set__.intersection({n})
2075
- or k in null_default_fields
2076
- ) # pylint: disable=no-member
3543
+ stream_options: OptionalNullable[CreatePromptPromptsStreamOptions] = UNSET
3544
+ r"""Options for streaming response. Only set this when you set stream: true."""
2077
3545
 
2078
- if val is not None and val != UNSET_SENTINEL:
2079
- m[k] = val
2080
- elif val != UNSET_SENTINEL and (
2081
- not k in optional_fields or (optional_nullable and is_set)
2082
- ):
2083
- m[k] = val
3546
+ thinking: Optional[CreatePromptPromptsThinking] = None
2084
3547
 
2085
- return m
3548
+ temperature: OptionalNullable[float] = UNSET
3549
+ r"""What sampling temperature to use, between 0 and 2. Higher values like 0.8 will make the output more random, while lower values like 0.2 will make it more focused and deterministic."""
2086
3550
 
3551
+ top_p: OptionalNullable[float] = UNSET
3552
+ r"""An alternative to sampling with temperature, called nucleus sampling, where the model considers the results of the tokens with top_p probability mass."""
2087
3553
 
2088
- class CreatePromptPromptConfigTypedDict(TypedDict):
2089
- r"""A list of messages compatible with the openAI schema"""
3554
+ top_k: OptionalNullable[float] = UNSET
3555
+ r"""Limits the model to consider only the top k most likely tokens at each step."""
2090
3556
 
2091
- messages: List[CreatePromptPromptsResponseMessagesTypedDict]
2092
- stream: NotRequired[bool]
2093
- model: NotRequired[str]
2094
- model_db_id: NotRequired[Nullable[str]]
2095
- r"""The id of the resource"""
2096
- model_type: NotRequired[Nullable[CreatePromptModelType]]
2097
- r"""The modality of the model"""
2098
- model_parameters: NotRequired[CreatePromptModelParametersTypedDict]
2099
- r"""Model Parameters: Not all parameters apply to every model"""
2100
- provider: NotRequired[CreatePromptProvider]
2101
- integration_id: NotRequired[Nullable[str]]
2102
- r"""The ID of the integration to use"""
2103
- version: NotRequired[str]
3557
+ tool_choice: Optional[CreatePromptPromptsToolChoice] = None
3558
+ r"""Controls which (if any) tool is called by the model."""
2104
3559
 
3560
+ parallel_tool_calls: Optional[bool] = None
3561
+ r"""Whether to enable parallel function calling during tool use."""
2105
3562
 
2106
- class CreatePromptPromptConfig(BaseModel):
2107
- r"""A list of messages compatible with the openAI schema"""
3563
+ modalities: OptionalNullable[List[CreatePromptPromptsModalities]] = UNSET
3564
+ r"""Output types that you would like the model to generate. Most models are capable of generating text, which is the default: [\"text\"]. The gpt-4o-audio-preview model can also be used to generate audio. To request that this model generate both text and audio responses, you can use: [\"text\", \"audio\"]."""
2108
3565
 
2109
- messages: List[CreatePromptPromptsResponseMessages]
3566
+ guardrails: Optional[List[CreatePromptPromptsGuardrails]] = None
3567
+ r"""A list of guardrails to apply to the request."""
2110
3568
 
2111
- stream: Optional[bool] = None
3569
+ fallbacks: Optional[List[CreatePromptPromptsFallbacks]] = None
3570
+ r"""Array of fallback models to use if primary model fails"""
2112
3571
 
2113
- model: Optional[str] = None
3572
+ retry: Optional[CreatePromptPromptsRetry] = None
3573
+ r"""Retry configuration for the request"""
2114
3574
 
2115
- model_db_id: OptionalNullable[str] = UNSET
2116
- r"""The id of the resource"""
3575
+ cache: Optional[CreatePromptPromptsCache] = None
3576
+ r"""Cache configuration for the request."""
2117
3577
 
2118
- model_type: OptionalNullable[CreatePromptModelType] = UNSET
2119
- r"""The modality of the model"""
3578
+ load_balancer: Optional[CreatePromptPromptsLoadBalancer] = None
3579
+ r"""Load balancer configuration for the request."""
2120
3580
 
2121
- model_parameters: Optional[CreatePromptModelParameters] = None
2122
- r"""Model Parameters: Not all parameters apply to every model"""
3581
+ timeout: Optional[CreatePromptPromptsTimeout] = None
3582
+ r"""Timeout configuration to apply to the request. If the request exceeds the timeout, it will be retried or fallback to the next model if configured."""
2123
3583
 
2124
- provider: Optional[CreatePromptProvider] = None
3584
+ messages: Optional[List[CreatePromptPromptsResponseMessages]] = None
3585
+ r"""Array of messages that make up the conversation. Each message has a role (system, user, assistant, or tool) and content."""
2125
3586
 
2126
- integration_id: OptionalNullable[str] = UNSET
2127
- r"""The ID of the integration to use"""
3587
+ model: OptionalNullable[str] = UNSET
3588
+ r"""Model ID used to generate the response, like `openai/gpt-4o` or `anthropic/claude-3-5-sonnet-20241022`. For private models, use format: `{workspaceKey}@{provider}/{model}`."""
2128
3589
 
2129
3590
  version: Optional[str] = None
2130
3591
 
2131
3592
  @model_serializer(mode="wrap")
2132
3593
  def serialize_model(self, handler):
2133
- optional_fields = [
2134
- "stream",
2135
- "model",
2136
- "model_db_id",
2137
- "model_type",
2138
- "model_parameters",
2139
- "provider",
2140
- "integration_id",
2141
- "version",
2142
- ]
2143
- nullable_fields = ["model_db_id", "model_type", "integration_id"]
2144
- null_default_fields = []
2145
-
3594
+ optional_fields = set(
3595
+ [
3596
+ "name",
3597
+ "audio",
3598
+ "frequency_penalty",
3599
+ "max_tokens",
3600
+ "max_completion_tokens",
3601
+ "logprobs",
3602
+ "top_logprobs",
3603
+ "n",
3604
+ "presence_penalty",
3605
+ "response_format",
3606
+ "reasoning_effort",
3607
+ "verbosity",
3608
+ "seed",
3609
+ "stop",
3610
+ "stream_options",
3611
+ "thinking",
3612
+ "temperature",
3613
+ "top_p",
3614
+ "top_k",
3615
+ "tool_choice",
3616
+ "parallel_tool_calls",
3617
+ "modalities",
3618
+ "guardrails",
3619
+ "fallbacks",
3620
+ "retry",
3621
+ "cache",
3622
+ "load_balancer",
3623
+ "timeout",
3624
+ "messages",
3625
+ "model",
3626
+ "version",
3627
+ ]
3628
+ )
3629
+ nullable_fields = set(
3630
+ [
3631
+ "audio",
3632
+ "frequency_penalty",
3633
+ "max_tokens",
3634
+ "max_completion_tokens",
3635
+ "logprobs",
3636
+ "top_logprobs",
3637
+ "n",
3638
+ "presence_penalty",
3639
+ "seed",
3640
+ "stop",
3641
+ "stream_options",
3642
+ "temperature",
3643
+ "top_p",
3644
+ "top_k",
3645
+ "modalities",
3646
+ "model",
3647
+ ]
3648
+ )
2146
3649
  serialized = handler(self)
2147
-
2148
3650
  m = {}
2149
3651
 
2150
3652
  for n, f in type(self).model_fields.items():
2151
3653
  k = f.alias or n
2152
3654
  val = serialized.get(k)
2153
- serialized.pop(k, None)
2154
-
2155
- optional_nullable = k in optional_fields and k in nullable_fields
2156
- is_set = (
2157
- self.__pydantic_fields_set__.intersection({n})
2158
- or k in null_default_fields
2159
- ) # pylint: disable=no-member
2160
-
2161
- if val is not None and val != UNSET_SENTINEL:
2162
- m[k] = val
2163
- elif val != UNSET_SENTINEL and (
2164
- not k in optional_fields or (optional_nullable and is_set)
2165
- ):
2166
- m[k] = val
3655
+ is_nullable_and_explicitly_set = (
3656
+ k in nullable_fields
3657
+ and (self.__pydantic_fields_set__.intersection({n})) # pylint: disable=no-member
3658
+ )
3659
+
3660
+ if val != UNSET_SENTINEL:
3661
+ if (
3662
+ val is not None
3663
+ or k not in optional_fields
3664
+ or is_nullable_and_explicitly_set
3665
+ ):
3666
+ m[k] = val
2167
3667
 
2168
3668
  return m
2169
3669
 
@@ -2220,31 +3720,26 @@ class CreatePromptPromptsMetadata(BaseModel):
2220
3720
 
2221
3721
  @model_serializer(mode="wrap")
2222
3722
  def serialize_model(self, handler):
2223
- optional_fields = ["use_cases", "language"]
2224
- nullable_fields = ["language"]
2225
- null_default_fields = []
2226
-
3723
+ optional_fields = set(["use_cases", "language"])
3724
+ nullable_fields = set(["language"])
2227
3725
  serialized = handler(self)
2228
-
2229
3726
  m = {}
2230
3727
 
2231
3728
  for n, f in type(self).model_fields.items():
2232
3729
  k = f.alias or n
2233
3730
  val = serialized.get(k)
2234
- serialized.pop(k, None)
2235
-
2236
- optional_nullable = k in optional_fields and k in nullable_fields
2237
- is_set = (
2238
- self.__pydantic_fields_set__.intersection({n})
2239
- or k in null_default_fields
2240
- ) # pylint: disable=no-member
2241
-
2242
- if val is not None and val != UNSET_SENTINEL:
2243
- m[k] = val
2244
- elif val != UNSET_SENTINEL and (
2245
- not k in optional_fields or (optional_nullable and is_set)
2246
- ):
2247
- m[k] = val
3731
+ is_nullable_and_explicitly_set = (
3732
+ k in nullable_fields
3733
+ and (self.__pydantic_fields_set__.intersection({n})) # pylint: disable=no-member
3734
+ )
3735
+
3736
+ if val != UNSET_SENTINEL:
3737
+ if (
3738
+ val is not None
3739
+ or k not in optional_fields
3740
+ or is_nullable_and_explicitly_set
3741
+ ):
3742
+ m[k] = val
2248
3743
 
2249
3744
  return m
2250
3745
 
@@ -2260,12 +3755,14 @@ class CreatePromptPromptTypedDict(TypedDict):
2260
3755
  updated: str
2261
3756
  display_name: str
2262
3757
  r"""The prompt’s name, meant to be displayable in the UI."""
2263
- prompt_config: CreatePromptPromptConfigTypedDict
2264
- r"""A list of messages compatible with the openAI schema"""
3758
+ prompt: PromptFieldTypedDict
3759
+ r"""Prompt configuration with model and messages. Use this instead of prompt_config."""
2265
3760
  created_by_id: NotRequired[Nullable[str]]
2266
3761
  updated_by_id: NotRequired[Nullable[str]]
2267
3762
  description: NotRequired[Nullable[str]]
2268
3763
  r"""The prompt’s description, meant to be displayable in the UI. Use this field to optionally store a long form explanation of the prompt for your own purpose"""
3764
+ prompt_config: NotRequired[PromptConfigTypedDict]
3765
+ r"""[DEPRECATED] Use the `prompt` property instead. A list of messages compatible with the openAI schema."""
2269
3766
  metadata: NotRequired[CreatePromptPromptsMetadataTypedDict]
2270
3767
 
2271
3768
 
@@ -2287,8 +3784,8 @@ class CreatePromptPrompt(BaseModel):
2287
3784
  display_name: str
2288
3785
  r"""The prompt’s name, meant to be displayable in the UI."""
2289
3786
 
2290
- prompt_config: CreatePromptPromptConfig
2291
- r"""A list of messages compatible with the openAI schema"""
3787
+ prompt: PromptField
3788
+ r"""Prompt configuration with model and messages. Use this instead of prompt_config."""
2292
3789
 
2293
3790
  created_by_id: OptionalNullable[str] = UNSET
2294
3791
 
@@ -2297,34 +3794,45 @@ class CreatePromptPrompt(BaseModel):
2297
3794
  description: OptionalNullable[str] = UNSET
2298
3795
  r"""The prompt’s description, meant to be displayable in the UI. Use this field to optionally store a long form explanation of the prompt for your own purpose"""
2299
3796
 
3797
+ prompt_config: Annotated[
3798
+ Optional[PromptConfig],
3799
+ pydantic.Field(
3800
+ deprecated="warning: ** DEPRECATED ** - This will be removed in a future release, please migrate away from it as soon as possible."
3801
+ ),
3802
+ ] = None
3803
+ r"""[DEPRECATED] Use the `prompt` property instead. A list of messages compatible with the openAI schema."""
3804
+
2300
3805
  metadata: Optional[CreatePromptPromptsMetadata] = None
2301
3806
 
2302
3807
  @model_serializer(mode="wrap")
2303
3808
  def serialize_model(self, handler):
2304
- optional_fields = ["created_by_id", "updated_by_id", "description", "metadata"]
2305
- nullable_fields = ["created_by_id", "updated_by_id", "description"]
2306
- null_default_fields = []
2307
-
3809
+ optional_fields = set(
3810
+ [
3811
+ "created_by_id",
3812
+ "updated_by_id",
3813
+ "description",
3814
+ "prompt_config",
3815
+ "metadata",
3816
+ ]
3817
+ )
3818
+ nullable_fields = set(["created_by_id", "updated_by_id", "description"])
2308
3819
  serialized = handler(self)
2309
-
2310
3820
  m = {}
2311
3821
 
2312
3822
  for n, f in type(self).model_fields.items():
2313
3823
  k = f.alias or n
2314
3824
  val = serialized.get(k)
2315
- serialized.pop(k, None)
2316
-
2317
- optional_nullable = k in optional_fields and k in nullable_fields
2318
- is_set = (
2319
- self.__pydantic_fields_set__.intersection({n})
2320
- or k in null_default_fields
2321
- ) # pylint: disable=no-member
2322
-
2323
- if val is not None and val != UNSET_SENTINEL:
2324
- m[k] = val
2325
- elif val != UNSET_SENTINEL and (
2326
- not k in optional_fields or (optional_nullable and is_set)
2327
- ):
2328
- m[k] = val
3825
+ is_nullable_and_explicitly_set = (
3826
+ k in nullable_fields
3827
+ and (self.__pydantic_fields_set__.intersection({n})) # pylint: disable=no-member
3828
+ )
3829
+
3830
+ if val != UNSET_SENTINEL:
3831
+ if (
3832
+ val is not None
3833
+ or k not in optional_fields
3834
+ or is_nullable_and_explicitly_set
3835
+ ):
3836
+ m[k] = val
2329
3837
 
2330
3838
  return m