mirascope 1.0.5__py3-none-any.whl → 2.1.1__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 (632) hide show
  1. mirascope/__init__.py +6 -6
  2. mirascope/_stubs.py +384 -0
  3. mirascope/_utils.py +34 -0
  4. mirascope/api/__init__.py +14 -0
  5. mirascope/api/_generated/README.md +207 -0
  6. mirascope/api/_generated/__init__.py +444 -0
  7. mirascope/api/_generated/annotations/__init__.py +33 -0
  8. mirascope/api/_generated/annotations/client.py +506 -0
  9. mirascope/api/_generated/annotations/raw_client.py +1414 -0
  10. mirascope/api/_generated/annotations/types/__init__.py +31 -0
  11. mirascope/api/_generated/annotations/types/annotations_create_request_label.py +5 -0
  12. mirascope/api/_generated/annotations/types/annotations_create_response.py +48 -0
  13. mirascope/api/_generated/annotations/types/annotations_create_response_label.py +5 -0
  14. mirascope/api/_generated/annotations/types/annotations_get_response.py +48 -0
  15. mirascope/api/_generated/annotations/types/annotations_get_response_label.py +5 -0
  16. mirascope/api/_generated/annotations/types/annotations_list_request_label.py +5 -0
  17. mirascope/api/_generated/annotations/types/annotations_list_response.py +21 -0
  18. mirascope/api/_generated/annotations/types/annotations_list_response_annotations_item.py +50 -0
  19. mirascope/api/_generated/annotations/types/annotations_list_response_annotations_item_label.py +5 -0
  20. mirascope/api/_generated/annotations/types/annotations_update_request_label.py +5 -0
  21. mirascope/api/_generated/annotations/types/annotations_update_response.py +48 -0
  22. mirascope/api/_generated/annotations/types/annotations_update_response_label.py +5 -0
  23. mirascope/api/_generated/api_keys/__init__.py +17 -0
  24. mirascope/api/_generated/api_keys/client.py +530 -0
  25. mirascope/api/_generated/api_keys/raw_client.py +1236 -0
  26. mirascope/api/_generated/api_keys/types/__init__.py +15 -0
  27. mirascope/api/_generated/api_keys/types/api_keys_create_response.py +28 -0
  28. mirascope/api/_generated/api_keys/types/api_keys_get_response.py +27 -0
  29. mirascope/api/_generated/api_keys/types/api_keys_list_all_for_org_response_item.py +40 -0
  30. mirascope/api/_generated/api_keys/types/api_keys_list_response_item.py +27 -0
  31. mirascope/api/_generated/client.py +211 -0
  32. mirascope/api/_generated/core/__init__.py +52 -0
  33. mirascope/api/_generated/core/api_error.py +23 -0
  34. mirascope/api/_generated/core/client_wrapper.py +46 -0
  35. mirascope/api/_generated/core/datetime_utils.py +28 -0
  36. mirascope/api/_generated/core/file.py +67 -0
  37. mirascope/api/_generated/core/force_multipart.py +16 -0
  38. mirascope/api/_generated/core/http_client.py +543 -0
  39. mirascope/api/_generated/core/http_response.py +55 -0
  40. mirascope/api/_generated/core/jsonable_encoder.py +100 -0
  41. mirascope/api/_generated/core/pydantic_utilities.py +255 -0
  42. mirascope/api/_generated/core/query_encoder.py +58 -0
  43. mirascope/api/_generated/core/remove_none_from_dict.py +11 -0
  44. mirascope/api/_generated/core/request_options.py +35 -0
  45. mirascope/api/_generated/core/serialization.py +276 -0
  46. mirascope/api/_generated/docs/__init__.py +4 -0
  47. mirascope/api/_generated/docs/client.py +91 -0
  48. mirascope/api/_generated/docs/raw_client.py +178 -0
  49. mirascope/api/_generated/environment.py +9 -0
  50. mirascope/api/_generated/environments/__init__.py +23 -0
  51. mirascope/api/_generated/environments/client.py +649 -0
  52. mirascope/api/_generated/environments/raw_client.py +1567 -0
  53. mirascope/api/_generated/environments/types/__init__.py +25 -0
  54. mirascope/api/_generated/environments/types/environments_create_response.py +24 -0
  55. mirascope/api/_generated/environments/types/environments_get_analytics_response.py +60 -0
  56. mirascope/api/_generated/environments/types/environments_get_analytics_response_top_functions_item.py +24 -0
  57. mirascope/api/_generated/environments/types/environments_get_analytics_response_top_models_item.py +22 -0
  58. mirascope/api/_generated/environments/types/environments_get_response.py +24 -0
  59. mirascope/api/_generated/environments/types/environments_list_response_item.py +24 -0
  60. mirascope/api/_generated/environments/types/environments_update_response.py +24 -0
  61. mirascope/api/_generated/errors/__init__.py +25 -0
  62. mirascope/api/_generated/errors/bad_request_error.py +14 -0
  63. mirascope/api/_generated/errors/conflict_error.py +14 -0
  64. mirascope/api/_generated/errors/forbidden_error.py +11 -0
  65. mirascope/api/_generated/errors/internal_server_error.py +10 -0
  66. mirascope/api/_generated/errors/not_found_error.py +11 -0
  67. mirascope/api/_generated/errors/payment_required_error.py +15 -0
  68. mirascope/api/_generated/errors/service_unavailable_error.py +14 -0
  69. mirascope/api/_generated/errors/too_many_requests_error.py +15 -0
  70. mirascope/api/_generated/errors/unauthorized_error.py +11 -0
  71. mirascope/api/_generated/functions/__init__.py +39 -0
  72. mirascope/api/_generated/functions/client.py +647 -0
  73. mirascope/api/_generated/functions/raw_client.py +1890 -0
  74. mirascope/api/_generated/functions/types/__init__.py +53 -0
  75. mirascope/api/_generated/functions/types/functions_create_request_dependencies_value.py +20 -0
  76. mirascope/api/_generated/functions/types/functions_create_response.py +37 -0
  77. mirascope/api/_generated/functions/types/functions_create_response_dependencies_value.py +20 -0
  78. mirascope/api/_generated/functions/types/functions_find_by_hash_response.py +39 -0
  79. mirascope/api/_generated/functions/types/functions_find_by_hash_response_dependencies_value.py +20 -0
  80. mirascope/api/_generated/functions/types/functions_get_by_env_response.py +53 -0
  81. mirascope/api/_generated/functions/types/functions_get_by_env_response_dependencies_value.py +22 -0
  82. mirascope/api/_generated/functions/types/functions_get_response.py +37 -0
  83. mirascope/api/_generated/functions/types/functions_get_response_dependencies_value.py +20 -0
  84. mirascope/api/_generated/functions/types/functions_list_by_env_response.py +25 -0
  85. mirascope/api/_generated/functions/types/functions_list_by_env_response_functions_item.py +56 -0
  86. mirascope/api/_generated/functions/types/functions_list_by_env_response_functions_item_dependencies_value.py +22 -0
  87. mirascope/api/_generated/functions/types/functions_list_response.py +21 -0
  88. mirascope/api/_generated/functions/types/functions_list_response_functions_item.py +41 -0
  89. mirascope/api/_generated/functions/types/functions_list_response_functions_item_dependencies_value.py +20 -0
  90. mirascope/api/_generated/health/__init__.py +7 -0
  91. mirascope/api/_generated/health/client.py +92 -0
  92. mirascope/api/_generated/health/raw_client.py +175 -0
  93. mirascope/api/_generated/health/types/__init__.py +8 -0
  94. mirascope/api/_generated/health/types/health_check_response.py +22 -0
  95. mirascope/api/_generated/health/types/health_check_response_status.py +5 -0
  96. mirascope/api/_generated/organization_invitations/__init__.py +33 -0
  97. mirascope/api/_generated/organization_invitations/client.py +546 -0
  98. mirascope/api/_generated/organization_invitations/raw_client.py +1519 -0
  99. mirascope/api/_generated/organization_invitations/types/__init__.py +53 -0
  100. mirascope/api/_generated/organization_invitations/types/organization_invitations_accept_response.py +34 -0
  101. mirascope/api/_generated/organization_invitations/types/organization_invitations_accept_response_role.py +7 -0
  102. mirascope/api/_generated/organization_invitations/types/organization_invitations_create_request_role.py +7 -0
  103. mirascope/api/_generated/organization_invitations/types/organization_invitations_create_response.py +48 -0
  104. mirascope/api/_generated/organization_invitations/types/organization_invitations_create_response_role.py +7 -0
  105. mirascope/api/_generated/organization_invitations/types/organization_invitations_create_response_status.py +7 -0
  106. mirascope/api/_generated/organization_invitations/types/organization_invitations_get_response.py +48 -0
  107. mirascope/api/_generated/organization_invitations/types/organization_invitations_get_response_role.py +7 -0
  108. mirascope/api/_generated/organization_invitations/types/organization_invitations_get_response_status.py +7 -0
  109. mirascope/api/_generated/organization_invitations/types/organization_invitations_list_response_item.py +48 -0
  110. mirascope/api/_generated/organization_invitations/types/organization_invitations_list_response_item_role.py +7 -0
  111. mirascope/api/_generated/organization_invitations/types/organization_invitations_list_response_item_status.py +7 -0
  112. mirascope/api/_generated/organization_memberships/__init__.py +19 -0
  113. mirascope/api/_generated/organization_memberships/client.py +302 -0
  114. mirascope/api/_generated/organization_memberships/raw_client.py +736 -0
  115. mirascope/api/_generated/organization_memberships/types/__init__.py +27 -0
  116. mirascope/api/_generated/organization_memberships/types/organization_memberships_list_response_item.py +33 -0
  117. mirascope/api/_generated/organization_memberships/types/organization_memberships_list_response_item_role.py +7 -0
  118. mirascope/api/_generated/organization_memberships/types/organization_memberships_update_request_role.py +7 -0
  119. mirascope/api/_generated/organization_memberships/types/organization_memberships_update_response.py +31 -0
  120. mirascope/api/_generated/organization_memberships/types/organization_memberships_update_response_role.py +7 -0
  121. mirascope/api/_generated/organizations/__init__.py +51 -0
  122. mirascope/api/_generated/organizations/client.py +869 -0
  123. mirascope/api/_generated/organizations/raw_client.py +2593 -0
  124. mirascope/api/_generated/organizations/types/__init__.py +71 -0
  125. mirascope/api/_generated/organizations/types/organizations_create_payment_intent_response.py +24 -0
  126. mirascope/api/_generated/organizations/types/organizations_create_response.py +26 -0
  127. mirascope/api/_generated/organizations/types/organizations_create_response_role.py +5 -0
  128. mirascope/api/_generated/organizations/types/organizations_get_response.py +26 -0
  129. mirascope/api/_generated/organizations/types/organizations_get_response_role.py +5 -0
  130. mirascope/api/_generated/organizations/types/organizations_list_response_item.py +26 -0
  131. mirascope/api/_generated/organizations/types/organizations_list_response_item_role.py +5 -0
  132. mirascope/api/_generated/organizations/types/organizations_preview_subscription_change_request_target_plan.py +7 -0
  133. mirascope/api/_generated/organizations/types/organizations_preview_subscription_change_response.py +47 -0
  134. mirascope/api/_generated/organizations/types/organizations_preview_subscription_change_response_validation_errors_item.py +33 -0
  135. mirascope/api/_generated/organizations/types/organizations_preview_subscription_change_response_validation_errors_item_resource.py +7 -0
  136. mirascope/api/_generated/organizations/types/organizations_router_balance_response.py +24 -0
  137. mirascope/api/_generated/organizations/types/organizations_subscription_response.py +53 -0
  138. mirascope/api/_generated/organizations/types/organizations_subscription_response_current_plan.py +7 -0
  139. mirascope/api/_generated/organizations/types/organizations_subscription_response_payment_method.py +26 -0
  140. mirascope/api/_generated/organizations/types/organizations_subscription_response_scheduled_change.py +34 -0
  141. mirascope/api/_generated/organizations/types/organizations_subscription_response_scheduled_change_target_plan.py +7 -0
  142. mirascope/api/_generated/organizations/types/organizations_update_response.py +26 -0
  143. mirascope/api/_generated/organizations/types/organizations_update_response_role.py +5 -0
  144. mirascope/api/_generated/organizations/types/organizations_update_subscription_request_target_plan.py +7 -0
  145. mirascope/api/_generated/organizations/types/organizations_update_subscription_response.py +35 -0
  146. mirascope/api/_generated/project_memberships/__init__.py +29 -0
  147. mirascope/api/_generated/project_memberships/client.py +528 -0
  148. mirascope/api/_generated/project_memberships/raw_client.py +1278 -0
  149. mirascope/api/_generated/project_memberships/types/__init__.py +33 -0
  150. mirascope/api/_generated/project_memberships/types/project_memberships_create_request_role.py +7 -0
  151. mirascope/api/_generated/project_memberships/types/project_memberships_create_response.py +35 -0
  152. mirascope/api/_generated/project_memberships/types/project_memberships_create_response_role.py +7 -0
  153. mirascope/api/_generated/project_memberships/types/project_memberships_get_response.py +33 -0
  154. mirascope/api/_generated/project_memberships/types/project_memberships_get_response_role.py +7 -0
  155. mirascope/api/_generated/project_memberships/types/project_memberships_list_response_item.py +33 -0
  156. mirascope/api/_generated/project_memberships/types/project_memberships_list_response_item_role.py +7 -0
  157. mirascope/api/_generated/project_memberships/types/project_memberships_update_request_role.py +7 -0
  158. mirascope/api/_generated/project_memberships/types/project_memberships_update_response.py +35 -0
  159. mirascope/api/_generated/project_memberships/types/project_memberships_update_response_role.py +7 -0
  160. mirascope/api/_generated/projects/__init__.py +7 -0
  161. mirascope/api/_generated/projects/client.py +428 -0
  162. mirascope/api/_generated/projects/raw_client.py +1302 -0
  163. mirascope/api/_generated/projects/types/__init__.py +10 -0
  164. mirascope/api/_generated/projects/types/projects_create_response.py +25 -0
  165. mirascope/api/_generated/projects/types/projects_get_response.py +25 -0
  166. mirascope/api/_generated/projects/types/projects_list_response_item.py +25 -0
  167. mirascope/api/_generated/projects/types/projects_update_response.py +25 -0
  168. mirascope/api/_generated/reference.md +4987 -0
  169. mirascope/api/_generated/tags/__init__.py +19 -0
  170. mirascope/api/_generated/tags/client.py +504 -0
  171. mirascope/api/_generated/tags/raw_client.py +1288 -0
  172. mirascope/api/_generated/tags/types/__init__.py +17 -0
  173. mirascope/api/_generated/tags/types/tags_create_response.py +41 -0
  174. mirascope/api/_generated/tags/types/tags_get_response.py +41 -0
  175. mirascope/api/_generated/tags/types/tags_list_response.py +23 -0
  176. mirascope/api/_generated/tags/types/tags_list_response_tags_item.py +41 -0
  177. mirascope/api/_generated/tags/types/tags_update_response.py +41 -0
  178. mirascope/api/_generated/token_cost/__init__.py +7 -0
  179. mirascope/api/_generated/token_cost/client.py +160 -0
  180. mirascope/api/_generated/token_cost/raw_client.py +264 -0
  181. mirascope/api/_generated/token_cost/types/__init__.py +8 -0
  182. mirascope/api/_generated/token_cost/types/token_cost_calculate_request_usage.py +54 -0
  183. mirascope/api/_generated/token_cost/types/token_cost_calculate_response.py +52 -0
  184. mirascope/api/_generated/traces/__init__.py +97 -0
  185. mirascope/api/_generated/traces/client.py +1103 -0
  186. mirascope/api/_generated/traces/raw_client.py +2322 -0
  187. mirascope/api/_generated/traces/types/__init__.py +155 -0
  188. mirascope/api/_generated/traces/types/traces_create_request_resource_spans_item.py +29 -0
  189. mirascope/api/_generated/traces/types/traces_create_request_resource_spans_item_resource.py +27 -0
  190. mirascope/api/_generated/traces/types/traces_create_request_resource_spans_item_resource_attributes_item.py +23 -0
  191. mirascope/api/_generated/traces/types/traces_create_request_resource_spans_item_resource_attributes_item_value.py +38 -0
  192. mirascope/api/_generated/traces/types/traces_create_request_resource_spans_item_resource_attributes_item_value_array_value.py +19 -0
  193. mirascope/api/_generated/traces/types/traces_create_request_resource_spans_item_resource_attributes_item_value_kvlist_value.py +22 -0
  194. mirascope/api/_generated/traces/types/traces_create_request_resource_spans_item_resource_attributes_item_value_kvlist_value_values_item.py +20 -0
  195. mirascope/api/_generated/traces/types/traces_create_request_resource_spans_item_scope_spans_item.py +29 -0
  196. mirascope/api/_generated/traces/types/traces_create_request_resource_spans_item_scope_spans_item_scope.py +31 -0
  197. mirascope/api/_generated/traces/types/traces_create_request_resource_spans_item_scope_spans_item_scope_attributes_item.py +23 -0
  198. mirascope/api/_generated/traces/types/traces_create_request_resource_spans_item_scope_spans_item_scope_attributes_item_value.py +38 -0
  199. mirascope/api/_generated/traces/types/traces_create_request_resource_spans_item_scope_spans_item_scope_attributes_item_value_array_value.py +19 -0
  200. mirascope/api/_generated/traces/types/traces_create_request_resource_spans_item_scope_spans_item_scope_attributes_item_value_kvlist_value.py +22 -0
  201. mirascope/api/_generated/traces/types/traces_create_request_resource_spans_item_scope_spans_item_scope_attributes_item_value_kvlist_value_values_item.py +22 -0
  202. mirascope/api/_generated/traces/types/traces_create_request_resource_spans_item_scope_spans_item_spans_item.py +48 -0
  203. mirascope/api/_generated/traces/types/traces_create_request_resource_spans_item_scope_spans_item_spans_item_attributes_item.py +23 -0
  204. mirascope/api/_generated/traces/types/traces_create_request_resource_spans_item_scope_spans_item_spans_item_attributes_item_value.py +38 -0
  205. mirascope/api/_generated/traces/types/traces_create_request_resource_spans_item_scope_spans_item_spans_item_attributes_item_value_array_value.py +19 -0
  206. mirascope/api/_generated/traces/types/traces_create_request_resource_spans_item_scope_spans_item_spans_item_attributes_item_value_kvlist_value.py +24 -0
  207. mirascope/api/_generated/traces/types/traces_create_request_resource_spans_item_scope_spans_item_spans_item_attributes_item_value_kvlist_value_values_item.py +22 -0
  208. mirascope/api/_generated/traces/types/traces_create_request_resource_spans_item_scope_spans_item_spans_item_status.py +20 -0
  209. mirascope/api/_generated/traces/types/traces_create_response.py +24 -0
  210. mirascope/api/_generated/traces/types/traces_create_response_partial_success.py +22 -0
  211. mirascope/api/_generated/traces/types/traces_get_analytics_summary_response.py +60 -0
  212. mirascope/api/_generated/traces/types/traces_get_analytics_summary_response_top_functions_item.py +24 -0
  213. mirascope/api/_generated/traces/types/traces_get_analytics_summary_response_top_models_item.py +22 -0
  214. mirascope/api/_generated/traces/types/traces_get_trace_detail_by_env_response.py +33 -0
  215. mirascope/api/_generated/traces/types/traces_get_trace_detail_by_env_response_spans_item.py +88 -0
  216. mirascope/api/_generated/traces/types/traces_get_trace_detail_response.py +33 -0
  217. mirascope/api/_generated/traces/types/traces_get_trace_detail_response_spans_item.py +88 -0
  218. mirascope/api/_generated/traces/types/traces_list_by_function_hash_response.py +25 -0
  219. mirascope/api/_generated/traces/types/traces_list_by_function_hash_response_traces_item.py +44 -0
  220. mirascope/api/_generated/traces/types/traces_search_by_env_request_attribute_filters_item.py +26 -0
  221. mirascope/api/_generated/traces/types/traces_search_by_env_request_attribute_filters_item_operator.py +7 -0
  222. mirascope/api/_generated/traces/types/traces_search_by_env_request_sort_by.py +7 -0
  223. mirascope/api/_generated/traces/types/traces_search_by_env_request_sort_order.py +7 -0
  224. mirascope/api/_generated/traces/types/traces_search_by_env_response.py +26 -0
  225. mirascope/api/_generated/traces/types/traces_search_by_env_response_spans_item.py +50 -0
  226. mirascope/api/_generated/traces/types/traces_search_request_attribute_filters_item.py +26 -0
  227. mirascope/api/_generated/traces/types/traces_search_request_attribute_filters_item_operator.py +7 -0
  228. mirascope/api/_generated/traces/types/traces_search_request_sort_by.py +7 -0
  229. mirascope/api/_generated/traces/types/traces_search_request_sort_order.py +5 -0
  230. mirascope/api/_generated/traces/types/traces_search_response.py +26 -0
  231. mirascope/api/_generated/traces/types/traces_search_response_spans_item.py +50 -0
  232. mirascope/api/_generated/types/__init__.py +85 -0
  233. mirascope/api/_generated/types/already_exists_error.py +22 -0
  234. mirascope/api/_generated/types/already_exists_error_tag.py +5 -0
  235. mirascope/api/_generated/types/bad_request_error_body.py +50 -0
  236. mirascope/api/_generated/types/click_house_error.py +22 -0
  237. mirascope/api/_generated/types/database_error.py +22 -0
  238. mirascope/api/_generated/types/database_error_tag.py +5 -0
  239. mirascope/api/_generated/types/date.py +3 -0
  240. mirascope/api/_generated/types/http_api_decode_error.py +27 -0
  241. mirascope/api/_generated/types/http_api_decode_error_tag.py +5 -0
  242. mirascope/api/_generated/types/immutable_resource_error.py +22 -0
  243. mirascope/api/_generated/types/internal_server_error_body.py +49 -0
  244. mirascope/api/_generated/types/issue.py +38 -0
  245. mirascope/api/_generated/types/issue_tag.py +10 -0
  246. mirascope/api/_generated/types/not_found_error_body.py +22 -0
  247. mirascope/api/_generated/types/not_found_error_tag.py +5 -0
  248. mirascope/api/_generated/types/number_from_string.py +3 -0
  249. mirascope/api/_generated/types/permission_denied_error.py +22 -0
  250. mirascope/api/_generated/types/permission_denied_error_tag.py +5 -0
  251. mirascope/api/_generated/types/plan_limit_exceeded_error.py +32 -0
  252. mirascope/api/_generated/types/plan_limit_exceeded_error_tag.py +7 -0
  253. mirascope/api/_generated/types/pricing_unavailable_error.py +23 -0
  254. mirascope/api/_generated/types/property_key.py +7 -0
  255. mirascope/api/_generated/types/property_key_key.py +25 -0
  256. mirascope/api/_generated/types/property_key_key_tag.py +5 -0
  257. mirascope/api/_generated/types/rate_limit_error.py +31 -0
  258. mirascope/api/_generated/types/rate_limit_error_tag.py +5 -0
  259. mirascope/api/_generated/types/service_unavailable_error_body.py +24 -0
  260. mirascope/api/_generated/types/service_unavailable_error_tag.py +7 -0
  261. mirascope/api/_generated/types/stripe_error.py +20 -0
  262. mirascope/api/_generated/types/subscription_past_due_error.py +31 -0
  263. mirascope/api/_generated/types/subscription_past_due_error_tag.py +7 -0
  264. mirascope/api/_generated/types/unauthorized_error_body.py +21 -0
  265. mirascope/api/_generated/types/unauthorized_error_tag.py +5 -0
  266. mirascope/api/client.py +255 -0
  267. mirascope/api/settings.py +99 -0
  268. mirascope/llm/__init__.py +316 -0
  269. mirascope/llm/calls/__init__.py +17 -0
  270. mirascope/llm/calls/calls.py +348 -0
  271. mirascope/llm/calls/decorator.py +268 -0
  272. mirascope/llm/content/__init__.py +71 -0
  273. mirascope/llm/content/audio.py +173 -0
  274. mirascope/llm/content/document.py +94 -0
  275. mirascope/llm/content/image.py +206 -0
  276. mirascope/llm/content/text.py +47 -0
  277. mirascope/llm/content/thought.py +58 -0
  278. mirascope/llm/content/tool_call.py +69 -0
  279. mirascope/llm/content/tool_output.py +43 -0
  280. mirascope/llm/context/__init__.py +6 -0
  281. mirascope/llm/context/_utils.py +41 -0
  282. mirascope/llm/context/context.py +24 -0
  283. mirascope/llm/exceptions.py +360 -0
  284. mirascope/llm/formatting/__init__.py +39 -0
  285. mirascope/llm/formatting/format.py +291 -0
  286. mirascope/llm/formatting/from_call_args.py +30 -0
  287. mirascope/llm/formatting/output_parser.py +178 -0
  288. mirascope/llm/formatting/partial.py +131 -0
  289. mirascope/llm/formatting/primitives.py +192 -0
  290. mirascope/llm/formatting/types.py +83 -0
  291. mirascope/llm/mcp/__init__.py +5 -0
  292. mirascope/llm/mcp/mcp_client.py +130 -0
  293. mirascope/llm/messages/__init__.py +35 -0
  294. mirascope/llm/messages/_utils.py +34 -0
  295. mirascope/llm/messages/message.py +190 -0
  296. mirascope/llm/models/__init__.py +21 -0
  297. mirascope/llm/models/models.py +1339 -0
  298. mirascope/llm/models/params.py +72 -0
  299. mirascope/llm/models/thinking_config.py +61 -0
  300. mirascope/llm/prompts/__init__.py +34 -0
  301. mirascope/llm/prompts/_utils.py +31 -0
  302. mirascope/llm/prompts/decorator.py +215 -0
  303. mirascope/llm/prompts/prompts.py +484 -0
  304. mirascope/llm/prompts/protocols.py +65 -0
  305. mirascope/llm/providers/__init__.py +65 -0
  306. mirascope/llm/providers/anthropic/__init__.py +11 -0
  307. mirascope/llm/providers/anthropic/_utils/__init__.py +27 -0
  308. mirascope/llm/providers/anthropic/_utils/beta_decode.py +297 -0
  309. mirascope/llm/providers/anthropic/_utils/beta_encode.py +272 -0
  310. mirascope/llm/providers/anthropic/_utils/decode.py +326 -0
  311. mirascope/llm/providers/anthropic/_utils/encode.py +431 -0
  312. mirascope/llm/providers/anthropic/_utils/errors.py +46 -0
  313. mirascope/llm/providers/anthropic/beta_provider.py +338 -0
  314. mirascope/llm/providers/anthropic/model_id.py +23 -0
  315. mirascope/llm/providers/anthropic/model_info.py +87 -0
  316. mirascope/llm/providers/anthropic/provider.py +440 -0
  317. mirascope/llm/providers/base/__init__.py +14 -0
  318. mirascope/llm/providers/base/_utils.py +248 -0
  319. mirascope/llm/providers/base/base_provider.py +1463 -0
  320. mirascope/llm/providers/base/kwargs.py +12 -0
  321. mirascope/llm/providers/google/__init__.py +6 -0
  322. mirascope/llm/providers/google/_utils/__init__.py +17 -0
  323. mirascope/llm/providers/google/_utils/decode.py +357 -0
  324. mirascope/llm/providers/google/_utils/encode.py +418 -0
  325. mirascope/llm/providers/google/_utils/errors.py +50 -0
  326. mirascope/llm/providers/google/message.py +7 -0
  327. mirascope/llm/providers/google/model_id.py +22 -0
  328. mirascope/llm/providers/google/model_info.py +63 -0
  329. mirascope/llm/providers/google/provider.py +456 -0
  330. mirascope/llm/providers/mirascope/__init__.py +5 -0
  331. mirascope/llm/providers/mirascope/_utils.py +73 -0
  332. mirascope/llm/providers/mirascope/provider.py +313 -0
  333. mirascope/llm/providers/mlx/__init__.py +9 -0
  334. mirascope/llm/providers/mlx/_utils.py +141 -0
  335. mirascope/llm/providers/mlx/encoding/__init__.py +8 -0
  336. mirascope/llm/providers/mlx/encoding/base.py +69 -0
  337. mirascope/llm/providers/mlx/encoding/transformers.py +146 -0
  338. mirascope/llm/providers/mlx/mlx.py +242 -0
  339. mirascope/llm/providers/mlx/model_id.py +17 -0
  340. mirascope/llm/providers/mlx/provider.py +416 -0
  341. mirascope/llm/providers/model_id.py +16 -0
  342. mirascope/llm/providers/ollama/__init__.py +7 -0
  343. mirascope/llm/providers/ollama/provider.py +71 -0
  344. mirascope/llm/providers/openai/__init__.py +15 -0
  345. mirascope/llm/providers/openai/_utils/__init__.py +5 -0
  346. mirascope/llm/providers/openai/_utils/errors.py +46 -0
  347. mirascope/llm/providers/openai/completions/__init__.py +7 -0
  348. mirascope/llm/providers/openai/completions/_utils/__init__.py +18 -0
  349. mirascope/llm/providers/openai/completions/_utils/decode.py +252 -0
  350. mirascope/llm/providers/openai/completions/_utils/encode.py +390 -0
  351. mirascope/llm/providers/openai/completions/_utils/feature_info.py +50 -0
  352. mirascope/llm/providers/openai/completions/base_provider.py +522 -0
  353. mirascope/llm/providers/openai/completions/provider.py +28 -0
  354. mirascope/llm/providers/openai/model_id.py +31 -0
  355. mirascope/llm/providers/openai/model_info.py +303 -0
  356. mirascope/llm/providers/openai/provider.py +405 -0
  357. mirascope/llm/providers/openai/responses/__init__.py +5 -0
  358. mirascope/llm/providers/openai/responses/_utils/__init__.py +15 -0
  359. mirascope/llm/providers/openai/responses/_utils/decode.py +289 -0
  360. mirascope/llm/providers/openai/responses/_utils/encode.py +399 -0
  361. mirascope/llm/providers/openai/responses/provider.py +472 -0
  362. mirascope/llm/providers/openrouter/__init__.py +5 -0
  363. mirascope/llm/providers/openrouter/provider.py +67 -0
  364. mirascope/llm/providers/provider_id.py +26 -0
  365. mirascope/llm/providers/provider_registry.py +305 -0
  366. mirascope/llm/providers/together/__init__.py +7 -0
  367. mirascope/llm/providers/together/provider.py +40 -0
  368. mirascope/llm/responses/__init__.py +66 -0
  369. mirascope/llm/responses/_utils.py +146 -0
  370. mirascope/llm/responses/base_response.py +103 -0
  371. mirascope/llm/responses/base_stream_response.py +824 -0
  372. mirascope/llm/responses/finish_reason.py +28 -0
  373. mirascope/llm/responses/response.py +362 -0
  374. mirascope/llm/responses/root_response.py +248 -0
  375. mirascope/llm/responses/stream_response.py +577 -0
  376. mirascope/llm/responses/streams.py +363 -0
  377. mirascope/llm/responses/usage.py +139 -0
  378. mirascope/llm/tools/__init__.py +71 -0
  379. mirascope/llm/tools/_utils.py +34 -0
  380. mirascope/llm/tools/decorator.py +184 -0
  381. mirascope/llm/tools/protocols.py +96 -0
  382. mirascope/llm/tools/provider_tools.py +18 -0
  383. mirascope/llm/tools/tool_schema.py +321 -0
  384. mirascope/llm/tools/toolkit.py +178 -0
  385. mirascope/llm/tools/tools.py +263 -0
  386. mirascope/llm/tools/types.py +112 -0
  387. mirascope/llm/tools/web_search_tool.py +32 -0
  388. mirascope/llm/types/__init__.py +22 -0
  389. mirascope/llm/types/dataclass.py +9 -0
  390. mirascope/llm/types/jsonable.py +44 -0
  391. mirascope/llm/types/type_vars.py +19 -0
  392. mirascope/ops/__init__.py +129 -0
  393. mirascope/ops/_internal/__init__.py +5 -0
  394. mirascope/ops/_internal/closure.py +1172 -0
  395. mirascope/ops/_internal/configuration.py +177 -0
  396. mirascope/ops/_internal/context.py +76 -0
  397. mirascope/ops/_internal/exporters/__init__.py +26 -0
  398. mirascope/ops/_internal/exporters/exporters.py +362 -0
  399. mirascope/ops/_internal/exporters/processors.py +104 -0
  400. mirascope/ops/_internal/exporters/types.py +165 -0
  401. mirascope/ops/_internal/exporters/utils.py +66 -0
  402. mirascope/ops/_internal/instrumentation/__init__.py +28 -0
  403. mirascope/ops/_internal/instrumentation/llm/__init__.py +8 -0
  404. mirascope/ops/_internal/instrumentation/llm/common.py +500 -0
  405. mirascope/ops/_internal/instrumentation/llm/cost.py +190 -0
  406. mirascope/ops/_internal/instrumentation/llm/encode.py +238 -0
  407. mirascope/ops/_internal/instrumentation/llm/gen_ai_types/__init__.py +38 -0
  408. mirascope/ops/_internal/instrumentation/llm/gen_ai_types/gen_ai_input_messages.py +31 -0
  409. mirascope/ops/_internal/instrumentation/llm/gen_ai_types/gen_ai_output_messages.py +38 -0
  410. mirascope/ops/_internal/instrumentation/llm/gen_ai_types/gen_ai_system_instructions.py +18 -0
  411. mirascope/ops/_internal/instrumentation/llm/gen_ai_types/shared.py +100 -0
  412. mirascope/ops/_internal/instrumentation/llm/llm.py +161 -0
  413. mirascope/ops/_internal/instrumentation/llm/model.py +1777 -0
  414. mirascope/ops/_internal/instrumentation/llm/response.py +521 -0
  415. mirascope/ops/_internal/instrumentation/llm/serialize.py +324 -0
  416. mirascope/ops/_internal/instrumentation/providers/__init__.py +29 -0
  417. mirascope/ops/_internal/instrumentation/providers/anthropic.py +78 -0
  418. mirascope/ops/_internal/instrumentation/providers/base.py +179 -0
  419. mirascope/ops/_internal/instrumentation/providers/google_genai.py +85 -0
  420. mirascope/ops/_internal/instrumentation/providers/openai.py +82 -0
  421. mirascope/ops/_internal/propagation.py +198 -0
  422. mirascope/ops/_internal/protocols.py +133 -0
  423. mirascope/ops/_internal/session.py +139 -0
  424. mirascope/ops/_internal/spans.py +232 -0
  425. mirascope/ops/_internal/traced_calls.py +389 -0
  426. mirascope/ops/_internal/traced_functions.py +528 -0
  427. mirascope/ops/_internal/tracing.py +353 -0
  428. mirascope/ops/_internal/types.py +13 -0
  429. mirascope/ops/_internal/utils.py +131 -0
  430. mirascope/ops/_internal/versioned_calls.py +512 -0
  431. mirascope/ops/_internal/versioned_functions.py +357 -0
  432. mirascope/ops/_internal/versioning.py +303 -0
  433. mirascope/ops/exceptions.py +21 -0
  434. mirascope-2.1.1.dist-info/METADATA +231 -0
  435. mirascope-2.1.1.dist-info/RECORD +437 -0
  436. {mirascope-1.0.5.dist-info → mirascope-2.1.1.dist-info}/WHEEL +1 -1
  437. {mirascope-1.0.5.dist-info → mirascope-2.1.1.dist-info}/licenses/LICENSE +1 -1
  438. mirascope/beta/__init__.py +0 -0
  439. mirascope/beta/openai/__init__.py +0 -5
  440. mirascope/beta/openai/parse.py +0 -129
  441. mirascope/beta/rag/__init__.py +0 -24
  442. mirascope/beta/rag/base/__init__.py +0 -22
  443. mirascope/beta/rag/base/chunkers/__init__.py +0 -2
  444. mirascope/beta/rag/base/chunkers/base_chunker.py +0 -37
  445. mirascope/beta/rag/base/chunkers/text_chunker.py +0 -33
  446. mirascope/beta/rag/base/config.py +0 -8
  447. mirascope/beta/rag/base/document.py +0 -11
  448. mirascope/beta/rag/base/embedders.py +0 -35
  449. mirascope/beta/rag/base/embedding_params.py +0 -18
  450. mirascope/beta/rag/base/embedding_response.py +0 -30
  451. mirascope/beta/rag/base/query_results.py +0 -7
  452. mirascope/beta/rag/base/vectorstore_params.py +0 -18
  453. mirascope/beta/rag/base/vectorstores.py +0 -37
  454. mirascope/beta/rag/chroma/__init__.py +0 -11
  455. mirascope/beta/rag/chroma/types.py +0 -57
  456. mirascope/beta/rag/chroma/vectorstores.py +0 -97
  457. mirascope/beta/rag/cohere/__init__.py +0 -11
  458. mirascope/beta/rag/cohere/embedders.py +0 -87
  459. mirascope/beta/rag/cohere/embedding_params.py +0 -29
  460. mirascope/beta/rag/cohere/embedding_response.py +0 -29
  461. mirascope/beta/rag/cohere/py.typed +0 -0
  462. mirascope/beta/rag/openai/__init__.py +0 -11
  463. mirascope/beta/rag/openai/embedders.py +0 -144
  464. mirascope/beta/rag/openai/embedding_params.py +0 -18
  465. mirascope/beta/rag/openai/embedding_response.py +0 -14
  466. mirascope/beta/rag/openai/py.typed +0 -0
  467. mirascope/beta/rag/pinecone/__init__.py +0 -19
  468. mirascope/beta/rag/pinecone/types.py +0 -143
  469. mirascope/beta/rag/pinecone/vectorstores.py +0 -148
  470. mirascope/beta/rag/weaviate/__init__.py +0 -6
  471. mirascope/beta/rag/weaviate/types.py +0 -92
  472. mirascope/beta/rag/weaviate/vectorstores.py +0 -103
  473. mirascope/core/__init__.py +0 -55
  474. mirascope/core/anthropic/__init__.py +0 -21
  475. mirascope/core/anthropic/_call.py +0 -71
  476. mirascope/core/anthropic/_utils/__init__.py +0 -16
  477. mirascope/core/anthropic/_utils/_calculate_cost.py +0 -63
  478. mirascope/core/anthropic/_utils/_convert_message_params.py +0 -54
  479. mirascope/core/anthropic/_utils/_get_json_output.py +0 -34
  480. mirascope/core/anthropic/_utils/_handle_stream.py +0 -89
  481. mirascope/core/anthropic/_utils/_setup_call.py +0 -76
  482. mirascope/core/anthropic/call_params.py +0 -36
  483. mirascope/core/anthropic/call_response.py +0 -158
  484. mirascope/core/anthropic/call_response_chunk.py +0 -104
  485. mirascope/core/anthropic/dynamic_config.py +0 -26
  486. mirascope/core/anthropic/py.typed +0 -0
  487. mirascope/core/anthropic/stream.py +0 -140
  488. mirascope/core/anthropic/tool.py +0 -77
  489. mirascope/core/base/__init__.py +0 -40
  490. mirascope/core/base/_call_factory.py +0 -323
  491. mirascope/core/base/_create.py +0 -167
  492. mirascope/core/base/_extract.py +0 -139
  493. mirascope/core/base/_partial.py +0 -63
  494. mirascope/core/base/_utils/__init__.py +0 -64
  495. mirascope/core/base/_utils/_base_type.py +0 -17
  496. mirascope/core/base/_utils/_convert_base_model_to_base_tool.py +0 -45
  497. mirascope/core/base/_utils/_convert_base_type_to_base_tool.py +0 -24
  498. mirascope/core/base/_utils/_convert_function_to_base_tool.py +0 -126
  499. mirascope/core/base/_utils/_default_tool_docstring.py +0 -6
  500. mirascope/core/base/_utils/_extract_tool_return.py +0 -36
  501. mirascope/core/base/_utils/_format_template.py +0 -29
  502. mirascope/core/base/_utils/_get_audio_type.py +0 -18
  503. mirascope/core/base/_utils/_get_fn_args.py +0 -14
  504. mirascope/core/base/_utils/_get_image_type.py +0 -26
  505. mirascope/core/base/_utils/_get_metadata.py +0 -17
  506. mirascope/core/base/_utils/_get_possible_user_message_param.py +0 -21
  507. mirascope/core/base/_utils/_get_prompt_template.py +0 -25
  508. mirascope/core/base/_utils/_get_template_values.py +0 -52
  509. mirascope/core/base/_utils/_get_template_variables.py +0 -38
  510. mirascope/core/base/_utils/_json_mode_content.py +0 -15
  511. mirascope/core/base/_utils/_parse_content_template.py +0 -157
  512. mirascope/core/base/_utils/_parse_prompt_messages.py +0 -51
  513. mirascope/core/base/_utils/_protocols.py +0 -215
  514. mirascope/core/base/_utils/_setup_call.py +0 -64
  515. mirascope/core/base/_utils/_setup_extract_tool.py +0 -24
  516. mirascope/core/base/call_params.py +0 -6
  517. mirascope/core/base/call_response.py +0 -189
  518. mirascope/core/base/call_response_chunk.py +0 -91
  519. mirascope/core/base/dynamic_config.py +0 -55
  520. mirascope/core/base/message_param.py +0 -61
  521. mirascope/core/base/metadata.py +0 -13
  522. mirascope/core/base/prompt.py +0 -415
  523. mirascope/core/base/stream.py +0 -365
  524. mirascope/core/base/structured_stream.py +0 -251
  525. mirascope/core/base/tool.py +0 -126
  526. mirascope/core/base/toolkit.py +0 -146
  527. mirascope/core/cohere/__init__.py +0 -21
  528. mirascope/core/cohere/_call.py +0 -71
  529. mirascope/core/cohere/_utils/__init__.py +0 -16
  530. mirascope/core/cohere/_utils/_calculate_cost.py +0 -39
  531. mirascope/core/cohere/_utils/_convert_message_params.py +0 -31
  532. mirascope/core/cohere/_utils/_get_json_output.py +0 -31
  533. mirascope/core/cohere/_utils/_handle_stream.py +0 -33
  534. mirascope/core/cohere/_utils/_setup_call.py +0 -89
  535. mirascope/core/cohere/call_params.py +0 -57
  536. mirascope/core/cohere/call_response.py +0 -167
  537. mirascope/core/cohere/call_response_chunk.py +0 -101
  538. mirascope/core/cohere/dynamic_config.py +0 -24
  539. mirascope/core/cohere/py.typed +0 -0
  540. mirascope/core/cohere/stream.py +0 -113
  541. mirascope/core/cohere/tool.py +0 -92
  542. mirascope/core/gemini/__init__.py +0 -21
  543. mirascope/core/gemini/_call.py +0 -71
  544. mirascope/core/gemini/_utils/__init__.py +0 -16
  545. mirascope/core/gemini/_utils/_calculate_cost.py +0 -8
  546. mirascope/core/gemini/_utils/_convert_message_params.py +0 -74
  547. mirascope/core/gemini/_utils/_get_json_output.py +0 -33
  548. mirascope/core/gemini/_utils/_handle_stream.py +0 -33
  549. mirascope/core/gemini/_utils/_setup_call.py +0 -68
  550. mirascope/core/gemini/call_params.py +0 -28
  551. mirascope/core/gemini/call_response.py +0 -173
  552. mirascope/core/gemini/call_response_chunk.py +0 -85
  553. mirascope/core/gemini/dynamic_config.py +0 -26
  554. mirascope/core/gemini/stream.py +0 -121
  555. mirascope/core/gemini/tool.py +0 -104
  556. mirascope/core/groq/__init__.py +0 -21
  557. mirascope/core/groq/_call.py +0 -71
  558. mirascope/core/groq/_utils/__init__.py +0 -16
  559. mirascope/core/groq/_utils/_calculate_cost.py +0 -68
  560. mirascope/core/groq/_utils/_convert_message_params.py +0 -23
  561. mirascope/core/groq/_utils/_get_json_output.py +0 -27
  562. mirascope/core/groq/_utils/_handle_stream.py +0 -121
  563. mirascope/core/groq/_utils/_setup_call.py +0 -67
  564. mirascope/core/groq/call_params.py +0 -51
  565. mirascope/core/groq/call_response.py +0 -160
  566. mirascope/core/groq/call_response_chunk.py +0 -89
  567. mirascope/core/groq/dynamic_config.py +0 -26
  568. mirascope/core/groq/py.typed +0 -0
  569. mirascope/core/groq/stream.py +0 -136
  570. mirascope/core/groq/tool.py +0 -79
  571. mirascope/core/litellm/__init__.py +0 -6
  572. mirascope/core/litellm/_call.py +0 -73
  573. mirascope/core/litellm/_utils/__init__.py +0 -5
  574. mirascope/core/litellm/_utils/_setup_call.py +0 -46
  575. mirascope/core/litellm/py.typed +0 -0
  576. mirascope/core/mistral/__init__.py +0 -21
  577. mirascope/core/mistral/_call.py +0 -69
  578. mirascope/core/mistral/_utils/__init__.py +0 -16
  579. mirascope/core/mistral/_utils/_calculate_cost.py +0 -47
  580. mirascope/core/mistral/_utils/_convert_message_params.py +0 -23
  581. mirascope/core/mistral/_utils/_get_json_output.py +0 -28
  582. mirascope/core/mistral/_utils/_handle_stream.py +0 -121
  583. mirascope/core/mistral/_utils/_setup_call.py +0 -86
  584. mirascope/core/mistral/call_params.py +0 -36
  585. mirascope/core/mistral/call_response.py +0 -156
  586. mirascope/core/mistral/call_response_chunk.py +0 -84
  587. mirascope/core/mistral/dynamic_config.py +0 -24
  588. mirascope/core/mistral/py.typed +0 -0
  589. mirascope/core/mistral/stream.py +0 -117
  590. mirascope/core/mistral/tool.py +0 -77
  591. mirascope/core/openai/__init__.py +0 -21
  592. mirascope/core/openai/_call.py +0 -71
  593. mirascope/core/openai/_utils/__init__.py +0 -16
  594. mirascope/core/openai/_utils/_calculate_cost.py +0 -110
  595. mirascope/core/openai/_utils/_convert_message_params.py +0 -53
  596. mirascope/core/openai/_utils/_get_json_output.py +0 -27
  597. mirascope/core/openai/_utils/_handle_stream.py +0 -125
  598. mirascope/core/openai/_utils/_setup_call.py +0 -62
  599. mirascope/core/openai/call_params.py +0 -54
  600. mirascope/core/openai/call_response.py +0 -162
  601. mirascope/core/openai/call_response_chunk.py +0 -90
  602. mirascope/core/openai/dynamic_config.py +0 -26
  603. mirascope/core/openai/py.typed +0 -0
  604. mirascope/core/openai/stream.py +0 -148
  605. mirascope/core/openai/tool.py +0 -79
  606. mirascope/core/py.typed +0 -0
  607. mirascope/integrations/__init__.py +0 -20
  608. mirascope/integrations/_middleware_factory.py +0 -277
  609. mirascope/integrations/langfuse/__init__.py +0 -3
  610. mirascope/integrations/langfuse/_utils.py +0 -114
  611. mirascope/integrations/langfuse/_with_langfuse.py +0 -71
  612. mirascope/integrations/logfire/__init__.py +0 -3
  613. mirascope/integrations/logfire/_utils.py +0 -188
  614. mirascope/integrations/logfire/_with_logfire.py +0 -60
  615. mirascope/integrations/otel/__init__.py +0 -5
  616. mirascope/integrations/otel/_utils.py +0 -268
  617. mirascope/integrations/otel/_with_hyperdx.py +0 -61
  618. mirascope/integrations/otel/_with_otel.py +0 -60
  619. mirascope/integrations/tenacity.py +0 -50
  620. mirascope/py.typed +0 -0
  621. mirascope/v0/__init__.py +0 -43
  622. mirascope/v0/anthropic.py +0 -54
  623. mirascope/v0/base/__init__.py +0 -12
  624. mirascope/v0/base/calls.py +0 -118
  625. mirascope/v0/base/extractors.py +0 -122
  626. mirascope/v0/base/ops_utils.py +0 -207
  627. mirascope/v0/base/prompts.py +0 -48
  628. mirascope/v0/base/types.py +0 -14
  629. mirascope/v0/base/utils.py +0 -21
  630. mirascope/v0/openai.py +0 -54
  631. mirascope-1.0.5.dist-info/METADATA +0 -519
  632. mirascope-1.0.5.dist-info/RECORD +0 -198
@@ -0,0 +1,238 @@
1
+ """Utilities for encoding Mirascope messages into GenAI semconv payloads."""
2
+
3
+ from __future__ import annotations
4
+
5
+ import json
6
+ from collections.abc import Sequence
7
+ from dataclasses import dataclass
8
+ from typing import TYPE_CHECKING
9
+
10
+ from . import gen_ai_types
11
+
12
+ if TYPE_CHECKING:
13
+ from typing import TypeAlias
14
+
15
+ MessagePart: TypeAlias = (
16
+ gen_ai_types.TextPart
17
+ | gen_ai_types.ToolCallRequestPart
18
+ | gen_ai_types.ToolCallResponsePart
19
+ | gen_ai_types.BlobPart
20
+ | gen_ai_types.FilePart
21
+ | gen_ai_types.UriPart
22
+ | gen_ai_types.ReasoningPart
23
+ | gen_ai_types.GenericPart
24
+ )
25
+
26
+
27
+ from .....llm.content import (
28
+ Audio,
29
+ Base64ImageSource,
30
+ Document,
31
+ Image,
32
+ Text,
33
+ Thought,
34
+ ToolCall,
35
+ ToolOutput,
36
+ )
37
+ from .....llm.formatting import FormattableT
38
+ from .....llm.messages import AssistantMessage, Message, SystemMessage
39
+ from .....llm.responses.finish_reason import FinishReason
40
+ from .....llm.responses.root_response import RootResponse
41
+ from .....llm.tools import ToolkitT
42
+ from .....llm.types import Jsonable
43
+
44
+
45
+ @dataclass(frozen=True, slots=True)
46
+ class OTelMessageSnapshot:
47
+ """Structured view of system, input, and output messages."""
48
+
49
+ system_instructions: gen_ai_types.SystemInstructions
50
+ """Instructions to be executed prior to the conversation."""
51
+
52
+ inputs: gen_ai_types.InputMessages
53
+ """Messages to be sent to the model."""
54
+
55
+ outputs: gen_ai_types.OutputMessages
56
+ """Messages received from the model."""
57
+
58
+
59
+ def _serialize_message_parts(
60
+ parts: Sequence[
61
+ Text | ToolCall | ToolOutput[Jsonable] | Thought | Image | Audio | Document
62
+ ],
63
+ ) -> list[MessagePart]:
64
+ """Serialize message content parts into GenAI-compliant dictionaries.
65
+
66
+ Handles Text, ToolCall, ToolOutput, Thought, Image, Audio, Document,
67
+ and str types.
68
+ """
69
+ serialized: list[MessagePart] = []
70
+ for part in parts:
71
+ match part:
72
+ case Text():
73
+ text_part: gen_ai_types.TextPart = {
74
+ "type": "text",
75
+ "content": part.text,
76
+ }
77
+ serialized.append(text_part)
78
+ case ToolCall():
79
+ try:
80
+ arguments = json.loads(part.args)
81
+ except json.JSONDecodeError: # pragma: no cover
82
+ arguments = ""
83
+ tool_call_part: gen_ai_types.ToolCallRequestPart = {
84
+ "type": "tool_call",
85
+ "id": part.id,
86
+ "name": part.name,
87
+ "arguments": arguments,
88
+ }
89
+ serialized.append(tool_call_part)
90
+ case ToolOutput():
91
+ tool_output_part: gen_ai_types.ToolCallResponsePart = {
92
+ "type": "tool_call_response",
93
+ "id": part.id,
94
+ "response": part.result,
95
+ }
96
+ serialized.append(tool_output_part)
97
+ case Thought():
98
+ serialized.append(
99
+ gen_ai_types.ReasoningPart(type="reasoning", content=part.thought)
100
+ )
101
+ case Image():
102
+ if isinstance(part.source, Base64ImageSource):
103
+ image = gen_ai_types.BlobPart(
104
+ type="blob",
105
+ modality="image",
106
+ mime_type=part.source.mime_type,
107
+ content=part.source.data,
108
+ )
109
+ else:
110
+ image = gen_ai_types.UriPart(
111
+ type="uri", modality="image", uri=part.source.url
112
+ )
113
+ serialized.append(image)
114
+ case Audio():
115
+ serialized.append(
116
+ gen_ai_types.BlobPart(
117
+ type="blob",
118
+ modality="audio",
119
+ mime_type=part.source.mime_type,
120
+ content=part.source.data,
121
+ )
122
+ )
123
+ case Document(): # pragma: no cover
124
+ raise NotImplementedError(
125
+ "Document serialization is not yet supported by any provider. "
126
+ "This will be implemented when provider support is added."
127
+ )
128
+ return serialized
129
+
130
+
131
+ def _serialize_message(message: Message) -> gen_ai_types.ChatMessage:
132
+ """Serialize a Mirascope message into a GenAI ChatMessage."""
133
+ content_parts = _serialize_message_parts(
134
+ message.content if not isinstance(message, SystemMessage) else [message.content]
135
+ )
136
+ serialized: gen_ai_types.ChatMessage = {
137
+ "role": message.role,
138
+ "parts": content_parts,
139
+ }
140
+ name = getattr(message, "name", None)
141
+ if name:
142
+ serialized["name"] = name
143
+ return serialized
144
+
145
+
146
+ def map_finish_reason(
147
+ reason: FinishReason | None,
148
+ ) -> gen_ai_types.FinishReason:
149
+ """Map a finish reason to a GenAI finish reason."""
150
+ if reason is None:
151
+ return "stop"
152
+ elif reason == FinishReason.MAX_TOKENS:
153
+ return "length"
154
+ elif reason == FinishReason.REFUSAL: # pragma: no cover
155
+ return "content_filter"
156
+ raise ValueError(f"Unknown finish reason: {reason}") # pragma: no cover
157
+
158
+
159
+ def _serialize_output_message(
160
+ message: AssistantMessage, finish_reason: FinishReason | None
161
+ ) -> gen_ai_types.OutputMessage:
162
+ """Serialize an assistant message into a GenAI OutputMessage with finish_reason."""
163
+ chat_message = _serialize_message(message)
164
+ output_message: gen_ai_types.OutputMessage = {
165
+ "role": chat_message["role"],
166
+ "parts": chat_message["parts"],
167
+ "finish_reason": map_finish_reason(finish_reason),
168
+ }
169
+ if "name" in chat_message:
170
+ output_message["name"] = chat_message["name"]
171
+ return output_message
172
+
173
+
174
+ def split_request_messages(
175
+ messages: Sequence[Message],
176
+ ) -> tuple[gen_ai_types.SystemInstructions, gen_ai_types.InputMessages]:
177
+ """Return serialized system instructions and non-system input messages.
178
+
179
+ System messages are flattened into a list of parts (not wrapped in message objects),
180
+ while other messages are serialized as complete ChatMessage objects.
181
+ """
182
+ system_instructions: gen_ai_types.SystemInstructions = []
183
+ inputs: gen_ai_types.InputMessages = []
184
+ for message in messages:
185
+ if message.role == "system":
186
+ # System messages contribute only their parts (flattened)
187
+ parts = _serialize_message_parts(
188
+ [message.content]
189
+ if isinstance(message, SystemMessage)
190
+ else message.content
191
+ )
192
+ system_instructions.extend(parts)
193
+ else:
194
+ # Non-system messages are serialized as full ChatMessage objects
195
+ serialized = _serialize_message(message)
196
+ inputs.append(serialized)
197
+ return system_instructions, inputs
198
+
199
+
200
+ def snapshot_from_response_messages(
201
+ *,
202
+ request_messages: Sequence[Message],
203
+ assistant_message: AssistantMessage,
204
+ finish_reason: FinishReason | None,
205
+ ) -> OTelMessageSnapshot:
206
+ """Build a snapshot using the request/response boundary for a call."""
207
+
208
+ system_instructions, inputs = split_request_messages(request_messages)
209
+ outputs = [_serialize_output_message(assistant_message, finish_reason)]
210
+ return OTelMessageSnapshot(
211
+ system_instructions=system_instructions,
212
+ inputs=inputs,
213
+ outputs=outputs,
214
+ )
215
+
216
+
217
+ def snapshot_from_root_response(
218
+ response: RootResponse[ToolkitT, FormattableT | None],
219
+ *,
220
+ request_messages: Sequence[Message] | None = None,
221
+ ) -> OTelMessageSnapshot:
222
+ """Build a snapshot directly from a `RootResponse`.
223
+
224
+ Args:
225
+ response: The response that includes the entire conversation history.
226
+ request_messages: Optional explicit request message sequence. Defaults to all
227
+ but the final assistant message inside `response.messages`.
228
+ """
229
+
230
+ assistant_message = response.messages[-1]
231
+ if not isinstance(assistant_message, AssistantMessage): # pragma: no cover
232
+ raise TypeError("Final response message must be an AssistantMessage")
233
+
234
+ return snapshot_from_response_messages(
235
+ request_messages=request_messages or response.messages[:-1],
236
+ assistant_message=assistant_message,
237
+ finish_reason=response.finish_reason,
238
+ )
@@ -0,0 +1,38 @@
1
+ """OpenTelemetry Gen AI Semantic Conventions types."""
2
+
3
+ from __future__ import annotations
4
+
5
+ from .gen_ai_input_messages import ChatMessage, InputMessages
6
+ from .gen_ai_output_messages import FinishReason, OutputMessage, OutputMessages
7
+ from .gen_ai_system_instructions import SystemInstructions
8
+ from .shared import (
9
+ BlobPart,
10
+ FilePart,
11
+ GenericPart,
12
+ Modality,
13
+ ReasoningPart,
14
+ Role,
15
+ TextPart,
16
+ ToolCallRequestPart,
17
+ ToolCallResponsePart,
18
+ UriPart,
19
+ )
20
+
21
+ __all__ = [
22
+ "BlobPart",
23
+ "ChatMessage",
24
+ "FilePart",
25
+ "FinishReason",
26
+ "GenericPart",
27
+ "InputMessages",
28
+ "Modality",
29
+ "OutputMessage",
30
+ "OutputMessages",
31
+ "ReasoningPart",
32
+ "Role",
33
+ "SystemInstructions",
34
+ "TextPart",
35
+ "ToolCallRequestPart",
36
+ "ToolCallResponsePart",
37
+ "UriPart",
38
+ ]
@@ -0,0 +1,31 @@
1
+ """OpenTelemetry Gen AI Semantic Conventions types."""
2
+
3
+ from __future__ import annotations
4
+
5
+ from typing import TypeAlias, TypedDict
6
+ from typing_extensions import NotRequired
7
+
8
+ from . import shared
9
+
10
+
11
+ class ChatMessage(TypedDict):
12
+ role: shared.Role | str
13
+ """Role of the entity that created the message."""
14
+
15
+ parts: list[
16
+ shared.TextPart
17
+ | shared.ToolCallRequestPart
18
+ | shared.ToolCallResponsePart
19
+ | shared.BlobPart
20
+ | shared.FilePart
21
+ | shared.UriPart
22
+ | shared.ReasoningPart
23
+ | shared.GenericPart
24
+ ]
25
+ """List of message parts that make up the message content."""
26
+
27
+ name: NotRequired[str | None]
28
+ """The name of the participant."""
29
+
30
+
31
+ InputMessages: TypeAlias = list[ChatMessage]
@@ -0,0 +1,38 @@
1
+ """OpenTelemetry Gen AI Semantic Conventions types."""
2
+
3
+ from __future__ import annotations
4
+
5
+ from typing import Literal, TypeAlias, TypedDict
6
+ from typing_extensions import NotRequired
7
+
8
+ from . import shared
9
+
10
+ FinishReason: TypeAlias = Literal[
11
+ "stop", "length", "content_filter", "tool_call", "error"
12
+ ]
13
+
14
+
15
+ class OutputMessage(TypedDict):
16
+ role: shared.Role | str
17
+ """Role of the entity that created the message."""
18
+
19
+ parts: list[
20
+ shared.TextPart
21
+ | shared.ToolCallRequestPart
22
+ | shared.ToolCallResponsePart
23
+ | shared.BlobPart
24
+ | shared.FilePart
25
+ | shared.UriPart
26
+ | shared.ReasoningPart
27
+ | shared.GenericPart
28
+ ]
29
+ """List of message parts that make up the message content."""
30
+
31
+ name: NotRequired[str | None]
32
+ """The name of the participant."""
33
+
34
+ finish_reason: FinishReason | str
35
+ """Reason for finishing the generation."""
36
+
37
+
38
+ OutputMessages: TypeAlias = list[OutputMessage]
@@ -0,0 +1,18 @@
1
+ """OpenTelemetry Gen AI Semantic Conventions types."""
2
+
3
+ from __future__ import annotations
4
+
5
+ from typing import TypeAlias
6
+
7
+ from . import shared
8
+
9
+ SystemInstructions: TypeAlias = list[
10
+ shared.TextPart
11
+ | shared.ToolCallRequestPart
12
+ | shared.ToolCallResponsePart
13
+ | shared.BlobPart
14
+ | shared.FilePart
15
+ | shared.UriPart
16
+ | shared.ReasoningPart
17
+ | shared.GenericPart
18
+ ]
@@ -0,0 +1,100 @@
1
+ """OpenTelemetry Gen AI Semantic Conventions types."""
2
+
3
+ from __future__ import annotations
4
+
5
+ from typing import Any, Literal, TypeAlias, TypedDict
6
+ from typing_extensions import NotRequired
7
+
8
+
9
+ class BlobPart(TypedDict):
10
+ type: Literal["blob"]
11
+ """The type of the content captured in this part."""
12
+
13
+ mime_type: NotRequired[str | None]
14
+ """The IANA MIME type of the attached data."""
15
+
16
+ modality: Modality | str
17
+ """The general modality of the data if it is known. Instrumentations SHOULD also set the mimeType field if the specific type is known."""
18
+
19
+ content: str
20
+ """Raw bytes of the attached data. This field SHOULD be encoded as a base64 string when transmitted as JSON."""
21
+
22
+
23
+ class FilePart(TypedDict):
24
+ type: Literal["file"]
25
+ """The type of the content captured in this part."""
26
+
27
+ mime_type: NotRequired[str | None]
28
+ """The IANA MIME type of the attached data."""
29
+
30
+ modality: Modality | str
31
+ """The general modality of the data if it is known. Instrumentations SHOULD also set the mimeType field if the specific type is known."""
32
+
33
+ file_id: str
34
+ """An identifier referencing a file that was pre-uploaded to the provider."""
35
+
36
+
37
+ class GenericPart(TypedDict):
38
+ type: str
39
+ """The type of the content captured in this part."""
40
+
41
+
42
+ Modality: TypeAlias = Literal["image", "video", "audio"]
43
+
44
+
45
+ class ReasoningPart(TypedDict):
46
+ type: Literal["reasoning"]
47
+ """The type of the content captured in this part."""
48
+
49
+ content: str
50
+ """Reasoning/thinking content received from the model."""
51
+
52
+
53
+ Role: TypeAlias = Literal["system", "user", "assistant", "tool"]
54
+
55
+
56
+ class TextPart(TypedDict):
57
+ type: Literal["text"]
58
+ """The type of the content captured in this part."""
59
+
60
+ content: str
61
+ """Text content sent to or received from the model."""
62
+
63
+
64
+ class ToolCallRequestPart(TypedDict):
65
+ type: Literal["tool_call"]
66
+ """The type of the content captured in this part."""
67
+
68
+ id: NotRequired[str | None]
69
+ """Unique identifier for the tool call."""
70
+
71
+ name: str
72
+ """Name of the tool."""
73
+
74
+ arguments: NotRequired[Any]
75
+ """Arguments for the tool call."""
76
+
77
+
78
+ class ToolCallResponsePart(TypedDict):
79
+ type: Literal["tool_call_response"]
80
+ """The type of the content captured in this part."""
81
+
82
+ id: NotRequired[str | None]
83
+ """Unique tool call identifier."""
84
+
85
+ response: Any
86
+ """Tool call response."""
87
+
88
+
89
+ class UriPart(TypedDict):
90
+ type: Literal["uri"]
91
+ """The type of the content captured in this part."""
92
+
93
+ mime_type: NotRequired[str | None]
94
+ """The IANA MIME type of the attached data."""
95
+
96
+ modality: Modality | str
97
+ """The general modality of the data if it is known. Instrumentations SHOULD also set the mimeType field if the specific type is known."""
98
+
99
+ uri: str
100
+ """A URI referencing attached data. It should not be a base64 data URL, which should use the `blob` part instead. The URI may use a scheme known to the provider api (e.g. `gs://bucket/object.png`), or be a publicly accessible location."""
@@ -0,0 +1,161 @@
1
+ """OpenTelemetry GenAI instrumentation for `mirascope.llm`.
2
+
3
+ This module provides the public instrument_llm() and uninstrument_llm() functions
4
+ that enable/disable instrumentation for Model calls and Response.resume methods.
5
+ """
6
+
7
+ from __future__ import annotations
8
+
9
+ import os
10
+
11
+ from opentelemetry import trace as otel_trace
12
+
13
+ from ...configuration import get_tracer
14
+ from .model import (
15
+ unwrap_model_call,
16
+ unwrap_model_call_async,
17
+ unwrap_model_context_call,
18
+ unwrap_model_context_call_async,
19
+ unwrap_model_context_resume,
20
+ unwrap_model_context_resume_async,
21
+ unwrap_model_context_resume_stream,
22
+ unwrap_model_context_resume_stream_async,
23
+ unwrap_model_context_stream,
24
+ unwrap_model_context_stream_async,
25
+ unwrap_model_resume,
26
+ unwrap_model_resume_async,
27
+ unwrap_model_resume_stream,
28
+ unwrap_model_resume_stream_async,
29
+ unwrap_model_stream,
30
+ unwrap_model_stream_async,
31
+ wrap_model_call,
32
+ wrap_model_call_async,
33
+ wrap_model_context_call,
34
+ wrap_model_context_call_async,
35
+ wrap_model_context_resume,
36
+ wrap_model_context_resume_async,
37
+ wrap_model_context_resume_stream,
38
+ wrap_model_context_resume_stream_async,
39
+ wrap_model_context_stream,
40
+ wrap_model_context_stream_async,
41
+ wrap_model_resume,
42
+ wrap_model_resume_async,
43
+ wrap_model_resume_stream,
44
+ wrap_model_resume_stream_async,
45
+ wrap_model_stream,
46
+ wrap_model_stream_async,
47
+ )
48
+ from .response import (
49
+ unwrap_async_context_response_resume,
50
+ unwrap_async_context_stream_response_resume,
51
+ unwrap_async_response_resume,
52
+ unwrap_async_stream_response_resume,
53
+ unwrap_context_response_resume,
54
+ unwrap_context_stream_response_resume,
55
+ unwrap_response_resume,
56
+ unwrap_stream_response_resume,
57
+ wrap_async_context_response_resume,
58
+ wrap_async_context_stream_response_resume,
59
+ wrap_async_response_resume,
60
+ wrap_async_stream_response_resume,
61
+ wrap_context_response_resume,
62
+ wrap_context_stream_response_resume,
63
+ wrap_response_resume,
64
+ wrap_stream_response_resume,
65
+ )
66
+
67
+
68
+ def instrument_llm() -> None:
69
+ """Enable GenAI 1.38 span emission for future `llm.Model` calls and streams.
70
+
71
+ Uses the tracer provider configured via `ops.configure()`. If no provider
72
+ was configured, uses the global OpenTelemetry tracer provider.
73
+
74
+ Example:
75
+
76
+ Enable instrumentation with a custom provider:
77
+ ```python
78
+ from mirascope import ops
79
+ from opentelemetry.sdk.trace import TracerProvider
80
+
81
+ provider = TracerProvider()
82
+ ops.configure(tracer_provider=provider)
83
+ ops.instrument_llm()
84
+ ```
85
+ """
86
+ if otel_trace is None: # pragma: no cover
87
+ raise ImportError(
88
+ "OpenTelemetry is not installed. Run `pip install mirascope[otel]` "
89
+ "and ensure `opentelemetry-api` is available before calling "
90
+ "`instrument_llm`."
91
+ )
92
+
93
+ os.environ.setdefault("OTEL_SEMCONV_STABILITY_OPT_IN", "gen_ai_latest_experimental")
94
+
95
+ if get_tracer() is None: # pragma: no cover
96
+ raise RuntimeError(
97
+ "You must call `configure()` before calling `instrument_llm()`."
98
+ )
99
+
100
+ # Model call methods
101
+ wrap_model_call()
102
+ wrap_model_call_async()
103
+ wrap_model_context_call()
104
+ wrap_model_context_call_async()
105
+ wrap_model_stream()
106
+ wrap_model_stream_async()
107
+ wrap_model_context_stream()
108
+ wrap_model_context_stream_async()
109
+
110
+ # Model resume methods
111
+ wrap_model_resume()
112
+ wrap_model_resume_async()
113
+ wrap_model_context_resume()
114
+ wrap_model_context_resume_async()
115
+ wrap_model_resume_stream()
116
+ wrap_model_resume_stream_async()
117
+ wrap_model_context_resume_stream()
118
+ wrap_model_context_resume_stream_async()
119
+
120
+ # Response resume methods (Mirascope-specific spans)
121
+ wrap_response_resume()
122
+ wrap_async_response_resume()
123
+ wrap_context_response_resume()
124
+ wrap_async_context_response_resume()
125
+ wrap_stream_response_resume()
126
+ wrap_async_stream_response_resume()
127
+ wrap_context_stream_response_resume()
128
+ wrap_async_context_stream_response_resume()
129
+
130
+
131
+ def uninstrument_llm() -> None:
132
+ """Disable previously configured instrumentation."""
133
+ # Model call methods
134
+ unwrap_model_call()
135
+ unwrap_model_call_async()
136
+ unwrap_model_context_call()
137
+ unwrap_model_context_call_async()
138
+ unwrap_model_stream()
139
+ unwrap_model_stream_async()
140
+ unwrap_model_context_stream()
141
+ unwrap_model_context_stream_async()
142
+
143
+ # Model resume methods
144
+ unwrap_model_resume()
145
+ unwrap_model_resume_async()
146
+ unwrap_model_context_resume()
147
+ unwrap_model_context_resume_async()
148
+ unwrap_model_resume_stream()
149
+ unwrap_model_resume_stream_async()
150
+ unwrap_model_context_resume_stream()
151
+ unwrap_model_context_resume_stream_async()
152
+
153
+ # Response resume methods (Mirascope-specific spans)
154
+ unwrap_response_resume()
155
+ unwrap_async_response_resume()
156
+ unwrap_context_response_resume()
157
+ unwrap_async_context_response_resume()
158
+ unwrap_stream_response_resume()
159
+ unwrap_async_stream_response_resume()
160
+ unwrap_context_stream_response_resume()
161
+ unwrap_async_context_stream_response_resume()