aiqtoolkit 1.2.0rc4__py3-none-any.whl → 1.2rc9__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.

Potentially problematic release.


This version of aiqtoolkit might be problematic. Click here for more details.

Files changed (441) hide show
  1. aiqtoolkit-1.2rc9.dist-info/METADATA +29 -0
  2. aiqtoolkit-1.2rc9.dist-info/RECORD +4 -0
  3. aiqtoolkit-1.2rc9.dist-info/top_level.txt +1 -0
  4. aiq/agent/__init__.py +0 -0
  5. aiq/agent/base.py +0 -239
  6. aiq/agent/dual_node.py +0 -67
  7. aiq/agent/react_agent/__init__.py +0 -0
  8. aiq/agent/react_agent/agent.py +0 -355
  9. aiq/agent/react_agent/output_parser.py +0 -104
  10. aiq/agent/react_agent/prompt.py +0 -41
  11. aiq/agent/react_agent/register.py +0 -149
  12. aiq/agent/reasoning_agent/__init__.py +0 -0
  13. aiq/agent/reasoning_agent/reasoning_agent.py +0 -225
  14. aiq/agent/register.py +0 -23
  15. aiq/agent/rewoo_agent/__init__.py +0 -0
  16. aiq/agent/rewoo_agent/agent.py +0 -411
  17. aiq/agent/rewoo_agent/prompt.py +0 -108
  18. aiq/agent/rewoo_agent/register.py +0 -158
  19. aiq/agent/tool_calling_agent/__init__.py +0 -0
  20. aiq/agent/tool_calling_agent/agent.py +0 -119
  21. aiq/agent/tool_calling_agent/register.py +0 -106
  22. aiq/authentication/__init__.py +0 -14
  23. aiq/authentication/api_key/__init__.py +0 -14
  24. aiq/authentication/api_key/api_key_auth_provider.py +0 -96
  25. aiq/authentication/api_key/api_key_auth_provider_config.py +0 -124
  26. aiq/authentication/api_key/register.py +0 -26
  27. aiq/authentication/exceptions/__init__.py +0 -14
  28. aiq/authentication/exceptions/api_key_exceptions.py +0 -38
  29. aiq/authentication/exceptions/auth_code_grant_exceptions.py +0 -86
  30. aiq/authentication/exceptions/call_back_exceptions.py +0 -38
  31. aiq/authentication/exceptions/request_exceptions.py +0 -54
  32. aiq/authentication/http_basic_auth/__init__.py +0 -0
  33. aiq/authentication/http_basic_auth/http_basic_auth_provider.py +0 -81
  34. aiq/authentication/http_basic_auth/register.py +0 -30
  35. aiq/authentication/interfaces.py +0 -93
  36. aiq/authentication/oauth2/__init__.py +0 -14
  37. aiq/authentication/oauth2/oauth2_auth_code_flow_provider.py +0 -107
  38. aiq/authentication/oauth2/oauth2_auth_code_flow_provider_config.py +0 -39
  39. aiq/authentication/oauth2/register.py +0 -25
  40. aiq/authentication/register.py +0 -21
  41. aiq/builder/__init__.py +0 -0
  42. aiq/builder/builder.py +0 -285
  43. aiq/builder/component_utils.py +0 -316
  44. aiq/builder/context.py +0 -264
  45. aiq/builder/embedder.py +0 -24
  46. aiq/builder/eval_builder.py +0 -161
  47. aiq/builder/evaluator.py +0 -29
  48. aiq/builder/framework_enum.py +0 -24
  49. aiq/builder/front_end.py +0 -73
  50. aiq/builder/function.py +0 -344
  51. aiq/builder/function_base.py +0 -380
  52. aiq/builder/function_info.py +0 -627
  53. aiq/builder/intermediate_step_manager.py +0 -174
  54. aiq/builder/llm.py +0 -25
  55. aiq/builder/retriever.py +0 -25
  56. aiq/builder/user_interaction_manager.py +0 -74
  57. aiq/builder/workflow.py +0 -148
  58. aiq/builder/workflow_builder.py +0 -1117
  59. aiq/cli/__init__.py +0 -14
  60. aiq/cli/cli_utils/__init__.py +0 -0
  61. aiq/cli/cli_utils/config_override.py +0 -231
  62. aiq/cli/cli_utils/validation.py +0 -37
  63. aiq/cli/commands/__init__.py +0 -0
  64. aiq/cli/commands/configure/__init__.py +0 -0
  65. aiq/cli/commands/configure/channel/__init__.py +0 -0
  66. aiq/cli/commands/configure/channel/add.py +0 -28
  67. aiq/cli/commands/configure/channel/channel.py +0 -36
  68. aiq/cli/commands/configure/channel/remove.py +0 -30
  69. aiq/cli/commands/configure/channel/update.py +0 -30
  70. aiq/cli/commands/configure/configure.py +0 -33
  71. aiq/cli/commands/evaluate.py +0 -139
  72. aiq/cli/commands/info/__init__.py +0 -14
  73. aiq/cli/commands/info/info.py +0 -39
  74. aiq/cli/commands/info/list_channels.py +0 -32
  75. aiq/cli/commands/info/list_components.py +0 -129
  76. aiq/cli/commands/info/list_mcp.py +0 -213
  77. aiq/cli/commands/registry/__init__.py +0 -14
  78. aiq/cli/commands/registry/publish.py +0 -88
  79. aiq/cli/commands/registry/pull.py +0 -118
  80. aiq/cli/commands/registry/registry.py +0 -38
  81. aiq/cli/commands/registry/remove.py +0 -108
  82. aiq/cli/commands/registry/search.py +0 -155
  83. aiq/cli/commands/sizing/__init__.py +0 -14
  84. aiq/cli/commands/sizing/calc.py +0 -297
  85. aiq/cli/commands/sizing/sizing.py +0 -27
  86. aiq/cli/commands/start.py +0 -246
  87. aiq/cli/commands/uninstall.py +0 -81
  88. aiq/cli/commands/validate.py +0 -47
  89. aiq/cli/commands/workflow/__init__.py +0 -14
  90. aiq/cli/commands/workflow/templates/__init__.py.j2 +0 -0
  91. aiq/cli/commands/workflow/templates/config.yml.j2 +0 -16
  92. aiq/cli/commands/workflow/templates/pyproject.toml.j2 +0 -22
  93. aiq/cli/commands/workflow/templates/register.py.j2 +0 -5
  94. aiq/cli/commands/workflow/templates/workflow.py.j2 +0 -36
  95. aiq/cli/commands/workflow/workflow.py +0 -37
  96. aiq/cli/commands/workflow/workflow_commands.py +0 -313
  97. aiq/cli/entrypoint.py +0 -135
  98. aiq/cli/main.py +0 -44
  99. aiq/cli/register_workflow.py +0 -488
  100. aiq/cli/type_registry.py +0 -1000
  101. aiq/data_models/__init__.py +0 -14
  102. aiq/data_models/api_server.py +0 -694
  103. aiq/data_models/authentication.py +0 -231
  104. aiq/data_models/common.py +0 -171
  105. aiq/data_models/component.py +0 -54
  106. aiq/data_models/component_ref.py +0 -168
  107. aiq/data_models/config.py +0 -406
  108. aiq/data_models/dataset_handler.py +0 -123
  109. aiq/data_models/discovery_metadata.py +0 -335
  110. aiq/data_models/embedder.py +0 -27
  111. aiq/data_models/evaluate.py +0 -127
  112. aiq/data_models/evaluator.py +0 -26
  113. aiq/data_models/front_end.py +0 -26
  114. aiq/data_models/function.py +0 -30
  115. aiq/data_models/function_dependencies.py +0 -72
  116. aiq/data_models/interactive.py +0 -246
  117. aiq/data_models/intermediate_step.py +0 -302
  118. aiq/data_models/invocation_node.py +0 -38
  119. aiq/data_models/its_strategy.py +0 -30
  120. aiq/data_models/llm.py +0 -27
  121. aiq/data_models/logging.py +0 -26
  122. aiq/data_models/memory.py +0 -27
  123. aiq/data_models/object_store.py +0 -44
  124. aiq/data_models/profiler.py +0 -54
  125. aiq/data_models/registry_handler.py +0 -26
  126. aiq/data_models/retriever.py +0 -30
  127. aiq/data_models/retry_mixin.py +0 -35
  128. aiq/data_models/span.py +0 -187
  129. aiq/data_models/step_adaptor.py +0 -64
  130. aiq/data_models/streaming.py +0 -33
  131. aiq/data_models/swe_bench_model.py +0 -54
  132. aiq/data_models/telemetry_exporter.py +0 -26
  133. aiq/embedder/__init__.py +0 -0
  134. aiq/embedder/langchain_client.py +0 -41
  135. aiq/embedder/nim_embedder.py +0 -59
  136. aiq/embedder/openai_embedder.py +0 -43
  137. aiq/embedder/register.py +0 -24
  138. aiq/eval/__init__.py +0 -14
  139. aiq/eval/config.py +0 -60
  140. aiq/eval/dataset_handler/__init__.py +0 -0
  141. aiq/eval/dataset_handler/dataset_downloader.py +0 -106
  142. aiq/eval/dataset_handler/dataset_filter.py +0 -52
  143. aiq/eval/dataset_handler/dataset_handler.py +0 -254
  144. aiq/eval/evaluate.py +0 -506
  145. aiq/eval/evaluator/__init__.py +0 -14
  146. aiq/eval/evaluator/base_evaluator.py +0 -73
  147. aiq/eval/evaluator/evaluator_model.py +0 -45
  148. aiq/eval/intermediate_step_adapter.py +0 -99
  149. aiq/eval/rag_evaluator/__init__.py +0 -0
  150. aiq/eval/rag_evaluator/evaluate.py +0 -178
  151. aiq/eval/rag_evaluator/register.py +0 -143
  152. aiq/eval/register.py +0 -23
  153. aiq/eval/remote_workflow.py +0 -133
  154. aiq/eval/runners/__init__.py +0 -14
  155. aiq/eval/runners/config.py +0 -39
  156. aiq/eval/runners/multi_eval_runner.py +0 -54
  157. aiq/eval/runtime_event_subscriber.py +0 -52
  158. aiq/eval/swe_bench_evaluator/__init__.py +0 -0
  159. aiq/eval/swe_bench_evaluator/evaluate.py +0 -215
  160. aiq/eval/swe_bench_evaluator/register.py +0 -36
  161. aiq/eval/trajectory_evaluator/__init__.py +0 -0
  162. aiq/eval/trajectory_evaluator/evaluate.py +0 -75
  163. aiq/eval/trajectory_evaluator/register.py +0 -40
  164. aiq/eval/tunable_rag_evaluator/__init__.py +0 -0
  165. aiq/eval/tunable_rag_evaluator/evaluate.py +0 -245
  166. aiq/eval/tunable_rag_evaluator/register.py +0 -52
  167. aiq/eval/usage_stats.py +0 -41
  168. aiq/eval/utils/__init__.py +0 -0
  169. aiq/eval/utils/output_uploader.py +0 -140
  170. aiq/eval/utils/tqdm_position_registry.py +0 -40
  171. aiq/eval/utils/weave_eval.py +0 -184
  172. aiq/experimental/__init__.py +0 -0
  173. aiq/experimental/decorators/__init__.py +0 -0
  174. aiq/experimental/decorators/experimental_warning_decorator.py +0 -130
  175. aiq/experimental/inference_time_scaling/__init__.py +0 -0
  176. aiq/experimental/inference_time_scaling/editing/__init__.py +0 -0
  177. aiq/experimental/inference_time_scaling/editing/iterative_plan_refinement_editor.py +0 -147
  178. aiq/experimental/inference_time_scaling/editing/llm_as_a_judge_editor.py +0 -204
  179. aiq/experimental/inference_time_scaling/editing/motivation_aware_summarization.py +0 -107
  180. aiq/experimental/inference_time_scaling/functions/__init__.py +0 -0
  181. aiq/experimental/inference_time_scaling/functions/execute_score_select_function.py +0 -105
  182. aiq/experimental/inference_time_scaling/functions/its_tool_orchestration_function.py +0 -205
  183. aiq/experimental/inference_time_scaling/functions/its_tool_wrapper_function.py +0 -146
  184. aiq/experimental/inference_time_scaling/functions/plan_select_execute_function.py +0 -224
  185. aiq/experimental/inference_time_scaling/models/__init__.py +0 -0
  186. aiq/experimental/inference_time_scaling/models/editor_config.py +0 -132
  187. aiq/experimental/inference_time_scaling/models/its_item.py +0 -48
  188. aiq/experimental/inference_time_scaling/models/scoring_config.py +0 -112
  189. aiq/experimental/inference_time_scaling/models/search_config.py +0 -120
  190. aiq/experimental/inference_time_scaling/models/selection_config.py +0 -154
  191. aiq/experimental/inference_time_scaling/models/stage_enums.py +0 -43
  192. aiq/experimental/inference_time_scaling/models/strategy_base.py +0 -66
  193. aiq/experimental/inference_time_scaling/models/tool_use_config.py +0 -41
  194. aiq/experimental/inference_time_scaling/register.py +0 -36
  195. aiq/experimental/inference_time_scaling/scoring/__init__.py +0 -0
  196. aiq/experimental/inference_time_scaling/scoring/llm_based_agent_scorer.py +0 -168
  197. aiq/experimental/inference_time_scaling/scoring/llm_based_plan_scorer.py +0 -168
  198. aiq/experimental/inference_time_scaling/scoring/motivation_aware_scorer.py +0 -111
  199. aiq/experimental/inference_time_scaling/search/__init__.py +0 -0
  200. aiq/experimental/inference_time_scaling/search/multi_llm_planner.py +0 -128
  201. aiq/experimental/inference_time_scaling/search/multi_query_retrieval_search.py +0 -122
  202. aiq/experimental/inference_time_scaling/search/single_shot_multi_plan_planner.py +0 -128
  203. aiq/experimental/inference_time_scaling/selection/__init__.py +0 -0
  204. aiq/experimental/inference_time_scaling/selection/best_of_n_selector.py +0 -63
  205. aiq/experimental/inference_time_scaling/selection/llm_based_agent_output_selector.py +0 -131
  206. aiq/experimental/inference_time_scaling/selection/llm_based_output_merging_selector.py +0 -159
  207. aiq/experimental/inference_time_scaling/selection/llm_based_plan_selector.py +0 -128
  208. aiq/experimental/inference_time_scaling/selection/threshold_selector.py +0 -58
  209. aiq/front_ends/__init__.py +0 -14
  210. aiq/front_ends/console/__init__.py +0 -14
  211. aiq/front_ends/console/authentication_flow_handler.py +0 -233
  212. aiq/front_ends/console/console_front_end_config.py +0 -32
  213. aiq/front_ends/console/console_front_end_plugin.py +0 -96
  214. aiq/front_ends/console/register.py +0 -25
  215. aiq/front_ends/cron/__init__.py +0 -14
  216. aiq/front_ends/fastapi/__init__.py +0 -14
  217. aiq/front_ends/fastapi/auth_flow_handlers/__init__.py +0 -0
  218. aiq/front_ends/fastapi/auth_flow_handlers/http_flow_handler.py +0 -27
  219. aiq/front_ends/fastapi/auth_flow_handlers/websocket_flow_handler.py +0 -107
  220. aiq/front_ends/fastapi/fastapi_front_end_config.py +0 -234
  221. aiq/front_ends/fastapi/fastapi_front_end_controller.py +0 -68
  222. aiq/front_ends/fastapi/fastapi_front_end_plugin.py +0 -116
  223. aiq/front_ends/fastapi/fastapi_front_end_plugin_worker.py +0 -1092
  224. aiq/front_ends/fastapi/html_snippets/__init__.py +0 -14
  225. aiq/front_ends/fastapi/html_snippets/auth_code_grant_success.py +0 -35
  226. aiq/front_ends/fastapi/intermediate_steps_subscriber.py +0 -80
  227. aiq/front_ends/fastapi/job_store.py +0 -183
  228. aiq/front_ends/fastapi/main.py +0 -72
  229. aiq/front_ends/fastapi/message_handler.py +0 -298
  230. aiq/front_ends/fastapi/message_validator.py +0 -345
  231. aiq/front_ends/fastapi/register.py +0 -25
  232. aiq/front_ends/fastapi/response_helpers.py +0 -195
  233. aiq/front_ends/fastapi/step_adaptor.py +0 -321
  234. aiq/front_ends/mcp/__init__.py +0 -14
  235. aiq/front_ends/mcp/mcp_front_end_config.py +0 -32
  236. aiq/front_ends/mcp/mcp_front_end_plugin.py +0 -93
  237. aiq/front_ends/mcp/register.py +0 -27
  238. aiq/front_ends/mcp/tool_converter.py +0 -242
  239. aiq/front_ends/register.py +0 -22
  240. aiq/front_ends/simple_base/__init__.py +0 -14
  241. aiq/front_ends/simple_base/simple_front_end_plugin_base.py +0 -54
  242. aiq/llm/__init__.py +0 -0
  243. aiq/llm/aws_bedrock_llm.py +0 -57
  244. aiq/llm/nim_llm.py +0 -46
  245. aiq/llm/openai_llm.py +0 -46
  246. aiq/llm/register.py +0 -23
  247. aiq/llm/utils/__init__.py +0 -14
  248. aiq/llm/utils/env_config_value.py +0 -94
  249. aiq/llm/utils/error.py +0 -17
  250. aiq/memory/__init__.py +0 -20
  251. aiq/memory/interfaces.py +0 -183
  252. aiq/memory/models.py +0 -112
  253. aiq/meta/module_to_distro.json +0 -3
  254. aiq/meta/pypi.md +0 -58
  255. aiq/object_store/__init__.py +0 -20
  256. aiq/object_store/in_memory_object_store.py +0 -76
  257. aiq/object_store/interfaces.py +0 -84
  258. aiq/object_store/models.py +0 -36
  259. aiq/object_store/register.py +0 -20
  260. aiq/observability/__init__.py +0 -14
  261. aiq/observability/exporter/__init__.py +0 -14
  262. aiq/observability/exporter/base_exporter.py +0 -449
  263. aiq/observability/exporter/exporter.py +0 -78
  264. aiq/observability/exporter/file_exporter.py +0 -33
  265. aiq/observability/exporter/processing_exporter.py +0 -322
  266. aiq/observability/exporter/raw_exporter.py +0 -52
  267. aiq/observability/exporter/span_exporter.py +0 -265
  268. aiq/observability/exporter_manager.py +0 -335
  269. aiq/observability/mixin/__init__.py +0 -14
  270. aiq/observability/mixin/batch_config_mixin.py +0 -26
  271. aiq/observability/mixin/collector_config_mixin.py +0 -23
  272. aiq/observability/mixin/file_mixin.py +0 -288
  273. aiq/observability/mixin/file_mode.py +0 -23
  274. aiq/observability/mixin/resource_conflict_mixin.py +0 -134
  275. aiq/observability/mixin/serialize_mixin.py +0 -61
  276. aiq/observability/mixin/type_introspection_mixin.py +0 -183
  277. aiq/observability/processor/__init__.py +0 -14
  278. aiq/observability/processor/batching_processor.py +0 -309
  279. aiq/observability/processor/callback_processor.py +0 -42
  280. aiq/observability/processor/intermediate_step_serializer.py +0 -28
  281. aiq/observability/processor/processor.py +0 -71
  282. aiq/observability/register.py +0 -96
  283. aiq/observability/utils/__init__.py +0 -14
  284. aiq/observability/utils/dict_utils.py +0 -236
  285. aiq/observability/utils/time_utils.py +0 -31
  286. aiq/plugins/.namespace +0 -1
  287. aiq/profiler/__init__.py +0 -0
  288. aiq/profiler/calc/__init__.py +0 -14
  289. aiq/profiler/calc/calc_runner.py +0 -627
  290. aiq/profiler/calc/calculations.py +0 -288
  291. aiq/profiler/calc/data_models.py +0 -188
  292. aiq/profiler/calc/plot.py +0 -345
  293. aiq/profiler/callbacks/__init__.py +0 -0
  294. aiq/profiler/callbacks/agno_callback_handler.py +0 -295
  295. aiq/profiler/callbacks/base_callback_class.py +0 -20
  296. aiq/profiler/callbacks/langchain_callback_handler.py +0 -290
  297. aiq/profiler/callbacks/llama_index_callback_handler.py +0 -205
  298. aiq/profiler/callbacks/semantic_kernel_callback_handler.py +0 -238
  299. aiq/profiler/callbacks/token_usage_base_model.py +0 -27
  300. aiq/profiler/data_frame_row.py +0 -51
  301. aiq/profiler/data_models.py +0 -24
  302. aiq/profiler/decorators/__init__.py +0 -0
  303. aiq/profiler/decorators/framework_wrapper.py +0 -131
  304. aiq/profiler/decorators/function_tracking.py +0 -254
  305. aiq/profiler/forecasting/__init__.py +0 -0
  306. aiq/profiler/forecasting/config.py +0 -18
  307. aiq/profiler/forecasting/model_trainer.py +0 -75
  308. aiq/profiler/forecasting/models/__init__.py +0 -22
  309. aiq/profiler/forecasting/models/forecasting_base_model.py +0 -40
  310. aiq/profiler/forecasting/models/linear_model.py +0 -196
  311. aiq/profiler/forecasting/models/random_forest_regressor.py +0 -268
  312. aiq/profiler/inference_metrics_model.py +0 -28
  313. aiq/profiler/inference_optimization/__init__.py +0 -0
  314. aiq/profiler/inference_optimization/bottleneck_analysis/__init__.py +0 -0
  315. aiq/profiler/inference_optimization/bottleneck_analysis/nested_stack_analysis.py +0 -460
  316. aiq/profiler/inference_optimization/bottleneck_analysis/simple_stack_analysis.py +0 -258
  317. aiq/profiler/inference_optimization/data_models.py +0 -386
  318. aiq/profiler/inference_optimization/experimental/__init__.py +0 -0
  319. aiq/profiler/inference_optimization/experimental/concurrency_spike_analysis.py +0 -468
  320. aiq/profiler/inference_optimization/experimental/prefix_span_analysis.py +0 -405
  321. aiq/profiler/inference_optimization/llm_metrics.py +0 -212
  322. aiq/profiler/inference_optimization/prompt_caching.py +0 -163
  323. aiq/profiler/inference_optimization/token_uniqueness.py +0 -107
  324. aiq/profiler/inference_optimization/workflow_runtimes.py +0 -72
  325. aiq/profiler/intermediate_property_adapter.py +0 -102
  326. aiq/profiler/profile_runner.py +0 -473
  327. aiq/profiler/utils.py +0 -184
  328. aiq/registry_handlers/__init__.py +0 -0
  329. aiq/registry_handlers/local/__init__.py +0 -0
  330. aiq/registry_handlers/local/local_handler.py +0 -176
  331. aiq/registry_handlers/local/register_local.py +0 -37
  332. aiq/registry_handlers/metadata_factory.py +0 -60
  333. aiq/registry_handlers/package_utils.py +0 -567
  334. aiq/registry_handlers/pypi/__init__.py +0 -0
  335. aiq/registry_handlers/pypi/pypi_handler.py +0 -251
  336. aiq/registry_handlers/pypi/register_pypi.py +0 -40
  337. aiq/registry_handlers/register.py +0 -21
  338. aiq/registry_handlers/registry_handler_base.py +0 -157
  339. aiq/registry_handlers/rest/__init__.py +0 -0
  340. aiq/registry_handlers/rest/register_rest.py +0 -56
  341. aiq/registry_handlers/rest/rest_handler.py +0 -237
  342. aiq/registry_handlers/schemas/__init__.py +0 -0
  343. aiq/registry_handlers/schemas/headers.py +0 -42
  344. aiq/registry_handlers/schemas/package.py +0 -68
  345. aiq/registry_handlers/schemas/publish.py +0 -63
  346. aiq/registry_handlers/schemas/pull.py +0 -82
  347. aiq/registry_handlers/schemas/remove.py +0 -36
  348. aiq/registry_handlers/schemas/search.py +0 -91
  349. aiq/registry_handlers/schemas/status.py +0 -47
  350. aiq/retriever/__init__.py +0 -0
  351. aiq/retriever/interface.py +0 -37
  352. aiq/retriever/milvus/__init__.py +0 -14
  353. aiq/retriever/milvus/register.py +0 -81
  354. aiq/retriever/milvus/retriever.py +0 -228
  355. aiq/retriever/models.py +0 -74
  356. aiq/retriever/nemo_retriever/__init__.py +0 -14
  357. aiq/retriever/nemo_retriever/register.py +0 -60
  358. aiq/retriever/nemo_retriever/retriever.py +0 -190
  359. aiq/retriever/register.py +0 -22
  360. aiq/runtime/__init__.py +0 -14
  361. aiq/runtime/loader.py +0 -215
  362. aiq/runtime/runner.py +0 -190
  363. aiq/runtime/session.py +0 -158
  364. aiq/runtime/user_metadata.py +0 -130
  365. aiq/settings/__init__.py +0 -0
  366. aiq/settings/global_settings.py +0 -318
  367. aiq/test/.namespace +0 -1
  368. aiq/tool/__init__.py +0 -0
  369. aiq/tool/chat_completion.py +0 -74
  370. aiq/tool/code_execution/README.md +0 -151
  371. aiq/tool/code_execution/__init__.py +0 -0
  372. aiq/tool/code_execution/code_sandbox.py +0 -267
  373. aiq/tool/code_execution/local_sandbox/.gitignore +0 -1
  374. aiq/tool/code_execution/local_sandbox/Dockerfile.sandbox +0 -60
  375. aiq/tool/code_execution/local_sandbox/__init__.py +0 -13
  376. aiq/tool/code_execution/local_sandbox/local_sandbox_server.py +0 -198
  377. aiq/tool/code_execution/local_sandbox/sandbox.requirements.txt +0 -6
  378. aiq/tool/code_execution/local_sandbox/start_local_sandbox.sh +0 -50
  379. aiq/tool/code_execution/register.py +0 -74
  380. aiq/tool/code_execution/test_code_execution_sandbox.py +0 -414
  381. aiq/tool/code_execution/utils.py +0 -100
  382. aiq/tool/datetime_tools.py +0 -42
  383. aiq/tool/document_search.py +0 -141
  384. aiq/tool/github_tools/__init__.py +0 -0
  385. aiq/tool/github_tools/create_github_commit.py +0 -133
  386. aiq/tool/github_tools/create_github_issue.py +0 -87
  387. aiq/tool/github_tools/create_github_pr.py +0 -106
  388. aiq/tool/github_tools/get_github_file.py +0 -106
  389. aiq/tool/github_tools/get_github_issue.py +0 -166
  390. aiq/tool/github_tools/get_github_pr.py +0 -256
  391. aiq/tool/github_tools/update_github_issue.py +0 -100
  392. aiq/tool/mcp/__init__.py +0 -14
  393. aiq/tool/mcp/exceptions.py +0 -142
  394. aiq/tool/mcp/mcp_client.py +0 -255
  395. aiq/tool/mcp/mcp_tool.py +0 -96
  396. aiq/tool/memory_tools/__init__.py +0 -0
  397. aiq/tool/memory_tools/add_memory_tool.py +0 -79
  398. aiq/tool/memory_tools/delete_memory_tool.py +0 -67
  399. aiq/tool/memory_tools/get_memory_tool.py +0 -72
  400. aiq/tool/nvidia_rag.py +0 -95
  401. aiq/tool/register.py +0 -38
  402. aiq/tool/retriever.py +0 -89
  403. aiq/tool/server_tools.py +0 -66
  404. aiq/utils/__init__.py +0 -0
  405. aiq/utils/data_models/__init__.py +0 -0
  406. aiq/utils/data_models/schema_validator.py +0 -58
  407. aiq/utils/debugging_utils.py +0 -43
  408. aiq/utils/dump_distro_mapping.py +0 -32
  409. aiq/utils/exception_handlers/__init__.py +0 -0
  410. aiq/utils/exception_handlers/automatic_retries.py +0 -289
  411. aiq/utils/exception_handlers/mcp.py +0 -211
  412. aiq/utils/exception_handlers/schemas.py +0 -114
  413. aiq/utils/io/__init__.py +0 -0
  414. aiq/utils/io/model_processing.py +0 -28
  415. aiq/utils/io/yaml_tools.py +0 -119
  416. aiq/utils/log_utils.py +0 -37
  417. aiq/utils/metadata_utils.py +0 -74
  418. aiq/utils/optional_imports.py +0 -142
  419. aiq/utils/producer_consumer_queue.py +0 -178
  420. aiq/utils/reactive/__init__.py +0 -0
  421. aiq/utils/reactive/base/__init__.py +0 -0
  422. aiq/utils/reactive/base/observable_base.py +0 -65
  423. aiq/utils/reactive/base/observer_base.py +0 -55
  424. aiq/utils/reactive/base/subject_base.py +0 -79
  425. aiq/utils/reactive/observable.py +0 -59
  426. aiq/utils/reactive/observer.py +0 -76
  427. aiq/utils/reactive/subject.py +0 -131
  428. aiq/utils/reactive/subscription.py +0 -49
  429. aiq/utils/settings/__init__.py +0 -0
  430. aiq/utils/settings/global_settings.py +0 -197
  431. aiq/utils/string_utils.py +0 -38
  432. aiq/utils/type_converter.py +0 -290
  433. aiq/utils/type_utils.py +0 -484
  434. aiq/utils/url_utils.py +0 -27
  435. aiqtoolkit-1.2.0rc4.dist-info/METADATA +0 -363
  436. aiqtoolkit-1.2.0rc4.dist-info/RECORD +0 -438
  437. aiqtoolkit-1.2.0rc4.dist-info/entry_points.txt +0 -20
  438. aiqtoolkit-1.2.0rc4.dist-info/licenses/LICENSE-3rd-party.txt +0 -3686
  439. aiqtoolkit-1.2.0rc4.dist-info/licenses/LICENSE.md +0 -201
  440. aiqtoolkit-1.2.0rc4.dist-info/top_level.txt +0 -1
  441. {aiqtoolkit-1.2.0rc4.dist-info → aiqtoolkit-1.2rc9.dist-info}/WHEEL +0 -0
@@ -1,316 +0,0 @@
1
- # SPDX-FileCopyrightText: Copyright (c) 2025, NVIDIA CORPORATION & AFFILIATES. All rights reserved.
2
- # SPDX-License-Identifier: Apache-2.0
3
- #
4
- # Licensed under the Apache License, Version 2.0 (the "License");
5
- # you may not use this file except in compliance with the License.
6
- # You may obtain a copy of the License at
7
- #
8
- # http://www.apache.org/licenses/LICENSE-2.0
9
- #
10
- # Unless required by applicable law or agreed to in writing, software
11
- # distributed under the License is distributed on an "AS IS" BASIS,
12
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
- # See the License for the specific language governing permissions and
14
- # limitations under the License.
15
-
16
- import logging
17
- import typing
18
- from collections.abc import Generator
19
- from collections.abc import Iterable
20
-
21
- import networkx as nx
22
- from pydantic import BaseModel
23
-
24
- from aiq.data_models.authentication import AuthProviderBaseConfig
25
- from aiq.data_models.common import TypedBaseModel
26
- from aiq.data_models.component import ComponentGroup
27
- from aiq.data_models.component_ref import ComponentRef
28
- from aiq.data_models.component_ref import ComponentRefNode
29
- from aiq.data_models.component_ref import generate_instance_id
30
- from aiq.data_models.config import AIQConfig
31
- from aiq.data_models.embedder import EmbedderBaseConfig
32
- from aiq.data_models.function import FunctionBaseConfig
33
- from aiq.data_models.its_strategy import ITSStrategyBaseConfig
34
- from aiq.data_models.llm import LLMBaseConfig
35
- from aiq.data_models.memory import MemoryBaseConfig
36
- from aiq.data_models.object_store import ObjectStoreBaseConfig
37
- from aiq.data_models.retriever import RetrieverBaseConfig
38
- from aiq.utils.type_utils import DecomposedType
39
-
40
- logger = logging.getLogger(__name__)
41
-
42
- # Order in which we want to process the component groups
43
- _component_group_order = [
44
- ComponentGroup.AUTHENTICATION,
45
- ComponentGroup.EMBEDDERS,
46
- ComponentGroup.LLMS,
47
- ComponentGroup.MEMORY,
48
- ComponentGroup.OBJECT_STORES,
49
- ComponentGroup.RETRIEVERS,
50
- ComponentGroup.ITS_STRATEGIES,
51
- ComponentGroup.FUNCTIONS,
52
- ]
53
-
54
-
55
- class ComponentInstanceData(BaseModel):
56
- """A data model to hold component runtime instance metadata to support generating build sequences.
57
-
58
- Args:
59
- component_group (ComponentGroup): The component group in an AIQ Toolkit configuration object.
60
- name (ComponentRef): The name of the component runtime instance.
61
- config (TypedBaseModel): The runtime instance's configuration object.
62
- instance_id (str): Unique identifier for each runtime instance.
63
- is_root (bool): A flag to indicate if the runtime instance is the root of the workflow.
64
- """
65
-
66
- component_group: ComponentGroup
67
- name: ComponentRef
68
- config: TypedBaseModel
69
- instance_id: str
70
- is_root: bool = False
71
-
72
-
73
- def iterate_leaf_to_root(graph: nx.DiGraph) -> Generator[ComponentRefNode]:
74
- """A recursive generator that yields leaf nodes from the bottom to the root of a directed graph.
75
-
76
- Args:
77
- graph (nx.DiGraph): A networkx directed graph object.
78
-
79
- Yields:
80
- ComponentRefNode: An object contain a ComponentRef and its component group.
81
- """
82
-
83
- leaf_nodes = [node for node, degree in graph.out_degree() if degree == 0]
84
-
85
- if len(leaf_nodes) > 0:
86
- for leaf_node in leaf_nodes:
87
- yield leaf_node
88
- graph.remove_node(leaf_node)
89
-
90
- yield from iterate_leaf_to_root(graph)
91
-
92
-
93
- def group_from_component(component: TypedBaseModel) -> ComponentGroup | None:
94
- """Determines the component group from a runtime instance configuration object.
95
-
96
- Args:
97
- component (TypedBaseModel): A runtime instance configuration object.
98
-
99
- Returns:
100
- ComponentGroup | None: The component group of the runtime instance configuration object. If the
101
- component is not a valid runtime instance, None is returned.
102
- """
103
-
104
- if (isinstance(component, AuthProviderBaseConfig)):
105
- return ComponentGroup.AUTHENTICATION
106
- if (isinstance(component, EmbedderBaseConfig)):
107
- return ComponentGroup.EMBEDDERS
108
- if (isinstance(component, FunctionBaseConfig)):
109
- return ComponentGroup.FUNCTIONS
110
- if (isinstance(component, LLMBaseConfig)):
111
- return ComponentGroup.LLMS
112
- if (isinstance(component, MemoryBaseConfig)):
113
- return ComponentGroup.MEMORY
114
- if (isinstance(component, ObjectStoreBaseConfig)):
115
- return ComponentGroup.OBJECT_STORES
116
- if (isinstance(component, RetrieverBaseConfig)):
117
- return ComponentGroup.RETRIEVERS
118
- if (isinstance(component, ITSStrategyBaseConfig)):
119
- return ComponentGroup.ITS_STRATEGIES
120
-
121
- return None
122
-
123
-
124
- def recursive_componentref_discovery(cls: TypedBaseModel, value: typing.Any,
125
- type_hint: type[typing.Any]) -> Generator[tuple[str, ComponentRefNode]]:
126
- """Discovers instances of ComponentRefs in a configuration object and updates the dependency graph.
127
-
128
- Args:
129
- cls (TypedBaseModel): A configuration object for a runtime instance.
130
- value (typing.Any): The current traversed value from the configuration object.
131
- type_hint (type[typing.Any]): The type of the current traversed value from the configuration object.
132
- """
133
-
134
- decomposed_type = DecomposedType(type_hint)
135
-
136
- if (value is None):
137
- return
138
-
139
- if ((decomposed_type.origin is None) and (not issubclass(type(value), BaseModel))):
140
- if issubclass(type(value), ComponentRef):
141
- instance_id = generate_instance_id(cls)
142
- value_node = ComponentRefNode(ref_name=value, component_group=value.component_group)
143
- yield instance_id, value_node
144
-
145
- elif ((decomposed_type.origin in (tuple, list, set)) and (isinstance(value, Iterable))):
146
- for v in value:
147
- yield from recursive_componentref_discovery(cls, v, decomposed_type.args[0])
148
- elif ((decomposed_type.origin in (dict, type(typing.TypedDict))) and (isinstance(value, dict))):
149
- for v in value.values():
150
- yield from recursive_componentref_discovery(cls, v, decomposed_type.args[1])
151
- elif (issubclass(type(value), BaseModel)):
152
- for field, field_info in value.model_fields.items():
153
- field_data = getattr(value, field)
154
- yield from recursive_componentref_discovery(cls, field_data, field_info.annotation)
155
- if (decomposed_type.is_union):
156
- for arg in decomposed_type.args:
157
- if arg is typing.Any or (isinstance(value, DecomposedType(arg).root)):
158
- yield from recursive_componentref_discovery(cls, value, arg)
159
- else:
160
- for arg in decomposed_type.args:
161
- yield from recursive_componentref_discovery(cls, value, arg)
162
-
163
-
164
- def update_dependency_graph(config: "AIQConfig", instance_config: TypedBaseModel,
165
- dependency_graph: nx.DiGraph) -> nx.DiGraph:
166
- """Updates the hierarchical component instance dependency graph from a configuration runtime instance.
167
-
168
- Args:
169
- config (AIQConfig): An AIQ Toolkit configuration object with runtime instance details.
170
- instance_config (TypedBaseModel): A component's runtime instance configuration object.
171
- dependency_graph (nx.DiGraph): A graph tracking runtime instance component dependencies.
172
-
173
- Returns:
174
- nx.DiGraph: An dependency graph that has been updated with the provided runtime instance.
175
- """
176
-
177
- for field_name, field_info in instance_config.model_fields.items():
178
-
179
- for instance_id, value_node in recursive_componentref_discovery(
180
- instance_config,
181
- getattr(instance_config, field_name),
182
- field_info.annotation): # type: ignore
183
-
184
- # add immediate edge
185
- dependency_graph.add_edge(instance_id, value_node)
186
- # add dependency edge to ensure connections to leaf nodes exist
187
- dependency_component_dict = getattr(config, value_node.component_group)
188
- dependency_component_instance_config = dependency_component_dict.get(value_node.ref_name)
189
- dependency_component_instance_id = generate_instance_id(dependency_component_instance_config)
190
- dependency_graph.add_edge(value_node, dependency_component_instance_id)
191
-
192
- return dependency_graph
193
-
194
-
195
- def config_to_dependency_objects(config: "AIQConfig") -> tuple[dict[str, ComponentInstanceData], nx.DiGraph]:
196
- """Generates a map of component runtime instance IDs to use when generating a build sequence.
197
-
198
- Args:
199
- config (AIQConfig): The AIQ Toolkit workflow configuration object.
200
-
201
- Returns:
202
- tuple[dict[str, ComponentInstanceData], nx.DiGraph]: A tuple containing a map of component runtime instance
203
- IDs to a component object containing its metadata and a dependency graph of nested components.
204
- """
205
-
206
- # Build map of every runtime instances
207
- dependency_map: dict[str, ComponentInstanceData] = {}
208
- dependency_graph: nx.DiGraph = nx.DiGraph()
209
-
210
- # Create the dependency map preserving as much order as we can
211
- for group in _component_group_order:
212
-
213
- component_dict = getattr(config, group.value)
214
-
215
- assert isinstance(component_dict, dict), "Config components must be a dictionary"
216
-
217
- for component_instance_name, component_instance_config in component_dict.items():
218
-
219
- instance_id = generate_instance_id(component_instance_config)
220
- dependency_map[instance_id] = ComponentInstanceData(component_group=group,
221
- instance_id=instance_id,
222
- name=component_instance_name,
223
- config=component_instance_config)
224
-
225
- dependency_graph = update_dependency_graph(config=config,
226
- instance_config=component_instance_config,
227
- dependency_graph=dependency_graph)
228
-
229
- # Set the workflow flag on the workflow instance (must be last)
230
- workflow_instance_id = generate_instance_id(config.workflow)
231
-
232
- dependency_map[workflow_instance_id] = ComponentInstanceData(
233
- component_group=ComponentGroup.FUNCTIONS,
234
- instance_id=workflow_instance_id,
235
- name="<workflow>", # type: ignore
236
- config=config.workflow,
237
- is_root=True)
238
-
239
- dependency_graph = update_dependency_graph(config=config,
240
- instance_config=config.workflow,
241
- dependency_graph=dependency_graph)
242
-
243
- return dependency_map, dependency_graph
244
-
245
-
246
- def build_dependency_sequence(config: "AIQConfig") -> list[ComponentInstanceData]:
247
- """Generates the depencency sequence from an AIQ Toolkit configuration object
248
-
249
- Args:
250
- config (AIQConfig): An AIQ Toolkit configuration object.
251
-
252
- Returns:
253
- list[ComponentInstanceData]: A list representing the instatiation sequence to ensure all valid
254
- runtime instance references.
255
- """
256
-
257
- total_node_count = len(config.embedders) + len(config.functions) + len(config.llms) + len(config.memory) + len(
258
- config.object_stores) + len(config.retrievers) + len(config.its_strategies) + len(
259
- config.authentication) + 1 # +1 for the workflow
260
-
261
- dependency_map: dict
262
- dependency_graph: nx.DiGraph
263
- dependency_map, dependency_graph = config_to_dependency_objects(config=config)
264
-
265
- dependency_sequence: list[ComponentInstanceData] = []
266
- instance_ids = set()
267
- for node in iterate_leaf_to_root(dependency_graph.copy()): # type: ignore
268
-
269
- if (node not in dependency_sequence):
270
-
271
- # Convert node to id
272
- if (isinstance(node, ComponentRefNode) and issubclass(type(node.ref_name), ComponentRef)):
273
-
274
- component_group_configs = getattr(config, node.component_group.value)
275
- node_config = component_group_configs.get(node.ref_name, None)
276
-
277
- # Only add nodes that are valid in the current instance configuration
278
- if (node_config is None):
279
- continue
280
-
281
- component_instance = ComponentInstanceData(
282
- name=node.ref_name,
283
- component_group=node.component_group.value, # type: ignore
284
- config=node_config,
285
- instance_id=generate_instance_id(node_config))
286
-
287
- else:
288
-
289
- component_instance = dependency_map.get(node, None)
290
-
291
- # Only add nodes that are valid in the current instance configuration
292
- if (component_instance is None):
293
- continue
294
-
295
- if (component_instance.instance_id not in instance_ids):
296
-
297
- dependency_sequence.append(component_instance)
298
- instance_ids.add(component_instance.instance_id)
299
-
300
- remaining_dependency_sequence: list[ComponentInstanceData] = []
301
-
302
- # Find the remaining nodes that are not in the sequence preserving order
303
- for instance_id, instance in dependency_map.items():
304
- if (instance_id not in instance_ids):
305
- remaining_dependency_sequence.append(instance)
306
-
307
- # Add the remaining at the front of the sequence
308
- dependency_sequence = remaining_dependency_sequence + dependency_sequence
309
-
310
- # Find the root node and make sure it is the last node in the sequence
311
- dependency_sequence = [x for x in dependency_sequence if not x.is_root
312
- ] + [x for x in dependency_sequence if x.is_root]
313
-
314
- assert len(dependency_sequence) == total_node_count, "Dependency sequence generation failed. Report as bug."
315
-
316
- return dependency_sequence
aiq/builder/context.py DELETED
@@ -1,264 +0,0 @@
1
- # SPDX-FileCopyrightText: Copyright (c) 2025, NVIDIA CORPORATION & AFFILIATES. All rights reserved.
2
- # SPDX-License-Identifier: Apache-2.0
3
- #
4
- # Licensed under the Apache License, Version 2.0 (the "License");
5
- # you may not use this file except in compliance with the License.
6
- # You may obtain a copy of the License at
7
- #
8
- # http://www.apache.org/licenses/LICENSE-2.0
9
- #
10
- # Unless required by applicable law or agreed to in writing, software
11
- # distributed under the License is distributed on an "AS IS" BASIS,
12
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
- # See the License for the specific language governing permissions and
14
- # limitations under the License.
15
-
16
- import typing
17
- import uuid
18
- from collections.abc import Awaitable
19
- from collections.abc import Callable
20
- from contextlib import contextmanager
21
- from contextvars import ContextVar
22
-
23
- from aiq.builder.intermediate_step_manager import IntermediateStepManager
24
- from aiq.builder.user_interaction_manager import AIQUserInteractionManager
25
- from aiq.data_models.authentication import AuthenticatedContext
26
- from aiq.data_models.authentication import AuthFlowType
27
- from aiq.data_models.authentication import AuthProviderBaseConfig
28
- from aiq.data_models.interactive import HumanResponse
29
- from aiq.data_models.interactive import InteractionPrompt
30
- from aiq.data_models.intermediate_step import IntermediateStep
31
- from aiq.data_models.intermediate_step import IntermediateStepPayload
32
- from aiq.data_models.intermediate_step import IntermediateStepType
33
- from aiq.data_models.intermediate_step import StreamEventData
34
- from aiq.data_models.invocation_node import InvocationNode
35
- from aiq.runtime.user_metadata import RequestAttributes
36
- from aiq.utils.reactive.subject import Subject
37
-
38
-
39
- class Singleton(type):
40
-
41
- def __init__(cls, name, bases, dict): # pylint: disable=W0622
42
- super(Singleton, cls).__init__(name, bases, dict)
43
- cls.instance = None
44
-
45
- def __call__(cls, *args, **kw):
46
- if cls.instance is None:
47
- cls.instance = super(Singleton, cls).__call__(*args, **kw)
48
- return cls.instance
49
-
50
-
51
- class ActiveFunctionContextManager:
52
-
53
- def __init__(self):
54
- self._output: typing.Any | None = None
55
-
56
- @property
57
- def output(self) -> typing.Any | None:
58
- return self._output
59
-
60
- def set_output(self, output: typing.Any):
61
- self._output = output
62
-
63
-
64
- class AIQContextState(metaclass=Singleton):
65
-
66
- def __init__(self):
67
- self.conversation_id: ContextVar[str | None] = ContextVar("conversation_id", default=None)
68
- self.input_message: ContextVar[typing.Any] = ContextVar("input_message", default=None)
69
- self.user_manager: ContextVar[typing.Any] = ContextVar("user_manager", default=None)
70
- self.metadata: ContextVar[RequestAttributes] = ContextVar("request_attributes", default=RequestAttributes())
71
- self.event_stream: ContextVar[Subject[IntermediateStep] | None] = ContextVar("event_stream", default=Subject())
72
- self.active_function: ContextVar[InvocationNode] = ContextVar("active_function",
73
- default=InvocationNode(function_id="root",
74
- function_name="root"))
75
- self.active_span_id_stack: ContextVar[list[str]] = ContextVar("active_span_id_stack", default=["root"])
76
-
77
- # Default is a lambda no-op which returns NoneType
78
- self.user_input_callback: ContextVar[Callable[[InteractionPrompt], Awaitable[HumanResponse | None]]
79
- | None] = ContextVar(
80
- "user_input_callback",
81
- default=AIQUserInteractionManager.default_callback_handler)
82
- self.user_auth_callback: ContextVar[Callable[[AuthProviderBaseConfig, AuthFlowType],
83
- Awaitable[AuthenticatedContext]]
84
- | None] = ContextVar("user_auth_callback", default=None)
85
-
86
- @staticmethod
87
- def get() -> "AIQContextState":
88
- return AIQContextState()
89
-
90
-
91
- class AIQContext:
92
-
93
- def __init__(self, context: AIQContextState):
94
- self._context_state = context
95
-
96
- @property
97
- def input_message(self):
98
- """
99
- Retrieves the input message from the context state.
100
-
101
- The input_message property is used to access the message stored in the
102
- context state. This property returns the message as it is currently
103
- maintained in the context.
104
-
105
- Returns:
106
- str: The input message retrieved from the context state.
107
- """
108
- return self._context_state.input_message.get()
109
-
110
- @property
111
- def user_manager(self):
112
- """
113
- Retrieves the user manager instance from the current context state.
114
-
115
- This property provides access to the user manager through the context
116
- state, allowing interaction with user management functionalities.
117
-
118
- Returns:
119
- UserManager: The instance of the user manager retrieved from the
120
- context state.
121
- """
122
- return self._context_state.user_manager.get()
123
-
124
- @property
125
- def metadata(self):
126
- """
127
- Retrieves the request attributes instance from the current context state
128
- providing access to user-defined metadata.
129
-
130
- Returns:
131
- RequestAttributes: The instance of the request attributes
132
- retrieved from the context state.
133
- """
134
- return self._context_state.metadata.get()
135
-
136
- @property
137
- def user_interaction_manager(self) -> AIQUserInteractionManager:
138
- """
139
- Return an instance of AIQUserInteractionManager that uses
140
- the current context's user_input_callback.
141
- """
142
- return AIQUserInteractionManager(self._context_state)
143
-
144
- @property
145
- def intermediate_step_manager(self) -> IntermediateStepManager:
146
- """
147
- Retrieves the intermediate step manager instance from the current context state.
148
-
149
- This property provides access to the intermediate step manager through the context
150
- state, allowing interaction with intermediate step management functionalities.
151
-
152
- Returns:
153
- IntermediateStepManager: The instance of the intermediate step manager retrieved
154
- from the context state.
155
- """
156
- return IntermediateStepManager(self._context_state)
157
-
158
- @property
159
- def conversation_id(self) -> str | None:
160
- """
161
- This property retrieves the conversation ID which is the unique identifier for the current chat conversation.
162
-
163
- Returns:
164
- str | None
165
- """
166
- return self._context_state.conversation_id.get()
167
-
168
- @contextmanager
169
- def push_active_function(self, function_name: str, input_data: typing.Any | None):
170
- """
171
- Set the 'active_function' in context, push an invocation node,
172
- AND create an OTel child span for that function call.
173
- """
174
- parent_function_node = self._context_state.active_function.get()
175
- current_function_id = str(uuid.uuid4())
176
- current_function_node = InvocationNode(function_id=current_function_id,
177
- function_name=function_name,
178
- parent_id=parent_function_node.function_id,
179
- parent_name=parent_function_node.function_name)
180
-
181
- # 1) Set the active function in the contextvar
182
- fn_token = self._context_state.active_function.set(current_function_node)
183
-
184
- # 2) Optionally record function start as an intermediate step
185
- step_manager = self.intermediate_step_manager
186
- step_manager.push_intermediate_step(
187
- IntermediateStepPayload(UUID=current_function_id,
188
- event_type=IntermediateStepType.FUNCTION_START,
189
- name=function_name,
190
- data=StreamEventData(input=input_data)))
191
-
192
- manager = ActiveFunctionContextManager()
193
-
194
- try:
195
- yield manager # run the function body
196
- finally:
197
- # 3) Record function end
198
-
199
- data = StreamEventData(input=input_data, output=manager.output)
200
-
201
- step_manager.push_intermediate_step(
202
- IntermediateStepPayload(UUID=current_function_id,
203
- event_type=IntermediateStepType.FUNCTION_END,
204
- name=function_name,
205
- data=data))
206
-
207
- # 4) Unset the function contextvar
208
- self._context_state.active_function.reset(fn_token)
209
-
210
- @property
211
- def active_function(self) -> InvocationNode:
212
- """
213
- Retrieves the active function from the context state.
214
-
215
- This property is used to access the active function stored in the context
216
- state. The active function is the function that is currently being executed.
217
- """
218
- return self._context_state.active_function.get()
219
-
220
- @property
221
- def active_span_id(self) -> str:
222
- """
223
- Retrieves the active span ID from the context state.
224
-
225
- This property provides access to the active span ID stored in the context state. The active span ID represents
226
- the currently running function/tool/llm/agent/etc and can be used to group telemetry data together.
227
-
228
- Returns:
229
- str: The active span ID.
230
- """
231
- return self._context_state.active_span_id_stack.get()[-1]
232
-
233
- @property
234
- def user_auth_callback(self) -> Callable[[AuthProviderBaseConfig, AuthFlowType], Awaitable[AuthenticatedContext]]:
235
- """
236
- Retrieves the user authentication callback function from the context state.
237
-
238
- This property provides access to the user authentication callback function stored in the context state.
239
- The callback function is responsible for handling user authentication based on the provided configuration.
240
-
241
- Returns:
242
- Callable[[AuthenticationBaseConfig], Awaitable[AuthenticatedContext]]: The user authentication
243
- callback function.
244
-
245
- Raises:
246
- RuntimeError: If the user authentication callback is not set in the context.
247
- """
248
- callback = self._context_state.user_auth_callback.get()
249
- if callback is None:
250
- raise RuntimeError("User authentication callback is not set in the context.")
251
- return callback
252
-
253
- @staticmethod
254
- def get() -> "AIQContext":
255
- """
256
- Static method to retrieve the current AIQContext instance.
257
-
258
- This method creates and returns an instance of the AIQContext class
259
- by obtaining the current state from the AIQContextState.
260
-
261
- Returns:
262
- AIQContext: The created AIQContext instance.
263
- """
264
- return AIQContext(AIQContextState.get())
aiq/builder/embedder.py DELETED
@@ -1,24 +0,0 @@
1
- # SPDX-FileCopyrightText: Copyright (c) 2025, NVIDIA CORPORATION & AFFILIATES. All rights reserved.
2
- # SPDX-License-Identifier: Apache-2.0
3
- #
4
- # Licensed under the Apache License, Version 2.0 (the "License");
5
- # you may not use this file except in compliance with the License.
6
- # You may obtain a copy of the License at
7
- #
8
- # http://www.apache.org/licenses/LICENSE-2.0
9
- #
10
- # Unless required by applicable law or agreed to in writing, software
11
- # distributed under the License is distributed on an "AS IS" BASIS,
12
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
- # See the License for the specific language governing permissions and
14
- # limitations under the License.
15
-
16
- from aiq.data_models.embedder import EmbedderBaseConfig
17
-
18
-
19
- class EmbedderProviderInfo:
20
-
21
- def __init__(self, *, config: EmbedderBaseConfig, description: str):
22
- self.config = config
23
- self.provider_type = type(config).static_type()
24
- self.description = description