aiqtoolkit 1.1.0rc6__py3-none-any.whl → 1.2.0__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


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

Files changed (319) hide show
  1. aiqtoolkit-1.2.0.dist-info/METADATA +29 -0
  2. aiqtoolkit-1.2.0.dist-info/RECORD +4 -0
  3. {aiqtoolkit-1.1.0rc6.dist-info → aiqtoolkit-1.2.0.dist-info}/WHEEL +1 -1
  4. aiqtoolkit-1.2.0.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 -176
  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.0rc6.dist-info/METADATA +0 -331
  315. aiqtoolkit-1.1.0rc6.dist-info/RECORD +0 -316
  316. aiqtoolkit-1.1.0rc6.dist-info/entry_points.txt +0 -17
  317. aiqtoolkit-1.1.0rc6.dist-info/licenses/LICENSE-3rd-party.txt +0 -3686
  318. aiqtoolkit-1.1.0rc6.dist-info/licenses/LICENSE.md +0 -201
  319. aiqtoolkit-1.1.0rc6.dist-info/top_level.txt +0 -1
aiq/utils/type_utils.py DELETED
@@ -1,397 +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 collections
17
- import collections.abc
18
- import inspect
19
- import json
20
- import os
21
- import sys
22
- import types
23
- import typing
24
- from functools import lru_cache
25
- from typing import TypeAlias
26
-
27
- from pydantic import BaseModel
28
- from pydantic import Field
29
- from pydantic import create_model
30
- from pydantic_core import PydanticUndefined
31
-
32
- # Mimic the `StrPath` type alias from the `typeshed` package. We can't import it directly because it's not available at
33
- # runtime and causes problems
34
- StrPath: TypeAlias = str | os.PathLike[str]
35
-
36
- ClassInfo: TypeAlias = type | types.UnionType | tuple["ClassInfo", ...]
37
-
38
-
39
- # utility for check if string is a valid json string
40
- def is_valid_json(string):
41
- try:
42
- input_str = string.replace("'", "\"")
43
- json.loads(input_str)
44
- return True
45
- except json.JSONDecodeError:
46
- return False
47
-
48
-
49
- # A compatibility layer for typing.override decorator.
50
- # In Python >= 3.12, it uses the built-in typing.override decorator
51
- # In Python < 3.12, it acts as a no-op decorator
52
- if sys.version_info >= (3, 12):
53
- from typing import override # pylint: disable=unused-import
54
- else:
55
-
56
- def override(func):
57
- return func
58
-
59
-
60
- class DecomposedType:
61
-
62
- def __init__(self, original: type):
63
-
64
- if (inspect.Signature.empty == original):
65
- original = types.NoneType
66
-
67
- self.type = original
68
-
69
- @property
70
- @lru_cache
71
- def origin(self):
72
- """
73
- Get the origin of the current type using `typing.get_origin`. For example, if the current type is `list[int]`,
74
- the origin would be `list`.
75
-
76
- Returns
77
- -------
78
- type
79
- The origin of the current type.
80
- """
81
-
82
- return typing.get_origin(self.type)
83
-
84
- @property
85
- @lru_cache
86
- def args(self):
87
- """
88
- Get the arguments of the current type using `typing.get_args`. For example, if the current type is `list[int,
89
- str]`, the arguments would be `[int, str]`.
90
-
91
- Returns
92
- -------
93
- tuple[type]
94
- The arguments of the current type.
95
- """
96
-
97
- return typing.get_args(self.type)
98
-
99
- @property
100
- @lru_cache
101
- def root(self):
102
- """
103
- Get the root type of the current type. This is the type without any annotations or async generators.
104
-
105
- Returns
106
- -------
107
- type
108
- The root type of the current type.
109
- """
110
-
111
- return self.origin if self.origin is not None else self.type
112
-
113
- @property
114
- @lru_cache
115
- def is_empty(self):
116
- """
117
- Check if the current type is eqivalent to `NoneType`.
118
-
119
- Returns
120
- -------
121
- bool
122
- True if the current type is `NoneType`, False otherwise.
123
- """
124
- return self.type is types.NoneType
125
-
126
- @property
127
- @lru_cache
128
- def is_class(self):
129
- """
130
- Check if the current type is a class using `inspect.isclass`. For example, `list[int]` would return False, but
131
- `list` would return True.
132
-
133
- Returns
134
- -------
135
- bool
136
- True if the current type is a class, False otherwise.
137
- """
138
-
139
- return inspect.isclass(self.type)
140
-
141
- @property
142
- @lru_cache
143
- def is_generic(self):
144
- """
145
- Check if the current type is a generic using `typing.GenericMeta`. For example, `list[int]` would return True,
146
- but `list` would return False.
147
-
148
- Returns
149
- -------
150
- bool
151
- True if the current type is a generic, False otherwise.
152
- """
153
-
154
- return self.origin is not None
155
-
156
- @property
157
- @lru_cache
158
- def is_annotated(self):
159
- """
160
- Check if the current type is an annotated type using `typing.Annotated`. For example, `Annotated[int, str]`
161
- would return True, but `int` would return False.
162
-
163
- Returns
164
- -------
165
- bool
166
- True if the current type is an annotated type, False otherwise.
167
- """
168
-
169
- return self.origin is typing.Annotated
170
-
171
- @property
172
- @lru_cache
173
- def is_union(self):
174
- """
175
- Check if the current type is a union type using `typing.Union`. For example, `Union[int, str]` would return
176
- True, but `int` would return False.
177
-
178
- Returns
179
- -------
180
- bool
181
- True if the current type is a union type, False otherwise.
182
- """
183
-
184
- return self.origin in (typing.Union, types.UnionType) # pylint: disable=consider-alternative-union-syntax
185
-
186
- @property
187
- @lru_cache
188
- def is_async_generator(self):
189
- """
190
- Check if the current type is an async generator type. For example, `AsyncGenerator[int]` would return True,
191
- but `int` would return False.
192
-
193
- Returns
194
- -------
195
- bool
196
- True if the current type is an async generator type, False otherwise.
197
- """
198
-
199
- return self.origin in (
200
- typing.AsyncGenerator, # pylint: disable=consider-alternative-union-syntax,deprecated-typing-alias
201
- collections.abc.AsyncGenerator,
202
- types.AsyncGeneratorType,
203
- )
204
-
205
- @property
206
- @lru_cache
207
- def is_optional(self):
208
- """
209
- Check if the current type is an optional type. For example, `Optional[int]` and `int | None` would return True,
210
- but `int` would return False.
211
-
212
- Returns
213
- -------
214
- bool
215
- True if the current type is an optional type, False otherwise.
216
- """
217
-
218
- return self.is_union and types.NoneType in self.args
219
-
220
- @property
221
- @lru_cache
222
- def has_base_type(self):
223
- """
224
- Check if the current type has a base type, ignoring any annotations or async generators.
225
- """
226
-
227
- return self.is_annotated or self.is_async_generator
228
-
229
- def get_optional_type(self) -> "DecomposedType":
230
- """
231
- If the current type is optional, return the type that is not `NoneType`. If the current type is not optional,
232
- raise a `ValueError`.
233
-
234
- Returns
235
- -------
236
- DecomposedType
237
- The optional type that is not `NoneType`.
238
-
239
- Raises
240
- ------
241
- ValueError
242
- If the current type is not optional.
243
- ValueError
244
- If the current type is optional but has more than one argument that is not `NoneType`.
245
- """
246
-
247
- if (not self.is_optional):
248
- raise ValueError(f"Type {self.type} is not optional.")
249
-
250
- remaining_args = tuple(arg for arg in self.args if arg is not types.NoneType)
251
-
252
- if (len(remaining_args) > 1):
253
- return DecomposedType(typing.Union[remaining_args]) # pylint: disable=consider-alternative-union-syntax
254
- if (len(remaining_args) == 1):
255
- return DecomposedType(remaining_args[0])
256
-
257
- raise ValueError(f"Type {self.type} is not optional.")
258
-
259
- def get_annotated_type(self) -> "DecomposedType":
260
- """
261
- If the current type is annotated, return the annotated type. If the current type is not annotated, raise a
262
- `ValueError`.
263
-
264
- Returns
265
- -------
266
- DecomposedType
267
- The annotated type.
268
-
269
- Raises
270
- ------
271
- ValueError
272
- If the current type is not annotated.
273
- """
274
-
275
- if (not self.is_annotated):
276
- raise ValueError(f"Type {self.type} is not annotated.")
277
-
278
- return DecomposedType(self.args[0])
279
-
280
- def get_async_generator_type(self) -> "DecomposedType":
281
- """
282
- If the current type is an async generator, return the async generator type. If the current type is not an async
283
- generator, raise a `ValueError`.
284
-
285
- Returns
286
- -------
287
- DecomposedType
288
- The async generator type.
289
-
290
- Raises
291
- ------
292
- ValueError
293
- If the current type is not an async generator.
294
- """
295
-
296
- if (not self.is_async_generator):
297
- raise ValueError(f"Type {self.type} is not an async generator.")
298
-
299
- return DecomposedType(self.args[0])
300
-
301
- def get_base_type(self) -> "DecomposedType":
302
- """
303
- Returns the base type of the current type, ignoring any annotations or async generators.
304
-
305
- Returns
306
- -------
307
- DecomposedType
308
- The base type of the current type.
309
- """
310
-
311
- base_type = self
312
-
313
- while (base_type.has_base_type):
314
- if (base_type.is_annotated):
315
- base_type = base_type.get_annotated_type()
316
- elif (base_type.is_async_generator):
317
- base_type = base_type.get_async_generator_type()
318
-
319
- return base_type
320
-
321
- def is_subtype(self, class_or_tuple: ClassInfo) -> bool:
322
- """
323
- Check if the current type is a subtype of the specified class or tuple of classes similar to `issubclass`.
324
-
325
- Parameters
326
- ----------
327
- class_or_tuple : ClassInfo
328
- The class or tuple of classes to check if the current type is a subtype of.
329
-
330
- Returns
331
- -------
332
- bool
333
- True if the current type is a subtype of the specified class or tuple of classes, False otherwise
334
- """
335
-
336
- if (isinstance(class_or_tuple, tuple)):
337
- return any(issubclass(self.root, DecomposedType(cls).root) for cls in class_or_tuple)
338
-
339
- return issubclass(self.root, DecomposedType(class_or_tuple).root)
340
-
341
- def is_instance(self, instance: typing.Any) -> bool:
342
- """
343
- Check if the current type is an instance of the specified instance similar to `isinstance`.
344
-
345
- Parameters
346
- ----------
347
- instance : typing.Any
348
- The instance to check if the current type is an instance of.
349
-
350
- Returns
351
- -------
352
- bool
353
- True if the current type is an instance of the specified instance, False otherwise
354
- """
355
-
356
- return isinstance(instance, self.root)
357
-
358
- def get_pydantic_schema(self,
359
- converters: list[collections.abc.Callable] | None = None) -> type[BaseModel] | type[None]:
360
- """
361
- Get the Pydantic schema for the current type.
362
-
363
- Parameters
364
- ----------
365
- converters : list[Callable], optional
366
- A list of converters to append new converts to, by default None
367
-
368
- Returns
369
- -------
370
- type[BaseModel]
371
- The Pydantic schema for the current type.
372
- """
373
-
374
- if (converters is None):
375
- converters = []
376
-
377
- if (self.has_base_type):
378
- return self.get_base_type().get_pydantic_schema(converters=converters)
379
-
380
- if (self.type == types.NoneType):
381
- return types.NoneType
382
-
383
- if (self.is_class and issubclass(self.type, BaseModel)):
384
- return self.type
385
-
386
- schema = create_model("OutputArgsSchema", value=(self.type, Field(default=PydanticUndefined)))
387
-
388
- def _convert_to_cls(schema_in: schema) -> self.type:
389
- return schema_in.value
390
-
391
- def _convert_to_schema(cls_in: self.type) -> schema:
392
- return schema.model_validate({"value": cls_in})
393
-
394
- converters.append(_convert_to_cls)
395
- converters.append(_convert_to_schema)
396
-
397
- return schema
aiq/utils/url_utils.py DELETED
@@ -1,27 +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
-
17
- def url_join(*parts):
18
- """
19
- Functionally similar to `os.path.join` but for URLs. This function will join the parts of a URL together, ensuring
20
- that the resulting URL is valid and all `/` have been deduped.
21
-
22
- Returns
23
- -------
24
- str
25
- The joined URL.
26
- """
27
- return "/".join(str(part).strip("/") for part in parts)