aiqtoolkit 1.2.0rc3__py3-none-any.whl → 1.2.0rc5__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 (440) hide show
  1. aiqtoolkit-1.2.0rc5.dist-info/METADATA +29 -0
  2. aiqtoolkit-1.2.0rc5.dist-info/RECORD +4 -0
  3. aiqtoolkit-1.2.0rc5.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 -92
  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 -286
  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 -74
  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 -198
  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 -194
  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 -152
  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/exception_handlers/__init__.py +0 -0
  409. aiq/utils/exception_handlers/automatic_retries.py +0 -289
  410. aiq/utils/exception_handlers/mcp.py +0 -211
  411. aiq/utils/exception_handlers/schemas.py +0 -114
  412. aiq/utils/io/__init__.py +0 -0
  413. aiq/utils/io/model_processing.py +0 -28
  414. aiq/utils/io/yaml_tools.py +0 -119
  415. aiq/utils/log_utils.py +0 -37
  416. aiq/utils/metadata_utils.py +0 -74
  417. aiq/utils/optional_imports.py +0 -142
  418. aiq/utils/producer_consumer_queue.py +0 -178
  419. aiq/utils/reactive/__init__.py +0 -0
  420. aiq/utils/reactive/base/__init__.py +0 -0
  421. aiq/utils/reactive/base/observable_base.py +0 -65
  422. aiq/utils/reactive/base/observer_base.py +0 -55
  423. aiq/utils/reactive/base/subject_base.py +0 -79
  424. aiq/utils/reactive/observable.py +0 -59
  425. aiq/utils/reactive/observer.py +0 -76
  426. aiq/utils/reactive/subject.py +0 -131
  427. aiq/utils/reactive/subscription.py +0 -49
  428. aiq/utils/settings/__init__.py +0 -0
  429. aiq/utils/settings/global_settings.py +0 -197
  430. aiq/utils/string_utils.py +0 -38
  431. aiq/utils/type_converter.py +0 -290
  432. aiq/utils/type_utils.py +0 -484
  433. aiq/utils/url_utils.py +0 -27
  434. aiqtoolkit-1.2.0rc3.dist-info/METADATA +0 -363
  435. aiqtoolkit-1.2.0rc3.dist-info/RECORD +0 -437
  436. aiqtoolkit-1.2.0rc3.dist-info/entry_points.txt +0 -20
  437. aiqtoolkit-1.2.0rc3.dist-info/licenses/LICENSE-3rd-party.txt +0 -3686
  438. aiqtoolkit-1.2.0rc3.dist-info/licenses/LICENSE.md +0 -201
  439. aiqtoolkit-1.2.0rc3.dist-info/top_level.txt +0 -1
  440. {aiqtoolkit-1.2.0rc3.dist-info → aiqtoolkit-1.2.0rc5.dist-info}/WHEEL +0 -0
@@ -1,211 +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 ssl
18
- import sys
19
- from collections.abc import Callable
20
- from functools import wraps
21
- from typing import Any
22
-
23
- import httpx
24
-
25
- from aiq.tool.mcp.exceptions import MCPAuthenticationError
26
- from aiq.tool.mcp.exceptions import MCPConnectionError
27
- from aiq.tool.mcp.exceptions import MCPError
28
- from aiq.tool.mcp.exceptions import MCPProtocolError
29
- from aiq.tool.mcp.exceptions import MCPRequestError
30
- from aiq.tool.mcp.exceptions import MCPSSLError
31
- from aiq.tool.mcp.exceptions import MCPTimeoutError
32
- from aiq.tool.mcp.exceptions import MCPToolNotFoundError
33
-
34
- logger = logging.getLogger(__name__)
35
-
36
-
37
- def format_mcp_error(error: MCPError, include_traceback: bool = False) -> None:
38
- """Format MCP errors for CLI display with structured logging and user guidance.
39
-
40
- Logs structured error information for debugging and displays user-friendly
41
- error messages with actionable suggestions to stderr.
42
-
43
- Args:
44
- error (MCPError): MCPError instance containing message, url, category, suggestions, and original_exception
45
- include_traceback (bool, optional): Whether to include the traceback in the error message. Defaults to False.
46
- """
47
- # Log structured error information for debugging
48
- logger.error("MCP operation failed: %s", error, exc_info=include_traceback)
49
-
50
- # Display user-friendly suggestions
51
- for suggestion in error.suggestions:
52
- print(f" → {suggestion}", file=sys.stderr)
53
-
54
-
55
- def _extract_url(args: tuple, kwargs: dict[str, Any], url_param: str, func_name: str) -> str:
56
- """Extract URL from function arguments using clean fallback chain.
57
-
58
- Args:
59
- args: Function positional arguments
60
- kwargs: Function keyword arguments
61
- url_param (str): Parameter name containing the URL
62
- func_name (str): Function name for logging
63
-
64
- Returns:
65
- str: URL string or "unknown" if extraction fails
66
- """
67
- # Try keyword arguments first
68
- if url_param in kwargs:
69
- return kwargs[url_param]
70
-
71
- # Try self attribute (e.g., self.url)
72
- if args and hasattr(args[0], url_param):
73
- return getattr(args[0], url_param)
74
-
75
- # Try common case: url as second parameter after self
76
- if len(args) > 1 and url_param == "url":
77
- return args[1]
78
-
79
- # Fallback with warning
80
- logger.warning("Could not extract URL for error handling in %s", func_name)
81
- return "unknown"
82
-
83
-
84
- def extract_primary_exception(exceptions: list[Exception]) -> Exception:
85
- """Extract the most relevant exception from a group.
86
-
87
- Prioritizes connection errors over others for better user experience.
88
-
89
- Args:
90
- exceptions (list[Exception]): List of exceptions from ExceptionGroup
91
-
92
- Returns:
93
- Exception: Most relevant exception for user feedback
94
- """
95
- # Prioritize connection errors
96
- for exc in exceptions:
97
- if isinstance(exc, (httpx.ConnectError, ConnectionError)):
98
- return exc
99
-
100
- # Then timeout errors
101
- for exc in exceptions:
102
- if isinstance(exc, httpx.TimeoutException):
103
- return exc
104
-
105
- # Then SSL errors
106
- for exc in exceptions:
107
- if isinstance(exc, ssl.SSLError):
108
- return exc
109
-
110
- # Fall back to first exception
111
- return exceptions[0]
112
-
113
-
114
- def convert_to_mcp_error(exception: Exception, url: str) -> MCPError:
115
- """Convert single exception to appropriate MCPError.
116
-
117
- Args:
118
- exception (Exception): Single exception to convert
119
- url (str): MCP server URL for context
120
-
121
- Returns:
122
- MCPError: Appropriate MCPError subclass
123
- """
124
- match exception:
125
- case httpx.ConnectError() | ConnectionError():
126
- return MCPConnectionError(url, exception)
127
- case httpx.TimeoutException():
128
- return MCPTimeoutError(url, exception)
129
- case ssl.SSLError():
130
- return MCPSSLError(url, exception)
131
- case httpx.RequestError():
132
- return MCPRequestError(url, exception)
133
- case ValueError() if "Tool" in str(exception) and "not available" in str(exception):
134
- # Extract tool name from error message if possible
135
- tool_name = str(exception).split("Tool ")[1].split(" not available")[0] if "Tool " in str(
136
- exception) else "unknown"
137
- return MCPToolNotFoundError(tool_name, url, exception)
138
- case _:
139
- # Handle TaskGroup error message specifically
140
- if "unhandled errors in a TaskGroup" in str(exception):
141
- return MCPProtocolError(url, "Failed to connect to MCP server", exception)
142
- if "unauthorized" in str(exception).lower() or "forbidden" in str(exception).lower():
143
- return MCPAuthenticationError(url, exception)
144
- return MCPError(f"Unexpected error: {exception}", url, original_exception=exception)
145
-
146
-
147
- def handle_mcp_exceptions(url_param: str = "url") -> Callable[..., Any]:
148
- """Decorator that handles exceptions and converts them to MCPErrors.
149
-
150
- This decorator wraps MCP client methods and converts low-level exceptions
151
- to structured MCPError instances with helpful user guidance.
152
-
153
- Args:
154
- url_param (str): Name of the parameter or attribute containing the MCP server URL
155
-
156
- Returns:
157
- Callable[..., Any]: Decorated function
158
-
159
- Example:
160
- .. code-block:: python
161
-
162
- @handle_mcp_exceptions("url")
163
- async def get_tools(self, url: str):
164
- # Method implementation
165
- pass
166
-
167
- @handle_mcp_exceptions("url") # Uses self.url
168
- async def get_tool(self):
169
- # Method implementation
170
- pass
171
- """
172
-
173
- def decorator(func: Callable[..., Any]) -> Callable[..., Any]:
174
-
175
- @wraps(func)
176
- async def wrapper(*args, **kwargs):
177
- try:
178
- return await func(*args, **kwargs)
179
- except MCPError:
180
- # Re-raise MCPErrors as-is
181
- raise
182
- except Exception as e:
183
- url = _extract_url(args, kwargs, url_param, func.__name__)
184
-
185
- # Handle ExceptionGroup by extracting most relevant exception
186
- if isinstance(e, ExceptionGroup): # noqa: F821
187
- primary_exception = extract_primary_exception(list(e.exceptions))
188
- mcp_error = convert_to_mcp_error(primary_exception, url)
189
- else:
190
- mcp_error = convert_to_mcp_error(e, url)
191
-
192
- raise mcp_error from e
193
-
194
- return wrapper
195
-
196
- return decorator
197
-
198
-
199
- def mcp_exception_handler(func: Callable[..., Any]) -> Callable[..., Any]:
200
- """Simplified decorator for methods that have self.url attribute.
201
-
202
- This is a convenience decorator that assumes the URL is available as self.url.
203
- Follows the same pattern as schema_exception_handler in this directory.
204
-
205
- Args:
206
- func (Callable[..., Any]): The function to decorate
207
-
208
- Returns:
209
- Callable[..., Any]: Decorated function
210
- """
211
- return handle_mcp_exceptions("url")(func)
@@ -1,114 +0,0 @@
1
- # SPDX-FileCopyrightText: Copyright (c) 2024-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
-
18
- import yaml
19
- from pydantic import ValidationError
20
-
21
- logger = logging.getLogger(__name__)
22
-
23
-
24
- def schema_exception_handler(func, **kwargs): # pylint: disable=unused-argument
25
- """
26
- A decorator that handles `ValidationError` exceptions for schema validation functions.
27
-
28
- This decorator wraps a function that performs schema validation using Pydantic.
29
- If a `ValidationError` is raised, it logs detailed error messages and raises a `ValueError` with the combined error
30
- messages.
31
-
32
- Parameters
33
- ----------
34
- func : callable
35
- The function to be decorated. This function is expected to perform schema validation.
36
-
37
- kwargs : dict
38
- Additional keyword arguments to be passed to the function.
39
-
40
- Returns
41
- -------
42
- callable
43
- The wrapped function that executes `func` with exception handling.
44
-
45
- Raises
46
- ------
47
- ValueError
48
- If a `ValidationError` is caught, this decorator logs the error details and raises a `ValueError` with the
49
- combined error messages.
50
-
51
- Notes
52
- -----
53
- This decorator is particularly useful for functions that validate configurations or data models,
54
- ensuring that any validation errors are logged and communicated clearly.
55
-
56
- Examples
57
- --------
58
- >>> @schema_exception_handler
59
- ... def validate_config(config_data):
60
- ... schema = MySchema(**config_data)
61
- ... return schema
62
- ...
63
- >>> try:
64
- ... validate_config(invalid_config)
65
- ... except ValueError as e:
66
- ... logger.error("Caught error: %s", e)
67
- Caught error: Invalid configuration: field1: value is not a valid integer; field2: field required
68
- """
69
-
70
- def inner_function(*args, **kwargs):
71
- try:
72
- return func(*args, **kwargs)
73
- except ValidationError as e:
74
- error_messages = "; ".join([f"{error['loc'][0]}: {error['msg']}" for error in e.errors()])
75
- log_error_message = f"Invalid configuration: {error_messages}"
76
- logger.error(log_error_message)
77
- raise ValueError(log_error_message) from e
78
-
79
- return inner_function
80
-
81
-
82
- def yaml_exception_handler(func):
83
- """
84
- A decorator that handles YAML parsing exceptions.
85
-
86
- This decorator wraps a function that performs YAML file operations.
87
- If a YAML-related error occurs, it logs the error and raises a ValueError
88
- with a clear error message.
89
-
90
- Returns
91
- -------
92
- callable
93
- The wrapped function that executes `func` with YAML exception handling.
94
-
95
- Raises
96
- ------
97
- ValueError
98
- If a YAML error is caught, with details about the parsing failure.
99
- """
100
-
101
- def inner_function(*args, **kwargs):
102
- try:
103
- return func(*args, **kwargs)
104
- except yaml.YAMLError as e:
105
- log_error_message = f"Invalid YAML configuration: {str(e)}"
106
- logger.error(log_error_message)
107
- raise ValueError(log_error_message) from e
108
-
109
- except Exception as e:
110
- log_error_message = f"Error reading YAML file: {str(e)}"
111
- logger.error(log_error_message)
112
- raise ValueError(log_error_message) from e
113
-
114
- return inner_function
aiq/utils/io/__init__.py DELETED
File without changes
@@ -1,28 +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 re
17
-
18
-
19
- def remove_r1_think_tags(text: str):
20
- pattern = r'(<think>)?.*?</think>\s*(.*)'
21
-
22
- # Add re.DOTALL flag to make . match newlines
23
- match = re.match(pattern, text, re.DOTALL)
24
-
25
- if match:
26
- return match.group(2)
27
-
28
- return text
@@ -1,119 +0,0 @@
1
- # SPDX-FileCopyrightText: Copyright (c) 2024-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 io
17
- import logging
18
- import typing
19
-
20
- import expandvars
21
- import yaml
22
-
23
- from aiq.utils.type_utils import StrPath
24
-
25
- logger = logging.getLogger(__name__)
26
-
27
-
28
- def _interpolate_variables(value: str | int | float | bool | None) -> str | int | float | bool | None:
29
- """
30
- Interpolate variables in a string with the format ${VAR:-default_value}.
31
- If the variable is not set, the default value will be used.
32
- If no default value is provided, an empty string will be used.
33
-
34
- Args:
35
- value (str | int | float | bool | None): The value to interpolate variables in.
36
-
37
- Returns:
38
- str | int | float | bool | None: The value with variables interpolated.
39
- """
40
-
41
- if not isinstance(value, str):
42
- return value
43
-
44
- return expandvars.expandvars(value)
45
-
46
-
47
- def yaml_load(config_path: StrPath) -> dict:
48
- """
49
- Load a YAML file and interpolate variables in the format
50
- ${VAR:-default_value}.
51
-
52
- Args:
53
- config_path (StrPath): The path to the YAML file to load.
54
-
55
- Returns:
56
- dict: The processed configuration dictionary.
57
- """
58
-
59
- # Read YAML file
60
- with open(config_path, "r", encoding="utf-8") as stream:
61
- config_str = stream.read()
62
-
63
- return yaml_loads(config_str)
64
-
65
-
66
- def yaml_loads(config: str) -> dict:
67
- """
68
- Load a YAML string and interpolate variables in the format
69
- ${VAR:-default_value}.
70
-
71
- Args:
72
- config (str): The YAML string to load.
73
-
74
- Returns:
75
- dict: The processed configuration dictionary.
76
- """
77
-
78
- interpolated_config_str = _interpolate_variables(config)
79
- assert isinstance(interpolated_config_str, str), "Config must be a string"
80
-
81
- stream = io.StringIO(interpolated_config_str)
82
- stream.seek(0)
83
-
84
- # Load the YAML data
85
- try:
86
- config_data = yaml.safe_load(stream)
87
- except yaml.YAMLError as e:
88
- logger.error("Error loading YAML: %s", interpolated_config_str, exc_info=True)
89
- raise ValueError(f"Error loading YAML: {e}") from e
90
-
91
- assert isinstance(config_data, dict)
92
-
93
- return config_data
94
-
95
-
96
- def yaml_dump(config: dict, fp: typing.TextIO) -> None:
97
- """
98
- Dump a configuration dictionary to a YAML file.
99
-
100
- Args:
101
- config (dict): The configuration dictionary to dump.
102
- fp (typing.TextIO): The file pointer to write the YAML to.
103
- """
104
- yaml.dump(config, stream=fp, indent=2, sort_keys=False)
105
- fp.flush()
106
-
107
-
108
- def yaml_dumps(config: dict) -> str:
109
- """
110
- Dump a configuration dictionary to a YAML string.
111
-
112
- Args:
113
- config (dict): The configuration dictionary to dump.
114
-
115
- Returns:
116
- str: The YAML string.
117
- """
118
-
119
- return yaml.dump(config, indent=2)
aiq/utils/log_utils.py DELETED
@@ -1,37 +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
-
18
-
19
- class LogFilter(logging.Filter):
20
- """
21
- This class is used to filter log records based on a defined set of criteria.
22
- """
23
-
24
- def __init__(self, filter_criteria: list[str]):
25
- self._filter_criteria = filter_criteria
26
- super().__init__()
27
-
28
- def filter(self, record: logging.LogRecord):
29
- """
30
- Evaluates whether a log record should be emitted based on the message content.
31
-
32
- Returns:
33
- False if the message content contains any of the filter criteria, True otherwise.
34
- """
35
- if any(match in record.getMessage() for match in self._filter_criteria):
36
- return False
37
- return True
@@ -1,74 +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 pydantic_core import PydanticUndefined
17
-
18
- from aiq.data_models.common import TypedBaseModelT
19
- from aiq.utils.type_utils import DecomposedType
20
-
21
-
22
- def generate_config_type_docs(config_type: TypedBaseModelT) -> str:
23
- """Generates a docstring from configuration object to facilitate discovery.
24
-
25
- Args:
26
- config_type (TypedBaseModelT): A component configuration object.
27
-
28
- Returns:
29
- str: An enriched docstring, including model attributes and default values.
30
- """
31
-
32
- # Get the docstring
33
- description_formatting = []
34
- # Ensure uniform formatting of docstring
35
- docstring = (config_type.__doc__ or "").strip().strip(".")
36
- docstring = docstring + "." if docstring != "" else "Description unavailable."
37
- description_formatting.append(docstring)
38
- description_formatting.append("")
39
- description_formatting.append(" Args:")
40
-
41
- # Iterate over fields to get their documentation
42
- for field_name, field_info in config_type.model_fields.items():
43
-
44
- if (field_name == "type"):
45
- field_name = "_type"
46
-
47
- decomponsed_type = DecomposedType(field_info.annotation)
48
-
49
- if not (decomponsed_type.is_union):
50
- annotation = field_info.annotation.__name__
51
- else:
52
- annotation = field_info.annotation
53
-
54
- default_string = ""
55
- if ((field_info.get_default() is not PydanticUndefined) and (field_name != "_type")):
56
- if issubclass(type(field_info.get_default()), str):
57
- default_value = f'"{field_info.get_default()}"'
58
- else:
59
- default_value = field_info.get_default()
60
- default_string += f" Defaults to {default_value}."
61
-
62
- # Ensure uniform formatting of field info
63
- field_info_description = (field_info.description or "").strip(".")
64
- if field_info_description != "":
65
- field_info_description = field_info_description + "."
66
- else:
67
- field_info_description = "Description unavailable."
68
-
69
- parameter_string = f" {field_name} ({annotation}): {field_info_description}{default_string}"
70
- description_formatting.append(parameter_string)
71
-
72
- description = "\n".join(description_formatting)
73
-
74
- return description