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