google-genai 1.53.0__py3-none-any.whl → 1.55.0__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (324) hide show
  1. google/genai/__init__.py +1 -0
  2. google/genai/_api_client.py +6 -6
  3. google/genai/_interactions/__init__.py +117 -0
  4. google/genai/_interactions/_base_client.py +2019 -0
  5. google/genai/_interactions/_client.py +511 -0
  6. google/genai/_interactions/_compat.py +234 -0
  7. google/genai/_interactions/_constants.py +29 -0
  8. google/genai/_interactions/_exceptions.py +122 -0
  9. google/genai/_interactions/_files.py +139 -0
  10. google/genai/_interactions/_models.py +873 -0
  11. google/genai/_interactions/_qs.py +165 -0
  12. google/genai/_interactions/_resource.py +58 -0
  13. google/genai/_interactions/_response.py +847 -0
  14. google/genai/_interactions/_streaming.py +354 -0
  15. google/genai/_interactions/_types.py +276 -0
  16. google/genai/_interactions/_utils/__init__.py +79 -0
  17. google/genai/_interactions/_utils/_compat.py +61 -0
  18. google/genai/_interactions/_utils/_datetime_parse.py +151 -0
  19. google/genai/_interactions/_utils/_logs.py +40 -0
  20. google/genai/_interactions/_utils/_proxy.py +80 -0
  21. google/genai/_interactions/_utils/_reflection.py +57 -0
  22. google/genai/_interactions/_utils/_resources_proxy.py +39 -0
  23. google/genai/_interactions/_utils/_streams.py +27 -0
  24. google/genai/_interactions/_utils/_sync.py +73 -0
  25. google/genai/_interactions/_utils/_transform.py +472 -0
  26. google/genai/_interactions/_utils/_typing.py +172 -0
  27. google/genai/_interactions/_utils/_utils.py +437 -0
  28. google/genai/_interactions/_version.py +18 -0
  29. google/genai/_interactions/resources/__init__.py +34 -0
  30. google/genai/_interactions/resources/interactions.py +1350 -0
  31. google/genai/_interactions/types/__init__.py +107 -0
  32. google/genai/_interactions/types/allowed_tools.py +33 -0
  33. google/genai/_interactions/types/allowed_tools_param.py +35 -0
  34. google/genai/_interactions/types/annotation.py +42 -0
  35. google/genai/_interactions/types/annotation_param.py +42 -0
  36. google/genai/_interactions/types/audio_content.py +38 -0
  37. google/genai/_interactions/types/audio_content_param.py +45 -0
  38. google/genai/_interactions/types/audio_mime_type.py +25 -0
  39. google/genai/_interactions/types/audio_mime_type_param.py +27 -0
  40. google/genai/_interactions/types/code_execution_call_arguments.py +33 -0
  41. google/genai/_interactions/types/code_execution_call_arguments_param.py +32 -0
  42. google/genai/_interactions/types/code_execution_call_content.py +37 -0
  43. google/genai/_interactions/types/code_execution_call_content_param.py +37 -0
  44. google/genai/_interactions/types/code_execution_result_content.py +42 -0
  45. google/genai/_interactions/types/code_execution_result_content_param.py +41 -0
  46. google/genai/_interactions/types/content_delta.py +358 -0
  47. google/genai/_interactions/types/content_start.py +79 -0
  48. google/genai/_interactions/types/content_stop.py +35 -0
  49. google/genai/_interactions/types/deep_research_agent_config.py +33 -0
  50. google/genai/_interactions/types/deep_research_agent_config_param.py +32 -0
  51. google/genai/_interactions/types/document_content.py +36 -0
  52. google/genai/_interactions/types/document_content_param.py +43 -0
  53. google/genai/_interactions/types/dynamic_agent_config.py +44 -0
  54. google/genai/_interactions/types/dynamic_agent_config_param.py +33 -0
  55. google/genai/_interactions/types/error_event.py +46 -0
  56. google/genai/_interactions/types/file_search_result_content.py +46 -0
  57. google/genai/_interactions/types/file_search_result_content_param.py +46 -0
  58. google/genai/_interactions/types/function.py +38 -0
  59. google/genai/_interactions/types/function_call_content.py +39 -0
  60. google/genai/_interactions/types/function_call_content_param.py +39 -0
  61. google/genai/_interactions/types/function_param.py +37 -0
  62. google/genai/_interactions/types/function_result_content.py +52 -0
  63. google/genai/_interactions/types/function_result_content_param.py +54 -0
  64. google/genai/_interactions/types/generation_config.py +57 -0
  65. google/genai/_interactions/types/generation_config_param.py +59 -0
  66. google/genai/_interactions/types/google_search_call_arguments.py +29 -0
  67. google/genai/_interactions/types/google_search_call_arguments_param.py +31 -0
  68. google/genai/_interactions/types/google_search_call_content.py +37 -0
  69. google/genai/_interactions/types/google_search_call_content_param.py +37 -0
  70. google/genai/_interactions/types/google_search_result.py +35 -0
  71. google/genai/_interactions/types/google_search_result_content.py +43 -0
  72. google/genai/_interactions/types/google_search_result_content_param.py +44 -0
  73. google/genai/_interactions/types/google_search_result_param.py +35 -0
  74. google/genai/_interactions/types/image_content.py +41 -0
  75. google/genai/_interactions/types/image_content_param.py +48 -0
  76. google/genai/_interactions/types/image_mime_type.py +23 -0
  77. google/genai/_interactions/types/image_mime_type_param.py +25 -0
  78. google/genai/_interactions/types/interaction.py +165 -0
  79. google/genai/_interactions/types/interaction_create_params.py +212 -0
  80. google/genai/_interactions/types/interaction_event.py +37 -0
  81. google/genai/_interactions/types/interaction_get_params.py +46 -0
  82. google/genai/_interactions/types/interaction_sse_event.py +32 -0
  83. google/genai/_interactions/types/interaction_status_update.py +37 -0
  84. google/genai/_interactions/types/mcp_server_tool_call_content.py +42 -0
  85. google/genai/_interactions/types/mcp_server_tool_call_content_param.py +42 -0
  86. google/genai/_interactions/types/mcp_server_tool_result_content.py +52 -0
  87. google/genai/_interactions/types/mcp_server_tool_result_content_param.py +54 -0
  88. google/genai/_interactions/types/model.py +36 -0
  89. google/genai/_interactions/types/model_param.py +38 -0
  90. google/genai/_interactions/types/speech_config.py +35 -0
  91. google/genai/_interactions/types/speech_config_param.py +35 -0
  92. google/genai/_interactions/types/text_content.py +37 -0
  93. google/genai/_interactions/types/text_content_param.py +38 -0
  94. google/genai/_interactions/types/thinking_level.py +22 -0
  95. google/genai/_interactions/types/thought_content.py +41 -0
  96. google/genai/_interactions/types/thought_content_param.py +47 -0
  97. google/genai/_interactions/types/tool.py +100 -0
  98. google/genai/_interactions/types/tool_choice.py +26 -0
  99. google/genai/_interactions/types/tool_choice_config.py +28 -0
  100. google/genai/_interactions/types/tool_choice_config_param.py +29 -0
  101. google/genai/_interactions/types/tool_choice_param.py +28 -0
  102. google/genai/_interactions/types/tool_choice_type.py +22 -0
  103. google/genai/_interactions/types/tool_param.py +97 -0
  104. google/genai/_interactions/types/turn.py +76 -0
  105. google/genai/_interactions/types/turn_param.py +73 -0
  106. google/genai/_interactions/types/url_context_call_arguments.py +29 -0
  107. google/genai/_interactions/types/url_context_call_arguments_param.py +31 -0
  108. google/genai/_interactions/types/url_context_call_content.py +37 -0
  109. google/genai/_interactions/types/url_context_call_content_param.py +37 -0
  110. google/genai/_interactions/types/url_context_result.py +33 -0
  111. google/genai/_interactions/types/url_context_result_content.py +43 -0
  112. google/genai/_interactions/types/url_context_result_content_param.py +44 -0
  113. google/genai/_interactions/types/url_context_result_param.py +32 -0
  114. google/genai/_interactions/types/usage.py +106 -0
  115. google/genai/_interactions/types/usage_param.py +106 -0
  116. google/genai/_interactions/types/video_content.py +41 -0
  117. google/genai/_interactions/types/video_content_param.py +48 -0
  118. google/genai/_interactions/types/video_mime_type.py +36 -0
  119. google/genai/_interactions/types/video_mime_type_param.py +38 -0
  120. google/genai/_live_converters.py +34 -3
  121. google/genai/_tokens_converters.py +5 -0
  122. google/genai/batches.py +62 -55
  123. google/genai/client.py +223 -0
  124. google/genai/errors.py +16 -1
  125. google/genai/file_search_stores.py +60 -60
  126. google/genai/files.py +56 -56
  127. google/genai/interactions.py +17 -0
  128. google/genai/live.py +4 -3
  129. google/genai/models.py +15 -3
  130. google/genai/tests/__init__.py +21 -0
  131. google/genai/tests/afc/__init__.py +21 -0
  132. google/genai/tests/afc/test_convert_if_exist_pydantic_model.py +309 -0
  133. google/genai/tests/afc/test_convert_number_values_for_function_call_args.py +63 -0
  134. google/genai/tests/afc/test_find_afc_incompatible_tool_indexes.py +240 -0
  135. google/genai/tests/afc/test_generate_content_stream_afc.py +530 -0
  136. google/genai/tests/afc/test_generate_content_stream_afc_thoughts.py +77 -0
  137. google/genai/tests/afc/test_get_function_map.py +176 -0
  138. google/genai/tests/afc/test_get_function_response_parts.py +277 -0
  139. google/genai/tests/afc/test_get_max_remote_calls_for_afc.py +130 -0
  140. google/genai/tests/afc/test_invoke_function_from_dict_args.py +241 -0
  141. google/genai/tests/afc/test_raise_error_for_afc_incompatible_config.py +159 -0
  142. google/genai/tests/afc/test_should_append_afc_history.py +53 -0
  143. google/genai/tests/afc/test_should_disable_afc.py +214 -0
  144. google/genai/tests/batches/__init__.py +17 -0
  145. google/genai/tests/batches/test_cancel.py +77 -0
  146. google/genai/tests/batches/test_create.py +78 -0
  147. google/genai/tests/batches/test_create_with_bigquery.py +113 -0
  148. google/genai/tests/batches/test_create_with_file.py +82 -0
  149. google/genai/tests/batches/test_create_with_gcs.py +125 -0
  150. google/genai/tests/batches/test_create_with_inlined_requests.py +255 -0
  151. google/genai/tests/batches/test_delete.py +86 -0
  152. google/genai/tests/batches/test_embedding.py +157 -0
  153. google/genai/tests/batches/test_get.py +78 -0
  154. google/genai/tests/batches/test_list.py +79 -0
  155. google/genai/tests/caches/__init__.py +17 -0
  156. google/genai/tests/caches/constants.py +29 -0
  157. google/genai/tests/caches/test_create.py +210 -0
  158. google/genai/tests/caches/test_create_custom_url.py +105 -0
  159. google/genai/tests/caches/test_delete.py +54 -0
  160. google/genai/tests/caches/test_delete_custom_url.py +52 -0
  161. google/genai/tests/caches/test_get.py +94 -0
  162. google/genai/tests/caches/test_get_custom_url.py +52 -0
  163. google/genai/tests/caches/test_list.py +68 -0
  164. google/genai/tests/caches/test_update.py +70 -0
  165. google/genai/tests/caches/test_update_custom_url.py +58 -0
  166. google/genai/tests/chats/__init__.py +1 -0
  167. google/genai/tests/chats/test_get_history.py +597 -0
  168. google/genai/tests/chats/test_send_message.py +844 -0
  169. google/genai/tests/chats/test_validate_response.py +90 -0
  170. google/genai/tests/client/__init__.py +17 -0
  171. google/genai/tests/client/test_async_stream.py +427 -0
  172. google/genai/tests/client/test_client_close.py +197 -0
  173. google/genai/tests/client/test_client_initialization.py +1687 -0
  174. google/genai/tests/client/test_client_requests.py +355 -0
  175. google/genai/tests/client/test_custom_client.py +77 -0
  176. google/genai/tests/client/test_http_options.py +178 -0
  177. google/genai/tests/client/test_replay_client_equality.py +168 -0
  178. google/genai/tests/client/test_retries.py +846 -0
  179. google/genai/tests/client/test_upload_errors.py +136 -0
  180. google/genai/tests/common/__init__.py +17 -0
  181. google/genai/tests/common/test_common.py +954 -0
  182. google/genai/tests/conftest.py +162 -0
  183. google/genai/tests/documents/__init__.py +17 -0
  184. google/genai/tests/documents/test_delete.py +51 -0
  185. google/genai/tests/documents/test_get.py +85 -0
  186. google/genai/tests/documents/test_list.py +72 -0
  187. google/genai/tests/errors/__init__.py +1 -0
  188. google/genai/tests/errors/test_api_error.py +417 -0
  189. google/genai/tests/file_search_stores/__init__.py +17 -0
  190. google/genai/tests/file_search_stores/test_create.py +66 -0
  191. google/genai/tests/file_search_stores/test_delete.py +64 -0
  192. google/genai/tests/file_search_stores/test_get.py +94 -0
  193. google/genai/tests/file_search_stores/test_import_file.py +112 -0
  194. google/genai/tests/file_search_stores/test_list.py +57 -0
  195. google/genai/tests/file_search_stores/test_upload_to_file_search_store.py +141 -0
  196. google/genai/tests/files/__init__.py +17 -0
  197. google/genai/tests/files/test_delete.py +46 -0
  198. google/genai/tests/files/test_download.py +85 -0
  199. google/genai/tests/files/test_get.py +46 -0
  200. google/genai/tests/files/test_list.py +72 -0
  201. google/genai/tests/files/test_upload.py +255 -0
  202. google/genai/tests/imports/test_no_optional_imports.py +28 -0
  203. google/genai/tests/interactions/__init__.py +0 -0
  204. google/genai/tests/interactions/test_integration.py +80 -0
  205. google/genai/tests/live/__init__.py +16 -0
  206. google/genai/tests/live/test_live.py +2177 -0
  207. google/genai/tests/live/test_live_music.py +362 -0
  208. google/genai/tests/live/test_live_response.py +163 -0
  209. google/genai/tests/live/test_send_client_content.py +147 -0
  210. google/genai/tests/live/test_send_realtime_input.py +268 -0
  211. google/genai/tests/live/test_send_tool_response.py +222 -0
  212. google/genai/tests/local_tokenizer/__init__.py +17 -0
  213. google/genai/tests/local_tokenizer/test_local_tokenizer.py +343 -0
  214. google/genai/tests/local_tokenizer/test_local_tokenizer_loader.py +235 -0
  215. google/genai/tests/mcp/__init__.py +17 -0
  216. google/genai/tests/mcp/test_has_mcp_tool_usage.py +89 -0
  217. google/genai/tests/mcp/test_mcp_to_gemini_tools.py +191 -0
  218. google/genai/tests/mcp/test_parse_config_for_mcp_sessions.py +201 -0
  219. google/genai/tests/mcp/test_parse_config_for_mcp_usage.py +130 -0
  220. google/genai/tests/mcp/test_set_mcp_usage_header.py +72 -0
  221. google/genai/tests/models/__init__.py +17 -0
  222. google/genai/tests/models/constants.py +8 -0
  223. google/genai/tests/models/test_compute_tokens.py +120 -0
  224. google/genai/tests/models/test_count_tokens.py +159 -0
  225. google/genai/tests/models/test_delete.py +107 -0
  226. google/genai/tests/models/test_edit_image.py +264 -0
  227. google/genai/tests/models/test_embed_content.py +94 -0
  228. google/genai/tests/models/test_function_call_streaming.py +442 -0
  229. google/genai/tests/models/test_generate_content.py +2502 -0
  230. google/genai/tests/models/test_generate_content_cached_content.py +132 -0
  231. google/genai/tests/models/test_generate_content_config_zero_value.py +103 -0
  232. google/genai/tests/models/test_generate_content_from_apikey.py +44 -0
  233. google/genai/tests/models/test_generate_content_http_options.py +40 -0
  234. google/genai/tests/models/test_generate_content_image_generation.py +143 -0
  235. google/genai/tests/models/test_generate_content_mcp.py +343 -0
  236. google/genai/tests/models/test_generate_content_media_resolution.py +97 -0
  237. google/genai/tests/models/test_generate_content_model.py +139 -0
  238. google/genai/tests/models/test_generate_content_part.py +821 -0
  239. google/genai/tests/models/test_generate_content_thought.py +76 -0
  240. google/genai/tests/models/test_generate_content_tools.py +1761 -0
  241. google/genai/tests/models/test_generate_images.py +191 -0
  242. google/genai/tests/models/test_generate_videos.py +759 -0
  243. google/genai/tests/models/test_get.py +104 -0
  244. google/genai/tests/models/test_list.py +233 -0
  245. google/genai/tests/models/test_recontext_image.py +189 -0
  246. google/genai/tests/models/test_segment_image.py +148 -0
  247. google/genai/tests/models/test_update.py +95 -0
  248. google/genai/tests/models/test_upscale_image.py +157 -0
  249. google/genai/tests/operations/__init__.py +17 -0
  250. google/genai/tests/operations/test_get.py +38 -0
  251. google/genai/tests/public_samples/__init__.py +17 -0
  252. google/genai/tests/public_samples/test_gemini_text_only.py +34 -0
  253. google/genai/tests/pytest_helper.py +229 -0
  254. google/genai/tests/shared/__init__.py +16 -0
  255. google/genai/tests/shared/batches/__init__.py +14 -0
  256. google/genai/tests/shared/batches/test_create_delete.py +57 -0
  257. google/genai/tests/shared/batches/test_create_get_cancel.py +56 -0
  258. google/genai/tests/shared/batches/test_list.py +40 -0
  259. google/genai/tests/shared/caches/__init__.py +14 -0
  260. google/genai/tests/shared/caches/test_create_get_delete.py +67 -0
  261. google/genai/tests/shared/caches/test_create_update_get.py +71 -0
  262. google/genai/tests/shared/caches/test_list.py +40 -0
  263. google/genai/tests/shared/chats/__init__.py +14 -0
  264. google/genai/tests/shared/chats/test_send_message.py +48 -0
  265. google/genai/tests/shared/chats/test_send_message_stream.py +50 -0
  266. google/genai/tests/shared/files/__init__.py +14 -0
  267. google/genai/tests/shared/files/test_list.py +41 -0
  268. google/genai/tests/shared/files/test_upload_get_delete.py +54 -0
  269. google/genai/tests/shared/models/__init__.py +14 -0
  270. google/genai/tests/shared/models/test_compute_tokens.py +41 -0
  271. google/genai/tests/shared/models/test_count_tokens.py +40 -0
  272. google/genai/tests/shared/models/test_edit_image.py +67 -0
  273. google/genai/tests/shared/models/test_embed.py +40 -0
  274. google/genai/tests/shared/models/test_generate_content.py +39 -0
  275. google/genai/tests/shared/models/test_generate_content_stream.py +54 -0
  276. google/genai/tests/shared/models/test_generate_images.py +40 -0
  277. google/genai/tests/shared/models/test_generate_videos.py +38 -0
  278. google/genai/tests/shared/models/test_list.py +37 -0
  279. google/genai/tests/shared/models/test_recontext_image.py +55 -0
  280. google/genai/tests/shared/models/test_segment_image.py +52 -0
  281. google/genai/tests/shared/models/test_upscale_image.py +52 -0
  282. google/genai/tests/shared/tunings/__init__.py +16 -0
  283. google/genai/tests/shared/tunings/test_create.py +46 -0
  284. google/genai/tests/shared/tunings/test_create_get_cancel.py +56 -0
  285. google/genai/tests/shared/tunings/test_list.py +39 -0
  286. google/genai/tests/tokens/__init__.py +16 -0
  287. google/genai/tests/tokens/test_create.py +154 -0
  288. google/genai/tests/transformers/__init__.py +17 -0
  289. google/genai/tests/transformers/test_blobs.py +71 -0
  290. google/genai/tests/transformers/test_bytes.py +15 -0
  291. google/genai/tests/transformers/test_duck_type.py +96 -0
  292. google/genai/tests/transformers/test_function_responses.py +72 -0
  293. google/genai/tests/transformers/test_schema.py +653 -0
  294. google/genai/tests/transformers/test_t_batch.py +286 -0
  295. google/genai/tests/transformers/test_t_content.py +160 -0
  296. google/genai/tests/transformers/test_t_contents.py +398 -0
  297. google/genai/tests/transformers/test_t_part.py +85 -0
  298. google/genai/tests/transformers/test_t_parts.py +87 -0
  299. google/genai/tests/transformers/test_t_tool.py +157 -0
  300. google/genai/tests/transformers/test_t_tools.py +195 -0
  301. google/genai/tests/tunings/__init__.py +16 -0
  302. google/genai/tests/tunings/test_cancel.py +39 -0
  303. google/genai/tests/tunings/test_end_to_end.py +106 -0
  304. google/genai/tests/tunings/test_get.py +67 -0
  305. google/genai/tests/tunings/test_list.py +75 -0
  306. google/genai/tests/tunings/test_tune.py +268 -0
  307. google/genai/tests/types/__init__.py +16 -0
  308. google/genai/tests/types/test_bytes_internal.py +271 -0
  309. google/genai/tests/types/test_bytes_type.py +152 -0
  310. google/genai/tests/types/test_future.py +101 -0
  311. google/genai/tests/types/test_optional_types.py +36 -0
  312. google/genai/tests/types/test_part_type.py +616 -0
  313. google/genai/tests/types/test_schema_from_json_schema.py +417 -0
  314. google/genai/tests/types/test_schema_json_schema.py +468 -0
  315. google/genai/tests/types/test_types.py +2903 -0
  316. google/genai/tunings.py +57 -57
  317. google/genai/types.py +229 -121
  318. google/genai/version.py +1 -1
  319. {google_genai-1.53.0.dist-info → google_genai-1.55.0.dist-info}/METADATA +4 -2
  320. google_genai-1.55.0.dist-info/RECORD +345 -0
  321. google_genai-1.53.0.dist-info/RECORD +0 -41
  322. {google_genai-1.53.0.dist-info → google_genai-1.55.0.dist-info}/WHEEL +0 -0
  323. {google_genai-1.53.0.dist-info → google_genai-1.55.0.dist-info}/licenses/LICENSE +0 -0
  324. {google_genai-1.53.0.dist-info → google_genai-1.55.0.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,437 @@
1
+ # Copyright 2025 Google LLC
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+ #
15
+
16
+ # mypy: ignore-errors
17
+ from __future__ import annotations
18
+
19
+ import os
20
+ import re
21
+ import inspect
22
+ import functools
23
+ from typing import (
24
+ Any,
25
+ Tuple,
26
+ Mapping,
27
+ TypeVar,
28
+ Callable,
29
+ Iterable,
30
+ Sequence,
31
+ cast,
32
+ overload,
33
+ )
34
+ from pathlib import Path
35
+ from datetime import date, datetime
36
+ from typing_extensions import TypeGuard
37
+
38
+ import sniffio
39
+
40
+ from .._types import Omit, NotGiven, FileTypes, HeadersLike
41
+
42
+ _T = TypeVar("_T")
43
+ _TupleT = TypeVar("_TupleT", bound=Tuple[object, ...])
44
+ _MappingT = TypeVar("_MappingT", bound=Mapping[str, object])
45
+ _SequenceT = TypeVar("_SequenceT", bound=Sequence[object])
46
+ CallableT = TypeVar("CallableT", bound=Callable[..., Any])
47
+
48
+
49
+ def flatten(t: Iterable[Iterable[_T]]) -> list[_T]:
50
+ return [item for sublist in t for item in sublist]
51
+
52
+
53
+ def extract_files(
54
+ # TODO: this needs to take Dict but variance issues.....
55
+ # create protocol type ?
56
+ query: Mapping[str, object],
57
+ *,
58
+ paths: Sequence[Sequence[str]],
59
+ ) -> list[tuple[str, FileTypes]]:
60
+ """Recursively extract files from the given dictionary based on specified paths.
61
+
62
+ A path may look like this ['foo', 'files', '<array>', 'data'].
63
+
64
+ Note: this mutates the given dictionary.
65
+ """
66
+ files: list[tuple[str, FileTypes]] = []
67
+ for path in paths:
68
+ files.extend(_extract_items(query, path, index=0, flattened_key=None))
69
+ return files
70
+
71
+
72
+ def _extract_items(
73
+ obj: object,
74
+ path: Sequence[str],
75
+ *,
76
+ index: int,
77
+ flattened_key: str | None,
78
+ ) -> list[tuple[str, FileTypes]]:
79
+ try:
80
+ key = path[index]
81
+ except IndexError:
82
+ if not is_given(obj):
83
+ # no value was provided - we can safely ignore
84
+ return []
85
+
86
+ # cyclical import
87
+ from .._files import assert_is_file_content
88
+
89
+ # We have exhausted the path, return the entry we found.
90
+ assert flattened_key is not None
91
+
92
+ if is_list(obj):
93
+ files: list[tuple[str, FileTypes]] = []
94
+ for entry in obj:
95
+ assert_is_file_content(entry, key=flattened_key + "[]" if flattened_key else "")
96
+ files.append((flattened_key + "[]", cast(FileTypes, entry)))
97
+ return files
98
+
99
+ assert_is_file_content(obj, key=flattened_key)
100
+ return [(flattened_key, cast(FileTypes, obj))]
101
+
102
+ index += 1
103
+ if is_dict(obj):
104
+ try:
105
+ # We are at the last entry in the path so we must remove the field
106
+ if (len(path)) == index:
107
+ item = obj.pop(key)
108
+ else:
109
+ item = obj[key]
110
+ except KeyError:
111
+ # Key was not present in the dictionary, this is not indicative of an error
112
+ # as the given path may not point to a required field. We also do not want
113
+ # to enforce required fields as the API may differ from the spec in some cases.
114
+ return []
115
+ if flattened_key is None:
116
+ flattened_key = key
117
+ else:
118
+ flattened_key += f"[{key}]"
119
+ return _extract_items(
120
+ item,
121
+ path,
122
+ index=index,
123
+ flattened_key=flattened_key,
124
+ )
125
+ elif is_list(obj):
126
+ if key != "<array>":
127
+ return []
128
+
129
+ return flatten(
130
+ [
131
+ _extract_items(
132
+ item,
133
+ path,
134
+ index=index,
135
+ flattened_key=flattened_key + "[]" if flattened_key is not None else "[]",
136
+ )
137
+ for item in obj
138
+ ]
139
+ )
140
+
141
+ # Something unexpected was passed, just ignore it.
142
+ return []
143
+
144
+
145
+ def is_given(obj: _T | NotGiven | Omit) -> TypeGuard[_T]:
146
+ return not isinstance(obj, NotGiven) and not isinstance(obj, Omit)
147
+
148
+
149
+ # Type safe methods for narrowing types with TypeVars.
150
+ # The default narrowing for isinstance(obj, dict) is dict[unknown, unknown],
151
+ # however this cause Pyright to rightfully report errors. As we know we don't
152
+ # care about the contained types we can safely use `object` in its place.
153
+ #
154
+ # There are two separate functions defined, `is_*` and `is_*_t` for different use cases.
155
+ # `is_*` is for when you're dealing with an unknown input
156
+ # `is_*_t` is for when you're narrowing a known union type to a specific subset
157
+
158
+
159
+ def is_tuple(obj: object) -> TypeGuard[tuple[object, ...]]:
160
+ return isinstance(obj, tuple)
161
+
162
+
163
+ def is_tuple_t(obj: _TupleT | object) -> TypeGuard[_TupleT]:
164
+ return isinstance(obj, tuple)
165
+
166
+
167
+ def is_sequence(obj: object) -> TypeGuard[Sequence[object]]:
168
+ return isinstance(obj, Sequence)
169
+
170
+
171
+ def is_sequence_t(obj: _SequenceT | object) -> TypeGuard[_SequenceT]:
172
+ return isinstance(obj, Sequence)
173
+
174
+
175
+ def is_mapping(obj: object) -> TypeGuard[Mapping[str, object]]:
176
+ return isinstance(obj, Mapping)
177
+
178
+
179
+ def is_mapping_t(obj: _MappingT | object) -> TypeGuard[_MappingT]:
180
+ return isinstance(obj, Mapping)
181
+
182
+
183
+ def is_dict(obj: object) -> TypeGuard[dict[object, object]]:
184
+ return isinstance(obj, dict)
185
+
186
+
187
+ def is_list(obj: object) -> TypeGuard[list[object]]:
188
+ return isinstance(obj, list)
189
+
190
+
191
+ def is_iterable(obj: object) -> TypeGuard[Iterable[object]]:
192
+ return isinstance(obj, Iterable)
193
+
194
+
195
+ def deepcopy_minimal(item: _T) -> _T:
196
+ """Minimal reimplementation of copy.deepcopy() that will only copy certain object types:
197
+
198
+ - mappings, e.g. `dict`
199
+ - list
200
+
201
+ This is done for performance reasons.
202
+ """
203
+ if is_mapping(item):
204
+ return cast(_T, {k: deepcopy_minimal(v) for k, v in item.items()})
205
+ if is_list(item):
206
+ return cast(_T, [deepcopy_minimal(entry) for entry in item])
207
+ return item
208
+
209
+
210
+ # copied from https://github.com/Rapptz/RoboDanny
211
+ def human_join(seq: Sequence[str], *, delim: str = ", ", final: str = "or") -> str:
212
+ size = len(seq)
213
+ if size == 0:
214
+ return ""
215
+
216
+ if size == 1:
217
+ return seq[0]
218
+
219
+ if size == 2:
220
+ return f"{seq[0]} {final} {seq[1]}"
221
+
222
+ return delim.join(seq[:-1]) + f" {final} {seq[-1]}"
223
+
224
+
225
+ def quote(string: str) -> str:
226
+ """Add single quotation marks around the given string. Does *not* do any escaping."""
227
+ return f"'{string}'"
228
+
229
+
230
+ def required_args(*variants: Sequence[str]) -> Callable[[CallableT], CallableT]:
231
+ """Decorator to enforce a given set of arguments or variants of arguments are passed to the decorated function.
232
+
233
+ Useful for enforcing runtime validation of overloaded functions.
234
+
235
+ Example usage:
236
+ ```py
237
+ @overload
238
+ def foo(*, a: str) -> str: ...
239
+
240
+
241
+ @overload
242
+ def foo(*, b: bool) -> str: ...
243
+
244
+
245
+ # This enforces the same constraints that a static type checker would
246
+ # i.e. that either a or b must be passed to the function
247
+ @required_args(["a"], ["b"])
248
+ def foo(*, a: str | None = None, b: bool | None = None) -> str: ...
249
+ ```
250
+ """
251
+
252
+ def inner(func: CallableT) -> CallableT:
253
+ params = inspect.signature(func).parameters
254
+ positional = [
255
+ name
256
+ for name, param in params.items()
257
+ if param.kind
258
+ in {
259
+ param.POSITIONAL_ONLY,
260
+ param.POSITIONAL_OR_KEYWORD,
261
+ }
262
+ ]
263
+
264
+ @functools.wraps(func)
265
+ def wrapper(*args: object, **kwargs: object) -> object:
266
+ given_params: set[str] = set()
267
+ for i, _ in enumerate(args):
268
+ try:
269
+ given_params.add(positional[i])
270
+ except IndexError:
271
+ raise TypeError(
272
+ f"{func.__name__}() takes {len(positional)} argument(s) but {len(args)} were given"
273
+ ) from None
274
+
275
+ for key in kwargs.keys():
276
+ given_params.add(key)
277
+
278
+ for variant in variants:
279
+ matches = all((param in given_params for param in variant))
280
+ if matches:
281
+ break
282
+ else: # no break
283
+ if len(variants) > 1:
284
+ variations = human_join(
285
+ ["(" + human_join([quote(arg) for arg in variant], final="and") + ")" for variant in variants]
286
+ )
287
+ msg = f"Missing required arguments; Expected either {variations} arguments to be given"
288
+ else:
289
+ assert len(variants) > 0
290
+
291
+ # TODO: this error message is not deterministic
292
+ missing = list(set(variants[0]) - given_params)
293
+ if len(missing) > 1:
294
+ msg = f"Missing required arguments: {human_join([quote(arg) for arg in missing])}"
295
+ else:
296
+ msg = f"Missing required argument: {quote(missing[0])}"
297
+ raise TypeError(msg)
298
+ return func(*args, **kwargs)
299
+
300
+ return wrapper # type: ignore
301
+
302
+ return inner
303
+
304
+
305
+ _K = TypeVar("_K")
306
+ _V = TypeVar("_V")
307
+
308
+
309
+ @overload
310
+ def strip_not_given(obj: None) -> None: ...
311
+
312
+
313
+ @overload
314
+ def strip_not_given(obj: Mapping[_K, _V | NotGiven]) -> dict[_K, _V]: ...
315
+
316
+
317
+ @overload
318
+ def strip_not_given(obj: object) -> object: ...
319
+
320
+
321
+ def strip_not_given(obj: object | None) -> object:
322
+ """Remove all top-level keys where their values are instances of `NotGiven`"""
323
+ if obj is None:
324
+ return None
325
+
326
+ if not is_mapping(obj):
327
+ return obj
328
+
329
+ return {key: value for key, value in obj.items() if not isinstance(value, NotGiven)}
330
+
331
+
332
+ def coerce_integer(val: str) -> int:
333
+ return int(val, base=10)
334
+
335
+
336
+ def coerce_float(val: str) -> float:
337
+ return float(val)
338
+
339
+
340
+ def coerce_boolean(val: str) -> bool:
341
+ return val == "true" or val == "1" or val == "on"
342
+
343
+
344
+ def maybe_coerce_integer(val: str | None) -> int | None:
345
+ if val is None:
346
+ return None
347
+ return coerce_integer(val)
348
+
349
+
350
+ def maybe_coerce_float(val: str | None) -> float | None:
351
+ if val is None:
352
+ return None
353
+ return coerce_float(val)
354
+
355
+
356
+ def maybe_coerce_boolean(val: str | None) -> bool | None:
357
+ if val is None:
358
+ return None
359
+ return coerce_boolean(val)
360
+
361
+
362
+ def removeprefix(string: str, prefix: str) -> str:
363
+ """Remove a prefix from a string.
364
+
365
+ Backport of `str.removeprefix` for Python < 3.9
366
+ """
367
+ if string.startswith(prefix):
368
+ return string[len(prefix) :]
369
+ return string
370
+
371
+
372
+ def removesuffix(string: str, suffix: str) -> str:
373
+ """Remove a suffix from a string.
374
+
375
+ Backport of `str.removesuffix` for Python < 3.9
376
+ """
377
+ if string.endswith(suffix):
378
+ return string[: -len(suffix)]
379
+ return string
380
+
381
+
382
+ def file_from_path(path: str) -> FileTypes:
383
+ contents = Path(path).read_bytes()
384
+ file_name = os.path.basename(path)
385
+ return (file_name, contents)
386
+
387
+
388
+ def get_required_header(headers: HeadersLike, header: str) -> str:
389
+ lower_header = header.lower()
390
+ if is_mapping_t(headers):
391
+ # mypy doesn't understand the type narrowing here
392
+ for k, v in headers.items(): # type: ignore
393
+ if k.lower() == lower_header and isinstance(v, str):
394
+ return v
395
+
396
+ # to deal with the case where the header looks like Stainless-Event-Id
397
+ intercaps_header = re.sub(r"([^\w])(\w)", lambda pat: pat.group(1) + pat.group(2).upper(), header.capitalize())
398
+
399
+ for normalized_header in [header, lower_header, header.upper(), intercaps_header]:
400
+ value = headers.get(normalized_header)
401
+ if value:
402
+ return value
403
+
404
+ raise ValueError(f"Could not find {header} header")
405
+
406
+
407
+ def get_async_library() -> str:
408
+ try:
409
+ return sniffio.current_async_library()
410
+ except Exception:
411
+ return "false"
412
+
413
+
414
+ def lru_cache(*, maxsize: int | None = 128) -> Callable[[CallableT], CallableT]:
415
+ """A version of functools.lru_cache that retains the type signature
416
+ for the wrapped function arguments.
417
+ """
418
+ wrapper = functools.lru_cache( # noqa: TID251
419
+ maxsize=maxsize,
420
+ )
421
+ return cast(Any, wrapper) # type: ignore[no-any-return]
422
+
423
+
424
+ def json_safe(data: object) -> object:
425
+ """Translates a mapping / sequence recursively in the same fashion
426
+ as `pydantic` v2's `model_dump(mode="json")`.
427
+ """
428
+ if is_mapping(data):
429
+ return {json_safe(key): json_safe(value) for key, value in data.items()}
430
+
431
+ if is_iterable(data) and not isinstance(data, (str, bytes, bytearray)):
432
+ return [json_safe(item) for item in data]
433
+
434
+ if isinstance(data, (datetime, date)):
435
+ return data.isoformat()
436
+
437
+ return data
@@ -0,0 +1,18 @@
1
+ # Copyright 2025 Google LLC
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+ #
15
+
16
+ from ..version import __version__ as __version__
17
+
18
+ __title__ = "google.genai._interactions"
@@ -0,0 +1,34 @@
1
+ # Copyright 2025 Google LLC
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+ #
15
+
16
+ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
17
+
18
+ from .interactions import (
19
+ InteractionsResource,
20
+ AsyncInteractionsResource,
21
+ InteractionsResourceWithRawResponse,
22
+ AsyncInteractionsResourceWithRawResponse,
23
+ InteractionsResourceWithStreamingResponse,
24
+ AsyncInteractionsResourceWithStreamingResponse,
25
+ )
26
+
27
+ __all__ = [
28
+ "InteractionsResource",
29
+ "AsyncInteractionsResource",
30
+ "InteractionsResourceWithRawResponse",
31
+ "AsyncInteractionsResourceWithRawResponse",
32
+ "InteractionsResourceWithStreamingResponse",
33
+ "AsyncInteractionsResourceWithStreamingResponse",
34
+ ]