aiqtoolkit 1.1.0a20250515__py3-none-any.whl → 1.1.0a20251020__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 (319) hide show
  1. aiqtoolkit-1.1.0a20251020.dist-info/METADATA +37 -0
  2. aiqtoolkit-1.1.0a20251020.dist-info/RECORD +4 -0
  3. {aiqtoolkit-1.1.0a20250515.dist-info → aiqtoolkit-1.1.0a20251020.dist-info}/WHEEL +1 -1
  4. aiqtoolkit-1.1.0a20251020.dist-info/top_level.txt +1 -0
  5. aiq/agent/__init__.py +0 -0
  6. aiq/agent/base.py +0 -76
  7. aiq/agent/dual_node.py +0 -67
  8. aiq/agent/react_agent/__init__.py +0 -0
  9. aiq/agent/react_agent/agent.py +0 -322
  10. aiq/agent/react_agent/output_parser.py +0 -104
  11. aiq/agent/react_agent/prompt.py +0 -46
  12. aiq/agent/react_agent/register.py +0 -148
  13. aiq/agent/reasoning_agent/__init__.py +0 -0
  14. aiq/agent/reasoning_agent/reasoning_agent.py +0 -224
  15. aiq/agent/register.py +0 -23
  16. aiq/agent/rewoo_agent/__init__.py +0 -0
  17. aiq/agent/rewoo_agent/agent.py +0 -410
  18. aiq/agent/rewoo_agent/prompt.py +0 -108
  19. aiq/agent/rewoo_agent/register.py +0 -158
  20. aiq/agent/tool_calling_agent/__init__.py +0 -0
  21. aiq/agent/tool_calling_agent/agent.py +0 -123
  22. aiq/agent/tool_calling_agent/register.py +0 -105
  23. aiq/builder/__init__.py +0 -0
  24. aiq/builder/builder.py +0 -223
  25. aiq/builder/component_utils.py +0 -303
  26. aiq/builder/context.py +0 -227
  27. aiq/builder/embedder.py +0 -24
  28. aiq/builder/eval_builder.py +0 -120
  29. aiq/builder/evaluator.py +0 -29
  30. aiq/builder/framework_enum.py +0 -24
  31. aiq/builder/front_end.py +0 -73
  32. aiq/builder/function.py +0 -297
  33. aiq/builder/function_base.py +0 -376
  34. aiq/builder/function_info.py +0 -627
  35. aiq/builder/intermediate_step_manager.py +0 -135
  36. aiq/builder/llm.py +0 -25
  37. aiq/builder/retriever.py +0 -25
  38. aiq/builder/user_interaction_manager.py +0 -71
  39. aiq/builder/workflow.py +0 -143
  40. aiq/builder/workflow_builder.py +0 -757
  41. aiq/cli/__init__.py +0 -14
  42. aiq/cli/cli_utils/__init__.py +0 -0
  43. aiq/cli/cli_utils/config_override.py +0 -231
  44. aiq/cli/cli_utils/validation.py +0 -37
  45. aiq/cli/commands/__init__.py +0 -0
  46. aiq/cli/commands/configure/__init__.py +0 -0
  47. aiq/cli/commands/configure/channel/__init__.py +0 -0
  48. aiq/cli/commands/configure/channel/add.py +0 -28
  49. aiq/cli/commands/configure/channel/channel.py +0 -36
  50. aiq/cli/commands/configure/channel/remove.py +0 -30
  51. aiq/cli/commands/configure/channel/update.py +0 -30
  52. aiq/cli/commands/configure/configure.py +0 -33
  53. aiq/cli/commands/evaluate.py +0 -139
  54. aiq/cli/commands/info/__init__.py +0 -14
  55. aiq/cli/commands/info/info.py +0 -39
  56. aiq/cli/commands/info/list_channels.py +0 -32
  57. aiq/cli/commands/info/list_components.py +0 -129
  58. aiq/cli/commands/info/list_mcp.py +0 -126
  59. aiq/cli/commands/registry/__init__.py +0 -14
  60. aiq/cli/commands/registry/publish.py +0 -88
  61. aiq/cli/commands/registry/pull.py +0 -118
  62. aiq/cli/commands/registry/registry.py +0 -38
  63. aiq/cli/commands/registry/remove.py +0 -108
  64. aiq/cli/commands/registry/search.py +0 -155
  65. aiq/cli/commands/start.py +0 -250
  66. aiq/cli/commands/uninstall.py +0 -83
  67. aiq/cli/commands/validate.py +0 -47
  68. aiq/cli/commands/workflow/__init__.py +0 -14
  69. aiq/cli/commands/workflow/templates/__init__.py.j2 +0 -0
  70. aiq/cli/commands/workflow/templates/config.yml.j2 +0 -16
  71. aiq/cli/commands/workflow/templates/pyproject.toml.j2 +0 -22
  72. aiq/cli/commands/workflow/templates/register.py.j2 +0 -5
  73. aiq/cli/commands/workflow/templates/workflow.py.j2 +0 -36
  74. aiq/cli/commands/workflow/workflow.py +0 -37
  75. aiq/cli/commands/workflow/workflow_commands.py +0 -313
  76. aiq/cli/entrypoint.py +0 -133
  77. aiq/cli/main.py +0 -44
  78. aiq/cli/register_workflow.py +0 -408
  79. aiq/cli/type_registry.py +0 -879
  80. aiq/data_models/__init__.py +0 -14
  81. aiq/data_models/api_server.py +0 -588
  82. aiq/data_models/common.py +0 -143
  83. aiq/data_models/component.py +0 -46
  84. aiq/data_models/component_ref.py +0 -135
  85. aiq/data_models/config.py +0 -349
  86. aiq/data_models/dataset_handler.py +0 -122
  87. aiq/data_models/discovery_metadata.py +0 -286
  88. aiq/data_models/embedder.py +0 -26
  89. aiq/data_models/evaluate.py +0 -104
  90. aiq/data_models/evaluator.py +0 -26
  91. aiq/data_models/front_end.py +0 -26
  92. aiq/data_models/function.py +0 -30
  93. aiq/data_models/function_dependencies.py +0 -64
  94. aiq/data_models/interactive.py +0 -237
  95. aiq/data_models/intermediate_step.py +0 -269
  96. aiq/data_models/invocation_node.py +0 -38
  97. aiq/data_models/llm.py +0 -26
  98. aiq/data_models/logging.py +0 -26
  99. aiq/data_models/memory.py +0 -26
  100. aiq/data_models/profiler.py +0 -53
  101. aiq/data_models/registry_handler.py +0 -26
  102. aiq/data_models/retriever.py +0 -30
  103. aiq/data_models/step_adaptor.py +0 -64
  104. aiq/data_models/streaming.py +0 -33
  105. aiq/data_models/swe_bench_model.py +0 -54
  106. aiq/data_models/telemetry_exporter.py +0 -26
  107. aiq/embedder/__init__.py +0 -0
  108. aiq/embedder/langchain_client.py +0 -41
  109. aiq/embedder/nim_embedder.py +0 -58
  110. aiq/embedder/openai_embedder.py +0 -42
  111. aiq/embedder/register.py +0 -24
  112. aiq/eval/__init__.py +0 -14
  113. aiq/eval/config.py +0 -42
  114. aiq/eval/dataset_handler/__init__.py +0 -0
  115. aiq/eval/dataset_handler/dataset_downloader.py +0 -106
  116. aiq/eval/dataset_handler/dataset_filter.py +0 -52
  117. aiq/eval/dataset_handler/dataset_handler.py +0 -169
  118. aiq/eval/evaluate.py +0 -325
  119. aiq/eval/evaluator/__init__.py +0 -14
  120. aiq/eval/evaluator/evaluator_model.py +0 -44
  121. aiq/eval/intermediate_step_adapter.py +0 -93
  122. aiq/eval/rag_evaluator/__init__.py +0 -0
  123. aiq/eval/rag_evaluator/evaluate.py +0 -138
  124. aiq/eval/rag_evaluator/register.py +0 -138
  125. aiq/eval/register.py +0 -23
  126. aiq/eval/remote_workflow.py +0 -128
  127. aiq/eval/runtime_event_subscriber.py +0 -52
  128. aiq/eval/swe_bench_evaluator/__init__.py +0 -0
  129. aiq/eval/swe_bench_evaluator/evaluate.py +0 -215
  130. aiq/eval/swe_bench_evaluator/register.py +0 -36
  131. aiq/eval/trajectory_evaluator/__init__.py +0 -0
  132. aiq/eval/trajectory_evaluator/evaluate.py +0 -118
  133. aiq/eval/trajectory_evaluator/register.py +0 -40
  134. aiq/eval/tunable_rag_evaluator/__init__.py +0 -0
  135. aiq/eval/tunable_rag_evaluator/evaluate.py +0 -263
  136. aiq/eval/tunable_rag_evaluator/register.py +0 -50
  137. aiq/eval/utils/__init__.py +0 -0
  138. aiq/eval/utils/output_uploader.py +0 -131
  139. aiq/eval/utils/tqdm_position_registry.py +0 -40
  140. aiq/front_ends/__init__.py +0 -14
  141. aiq/front_ends/console/__init__.py +0 -14
  142. aiq/front_ends/console/console_front_end_config.py +0 -32
  143. aiq/front_ends/console/console_front_end_plugin.py +0 -107
  144. aiq/front_ends/console/register.py +0 -25
  145. aiq/front_ends/cron/__init__.py +0 -14
  146. aiq/front_ends/fastapi/__init__.py +0 -14
  147. aiq/front_ends/fastapi/fastapi_front_end_config.py +0 -150
  148. aiq/front_ends/fastapi/fastapi_front_end_plugin.py +0 -103
  149. aiq/front_ends/fastapi/fastapi_front_end_plugin_worker.py +0 -607
  150. aiq/front_ends/fastapi/intermediate_steps_subscriber.py +0 -80
  151. aiq/front_ends/fastapi/job_store.py +0 -161
  152. aiq/front_ends/fastapi/main.py +0 -70
  153. aiq/front_ends/fastapi/message_handler.py +0 -279
  154. aiq/front_ends/fastapi/message_validator.py +0 -345
  155. aiq/front_ends/fastapi/register.py +0 -25
  156. aiq/front_ends/fastapi/response_helpers.py +0 -195
  157. aiq/front_ends/fastapi/step_adaptor.py +0 -320
  158. aiq/front_ends/fastapi/websocket.py +0 -148
  159. aiq/front_ends/mcp/__init__.py +0 -14
  160. aiq/front_ends/mcp/mcp_front_end_config.py +0 -32
  161. aiq/front_ends/mcp/mcp_front_end_plugin.py +0 -93
  162. aiq/front_ends/mcp/register.py +0 -27
  163. aiq/front_ends/mcp/tool_converter.py +0 -242
  164. aiq/front_ends/register.py +0 -22
  165. aiq/front_ends/simple_base/__init__.py +0 -14
  166. aiq/front_ends/simple_base/simple_front_end_plugin_base.py +0 -52
  167. aiq/llm/__init__.py +0 -0
  168. aiq/llm/nim_llm.py +0 -45
  169. aiq/llm/openai_llm.py +0 -45
  170. aiq/llm/register.py +0 -22
  171. aiq/llm/utils/__init__.py +0 -14
  172. aiq/llm/utils/env_config_value.py +0 -94
  173. aiq/llm/utils/error.py +0 -17
  174. aiq/memory/__init__.py +0 -20
  175. aiq/memory/interfaces.py +0 -183
  176. aiq/memory/models.py +0 -112
  177. aiq/meta/module_to_distro.json +0 -3
  178. aiq/meta/pypi.md +0 -58
  179. aiq/observability/__init__.py +0 -0
  180. aiq/observability/async_otel_listener.py +0 -429
  181. aiq/observability/register.py +0 -99
  182. aiq/plugins/.namespace +0 -1
  183. aiq/profiler/__init__.py +0 -0
  184. aiq/profiler/callbacks/__init__.py +0 -0
  185. aiq/profiler/callbacks/agno_callback_handler.py +0 -295
  186. aiq/profiler/callbacks/base_callback_class.py +0 -20
  187. aiq/profiler/callbacks/langchain_callback_handler.py +0 -278
  188. aiq/profiler/callbacks/llama_index_callback_handler.py +0 -205
  189. aiq/profiler/callbacks/semantic_kernel_callback_handler.py +0 -238
  190. aiq/profiler/callbacks/token_usage_base_model.py +0 -27
  191. aiq/profiler/data_frame_row.py +0 -51
  192. aiq/profiler/decorators/__init__.py +0 -0
  193. aiq/profiler/decorators/framework_wrapper.py +0 -131
  194. aiq/profiler/decorators/function_tracking.py +0 -254
  195. aiq/profiler/forecasting/__init__.py +0 -0
  196. aiq/profiler/forecasting/config.py +0 -18
  197. aiq/profiler/forecasting/model_trainer.py +0 -75
  198. aiq/profiler/forecasting/models/__init__.py +0 -22
  199. aiq/profiler/forecasting/models/forecasting_base_model.py +0 -40
  200. aiq/profiler/forecasting/models/linear_model.py +0 -196
  201. aiq/profiler/forecasting/models/random_forest_regressor.py +0 -268
  202. aiq/profiler/inference_metrics_model.py +0 -25
  203. aiq/profiler/inference_optimization/__init__.py +0 -0
  204. aiq/profiler/inference_optimization/bottleneck_analysis/__init__.py +0 -0
  205. aiq/profiler/inference_optimization/bottleneck_analysis/nested_stack_analysis.py +0 -452
  206. aiq/profiler/inference_optimization/bottleneck_analysis/simple_stack_analysis.py +0 -258
  207. aiq/profiler/inference_optimization/data_models.py +0 -386
  208. aiq/profiler/inference_optimization/experimental/__init__.py +0 -0
  209. aiq/profiler/inference_optimization/experimental/concurrency_spike_analysis.py +0 -468
  210. aiq/profiler/inference_optimization/experimental/prefix_span_analysis.py +0 -405
  211. aiq/profiler/inference_optimization/llm_metrics.py +0 -212
  212. aiq/profiler/inference_optimization/prompt_caching.py +0 -163
  213. aiq/profiler/inference_optimization/token_uniqueness.py +0 -107
  214. aiq/profiler/inference_optimization/workflow_runtimes.py +0 -72
  215. aiq/profiler/intermediate_property_adapter.py +0 -102
  216. aiq/profiler/profile_runner.py +0 -433
  217. aiq/profiler/utils.py +0 -184
  218. aiq/registry_handlers/__init__.py +0 -0
  219. aiq/registry_handlers/local/__init__.py +0 -0
  220. aiq/registry_handlers/local/local_handler.py +0 -176
  221. aiq/registry_handlers/local/register_local.py +0 -37
  222. aiq/registry_handlers/metadata_factory.py +0 -60
  223. aiq/registry_handlers/package_utils.py +0 -198
  224. aiq/registry_handlers/pypi/__init__.py +0 -0
  225. aiq/registry_handlers/pypi/pypi_handler.py +0 -251
  226. aiq/registry_handlers/pypi/register_pypi.py +0 -40
  227. aiq/registry_handlers/register.py +0 -21
  228. aiq/registry_handlers/registry_handler_base.py +0 -157
  229. aiq/registry_handlers/rest/__init__.py +0 -0
  230. aiq/registry_handlers/rest/register_rest.py +0 -56
  231. aiq/registry_handlers/rest/rest_handler.py +0 -237
  232. aiq/registry_handlers/schemas/__init__.py +0 -0
  233. aiq/registry_handlers/schemas/headers.py +0 -42
  234. aiq/registry_handlers/schemas/package.py +0 -68
  235. aiq/registry_handlers/schemas/publish.py +0 -63
  236. aiq/registry_handlers/schemas/pull.py +0 -82
  237. aiq/registry_handlers/schemas/remove.py +0 -36
  238. aiq/registry_handlers/schemas/search.py +0 -91
  239. aiq/registry_handlers/schemas/status.py +0 -47
  240. aiq/retriever/__init__.py +0 -0
  241. aiq/retriever/interface.py +0 -37
  242. aiq/retriever/milvus/__init__.py +0 -14
  243. aiq/retriever/milvus/register.py +0 -81
  244. aiq/retriever/milvus/retriever.py +0 -228
  245. aiq/retriever/models.py +0 -74
  246. aiq/retriever/nemo_retriever/__init__.py +0 -14
  247. aiq/retriever/nemo_retriever/register.py +0 -60
  248. aiq/retriever/nemo_retriever/retriever.py +0 -190
  249. aiq/retriever/register.py +0 -22
  250. aiq/runtime/__init__.py +0 -14
  251. aiq/runtime/loader.py +0 -188
  252. aiq/runtime/runner.py +0 -176
  253. aiq/runtime/session.py +0 -140
  254. aiq/runtime/user_metadata.py +0 -131
  255. aiq/settings/__init__.py +0 -0
  256. aiq/settings/global_settings.py +0 -318
  257. aiq/test/.namespace +0 -1
  258. aiq/tool/__init__.py +0 -0
  259. aiq/tool/code_execution/__init__.py +0 -0
  260. aiq/tool/code_execution/code_sandbox.py +0 -188
  261. aiq/tool/code_execution/local_sandbox/Dockerfile.sandbox +0 -60
  262. aiq/tool/code_execution/local_sandbox/__init__.py +0 -13
  263. aiq/tool/code_execution/local_sandbox/local_sandbox_server.py +0 -83
  264. aiq/tool/code_execution/local_sandbox/sandbox.requirements.txt +0 -4
  265. aiq/tool/code_execution/local_sandbox/start_local_sandbox.sh +0 -25
  266. aiq/tool/code_execution/register.py +0 -70
  267. aiq/tool/code_execution/utils.py +0 -100
  268. aiq/tool/datetime_tools.py +0 -42
  269. aiq/tool/document_search.py +0 -141
  270. aiq/tool/github_tools/__init__.py +0 -0
  271. aiq/tool/github_tools/create_github_commit.py +0 -133
  272. aiq/tool/github_tools/create_github_issue.py +0 -87
  273. aiq/tool/github_tools/create_github_pr.py +0 -106
  274. aiq/tool/github_tools/get_github_file.py +0 -106
  275. aiq/tool/github_tools/get_github_issue.py +0 -166
  276. aiq/tool/github_tools/get_github_pr.py +0 -256
  277. aiq/tool/github_tools/update_github_issue.py +0 -100
  278. aiq/tool/mcp/__init__.py +0 -14
  279. aiq/tool/mcp/mcp_client.py +0 -220
  280. aiq/tool/mcp/mcp_tool.py +0 -95
  281. aiq/tool/memory_tools/__init__.py +0 -0
  282. aiq/tool/memory_tools/add_memory_tool.py +0 -79
  283. aiq/tool/memory_tools/delete_memory_tool.py +0 -67
  284. aiq/tool/memory_tools/get_memory_tool.py +0 -72
  285. aiq/tool/nvidia_rag.py +0 -95
  286. aiq/tool/register.py +0 -37
  287. aiq/tool/retriever.py +0 -89
  288. aiq/tool/server_tools.py +0 -63
  289. aiq/utils/__init__.py +0 -0
  290. aiq/utils/data_models/__init__.py +0 -0
  291. aiq/utils/data_models/schema_validator.py +0 -58
  292. aiq/utils/debugging_utils.py +0 -43
  293. aiq/utils/exception_handlers/__init__.py +0 -0
  294. aiq/utils/exception_handlers/schemas.py +0 -114
  295. aiq/utils/io/__init__.py +0 -0
  296. aiq/utils/io/yaml_tools.py +0 -119
  297. aiq/utils/metadata_utils.py +0 -74
  298. aiq/utils/optional_imports.py +0 -142
  299. aiq/utils/producer_consumer_queue.py +0 -178
  300. aiq/utils/reactive/__init__.py +0 -0
  301. aiq/utils/reactive/base/__init__.py +0 -0
  302. aiq/utils/reactive/base/observable_base.py +0 -65
  303. aiq/utils/reactive/base/observer_base.py +0 -55
  304. aiq/utils/reactive/base/subject_base.py +0 -79
  305. aiq/utils/reactive/observable.py +0 -59
  306. aiq/utils/reactive/observer.py +0 -76
  307. aiq/utils/reactive/subject.py +0 -131
  308. aiq/utils/reactive/subscription.py +0 -49
  309. aiq/utils/settings/__init__.py +0 -0
  310. aiq/utils/settings/global_settings.py +0 -197
  311. aiq/utils/type_converter.py +0 -232
  312. aiq/utils/type_utils.py +0 -397
  313. aiq/utils/url_utils.py +0 -27
  314. aiqtoolkit-1.1.0a20250515.dist-info/METADATA +0 -331
  315. aiqtoolkit-1.1.0a20250515.dist-info/RECORD +0 -316
  316. aiqtoolkit-1.1.0a20250515.dist-info/entry_points.txt +0 -17
  317. aiqtoolkit-1.1.0a20250515.dist-info/licenses/LICENSE-3rd-party.txt +0 -3686
  318. aiqtoolkit-1.1.0a20250515.dist-info/licenses/LICENSE.md +0 -201
  319. aiqtoolkit-1.1.0a20250515.dist-info/top_level.txt +0 -1
aiq/tool/retriever.py DELETED
@@ -1,89 +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
- from pydantic import BaseModel
19
- from pydantic import Field
20
-
21
- from aiq.builder.builder import Builder
22
- from aiq.builder.function_info import FunctionInfo
23
- from aiq.cli.register_workflow import register_function
24
- from aiq.data_models.component_ref import RetrieverRef
25
- from aiq.data_models.function import FunctionBaseConfig
26
- from aiq.retriever.interface import AIQRetriever
27
- from aiq.retriever.models import RetrieverError
28
- from aiq.retriever.models import RetrieverOutput
29
-
30
- logger = logging.getLogger(__name__)
31
-
32
-
33
- class AIQRetrieverConfig(FunctionBaseConfig, name="aiq_retriever"):
34
- """
35
- AIQRetriever tool which provides a common interface for different vectorstores. Its
36
- configuration uses clients, which are the vectorstore-specific implementaiton of the retriever interface.
37
- """
38
- retriever: RetrieverRef = Field(description="The retriever instance name from the workflow configuration object.")
39
- raise_errors: bool = Field(
40
- default=True,
41
- description="If true the tool will raise exceptions, otherwise it will log them as warnings and return []",
42
- )
43
- topic: str | None = Field(default=None, description="Used to provide a more detailed tool description to the agent")
44
- description: str | None = Field(default=None, description="If present it will be used as the tool description")
45
-
46
-
47
- def _get_description_from_config(config: AIQRetrieverConfig) -> str:
48
- """
49
- Generate a description of what the tool will do based on how it is configured.
50
- """
51
- description = "Retrieve document chunks{topic} which can be used to answer the provided question."
52
-
53
- _topic = f" related to {config.topic}" if config.topic else ""
54
-
55
- return description.format(topic=_topic) if not config.description else config.description
56
-
57
-
58
- @register_function(config_type=AIQRetrieverConfig)
59
- async def aiq_retriever_tool(config: AIQRetrieverConfig, builder: Builder):
60
- """
61
- Configure an AIQ Toolkit Retriever Tool which supports different clients such as Milvus and Nemo Retriever.
62
-
63
- Args:
64
- config: A config object with required parameters 'client' and 'client_config'
65
- builder: A workflow builder object
66
- """
67
-
68
- class RetrieverInputSchema(BaseModel):
69
- query: str = Field(description="The query to be searched in the configured data store")
70
-
71
- client: AIQRetriever = await builder.get_retriever(config.retriever)
72
-
73
- async def _retrieve(query: str) -> RetrieverOutput:
74
- try:
75
- retrieved_context = await client.search(query=query)
76
- logger.info("Retrieved %s records for query %s.", len(retrieved_context), query)
77
- return retrieved_context
78
-
79
- except RetrieverError as e:
80
- if config.raise_errors:
81
- raise e
82
- logger.warning("Retriever threw an error: %s. Returning an empty response.", e)
83
- return RetrieverOutput(results=[])
84
-
85
- yield FunctionInfo.from_fn(
86
- fn=_retrieve,
87
- input_schema=RetrieverInputSchema,
88
- description=_get_description_from_config(config),
89
- )
aiq/tool/server_tools.py DELETED
@@ -1,63 +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
- from aiq.builder.builder import Builder
17
- from aiq.builder.function_info import FunctionInfo
18
- from aiq.cli.register_workflow import register_function
19
- from aiq.data_models.function import FunctionBaseConfig
20
-
21
-
22
- class RequestAttributesTool(FunctionBaseConfig, name="current_request_attributes"):
23
- """
24
- A simple tool that demonstrates how to retrieve user-defined request attributes from HTTP requests
25
- within workflow tools. Please refer to the 'general' section of the configuration file located in the
26
- 'examples/simple_calculator/configs/config-metadata.yml' directory to see how to define a custom route using a
27
- YAML file and associate it with a corresponding function to acquire request attributes.
28
- """
29
- pass
30
-
31
-
32
- @register_function(config_type=RequestAttributesTool)
33
- async def current_request_attributes(config: RequestAttributesTool, builder: Builder):
34
-
35
- from starlette.datastructures import Headers
36
- from starlette.datastructures import QueryParams
37
-
38
- async def _get_request_attributes(unused: str) -> str:
39
-
40
- from aiq.builder.context import AIQContext
41
- aiq_context = AIQContext.get()
42
- method: str | None = aiq_context.metadata.method
43
- url_path: str | None = aiq_context.metadata.url_path
44
- url_scheme: str | None = aiq_context.metadata.url_scheme
45
- headers: Headers | None = aiq_context.metadata.headers
46
- query_params: QueryParams | None = aiq_context.metadata.query_params
47
- path_params: dict[str, str] | None = aiq_context.metadata.path_params
48
- client_host: str | None = aiq_context.metadata.client_host
49
- client_port: int | None = aiq_context.metadata.client_port
50
- cookies: dict[str, str] | None = aiq_context.metadata.cookies
51
-
52
- return (f"Method: {method}, "
53
- f"URL Path: {url_path}, "
54
- f"URL Scheme: {url_scheme}, "
55
- f"Headers: {dict(headers) if headers is not None else 'None'}, "
56
- f"Query Params: {dict(query_params) if query_params is not None else 'None'}, "
57
- f"Path Params: {path_params}, "
58
- f"Client Host: {client_host}, "
59
- f"Client Port: {client_port}, "
60
- f"Cookies: {cookies}")
61
-
62
- yield FunctionInfo.from_fn(_get_request_attributes,
63
- description="Returns the acquired user defined request attriubutes.")
aiq/utils/__init__.py DELETED
File without changes
File without changes
@@ -1,58 +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 yaml
17
- from pydantic import ValidationError
18
-
19
- from ..exception_handlers.schemas import schema_exception_handler
20
- from ..exception_handlers.schemas import yaml_exception_handler
21
-
22
-
23
- @schema_exception_handler
24
- def validate_schema(metadata, Schema): # pylint: disable=invalid-name
25
-
26
- try:
27
- return Schema(**metadata)
28
- except ValidationError as e:
29
-
30
- raise e
31
-
32
-
33
- @yaml_exception_handler
34
- def validate_yaml(ctx, param, value): # pylint: disable=unused-argument
35
- """
36
- Validate that the file is a valid YAML file
37
-
38
- Parameters
39
- ----------
40
- ctx: Click context
41
- param: Click parameter
42
- value: Path to YAML file
43
-
44
- Returns
45
- -------
46
- str: Path to valid YAML file
47
-
48
- Raises
49
- ------
50
- ValueError: If file is invalid or unreadable
51
- """
52
- if value is None:
53
- return None
54
-
55
- with open(value, 'r', encoding="utf-8") as f:
56
- yaml.safe_load(f)
57
-
58
- return value
@@ -1,43 +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
-
17
- def is_debugger_attached() -> bool:
18
- """
19
- Check if a debugger is attached to the current process.
20
-
21
- Returns
22
- -------
23
- bool
24
- True if a debugger is attached, False otherwise
25
- """
26
- import sys
27
-
28
- if "debugpy" in sys.modules:
29
-
30
- import debugpy
31
-
32
- return debugpy.is_client_connected()
33
-
34
- trace_func = sys.gettrace()
35
-
36
- # The presence of a trace function and pydevd means a debugger is attached
37
- if (trace_func is not None):
38
- trace_module = getattr(trace_func, "__module__", None)
39
-
40
- if (trace_module is not None and trace_module.find("pydevd") != -1):
41
- return True
42
-
43
- return False
File without changes
@@ -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,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)
@@ -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