nvidia-nat 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.
- aiq/__init__.py +66 -0
- nat/agent/__init__.py +0 -0
- nat/agent/base.py +265 -0
- nat/agent/dual_node.py +72 -0
- nat/agent/prompt_optimizer/__init__.py +0 -0
- nat/agent/prompt_optimizer/prompt.py +68 -0
- nat/agent/prompt_optimizer/register.py +149 -0
- nat/agent/react_agent/__init__.py +0 -0
- nat/agent/react_agent/agent.py +394 -0
- nat/agent/react_agent/output_parser.py +104 -0
- nat/agent/react_agent/prompt.py +44 -0
- nat/agent/react_agent/register.py +168 -0
- nat/agent/reasoning_agent/__init__.py +0 -0
- nat/agent/reasoning_agent/reasoning_agent.py +227 -0
- nat/agent/register.py +23 -0
- nat/agent/rewoo_agent/__init__.py +0 -0
- nat/agent/rewoo_agent/agent.py +593 -0
- nat/agent/rewoo_agent/prompt.py +107 -0
- nat/agent/rewoo_agent/register.py +175 -0
- nat/agent/tool_calling_agent/__init__.py +0 -0
- nat/agent/tool_calling_agent/agent.py +246 -0
- nat/agent/tool_calling_agent/register.py +129 -0
- nat/authentication/__init__.py +14 -0
- nat/authentication/api_key/__init__.py +14 -0
- nat/authentication/api_key/api_key_auth_provider.py +96 -0
- nat/authentication/api_key/api_key_auth_provider_config.py +124 -0
- nat/authentication/api_key/register.py +26 -0
- nat/authentication/credential_validator/__init__.py +14 -0
- nat/authentication/credential_validator/bearer_token_validator.py +557 -0
- nat/authentication/exceptions/__init__.py +14 -0
- nat/authentication/exceptions/api_key_exceptions.py +38 -0
- nat/authentication/http_basic_auth/__init__.py +0 -0
- nat/authentication/http_basic_auth/http_basic_auth_provider.py +81 -0
- nat/authentication/http_basic_auth/register.py +30 -0
- nat/authentication/interfaces.py +96 -0
- nat/authentication/oauth2/__init__.py +14 -0
- nat/authentication/oauth2/oauth2_auth_code_flow_provider.py +140 -0
- nat/authentication/oauth2/oauth2_auth_code_flow_provider_config.py +39 -0
- nat/authentication/oauth2/oauth2_resource_server_config.py +124 -0
- nat/authentication/oauth2/register.py +25 -0
- nat/authentication/register.py +20 -0
- nat/builder/__init__.py +0 -0
- nat/builder/builder.py +317 -0
- nat/builder/component_utils.py +320 -0
- nat/builder/context.py +321 -0
- nat/builder/embedder.py +24 -0
- nat/builder/eval_builder.py +166 -0
- nat/builder/evaluator.py +29 -0
- nat/builder/framework_enum.py +25 -0
- nat/builder/front_end.py +73 -0
- nat/builder/function.py +714 -0
- nat/builder/function_base.py +380 -0
- nat/builder/function_info.py +625 -0
- nat/builder/intermediate_step_manager.py +206 -0
- nat/builder/llm.py +25 -0
- nat/builder/retriever.py +25 -0
- nat/builder/user_interaction_manager.py +78 -0
- nat/builder/workflow.py +160 -0
- nat/builder/workflow_builder.py +1365 -0
- nat/cli/__init__.py +14 -0
- nat/cli/cli_utils/__init__.py +0 -0
- nat/cli/cli_utils/config_override.py +231 -0
- nat/cli/cli_utils/validation.py +37 -0
- nat/cli/commands/__init__.py +0 -0
- nat/cli/commands/configure/__init__.py +0 -0
- nat/cli/commands/configure/channel/__init__.py +0 -0
- nat/cli/commands/configure/channel/add.py +28 -0
- nat/cli/commands/configure/channel/channel.py +34 -0
- nat/cli/commands/configure/channel/remove.py +30 -0
- nat/cli/commands/configure/channel/update.py +30 -0
- nat/cli/commands/configure/configure.py +33 -0
- nat/cli/commands/evaluate.py +139 -0
- nat/cli/commands/info/__init__.py +14 -0
- nat/cli/commands/info/info.py +47 -0
- nat/cli/commands/info/list_channels.py +32 -0
- nat/cli/commands/info/list_components.py +128 -0
- nat/cli/commands/mcp/__init__.py +14 -0
- nat/cli/commands/mcp/mcp.py +986 -0
- nat/cli/commands/object_store/__init__.py +14 -0
- nat/cli/commands/object_store/object_store.py +227 -0
- nat/cli/commands/optimize.py +90 -0
- nat/cli/commands/registry/__init__.py +14 -0
- nat/cli/commands/registry/publish.py +88 -0
- nat/cli/commands/registry/pull.py +118 -0
- nat/cli/commands/registry/registry.py +36 -0
- nat/cli/commands/registry/remove.py +108 -0
- nat/cli/commands/registry/search.py +153 -0
- nat/cli/commands/sizing/__init__.py +14 -0
- nat/cli/commands/sizing/calc.py +297 -0
- nat/cli/commands/sizing/sizing.py +27 -0
- nat/cli/commands/start.py +257 -0
- nat/cli/commands/uninstall.py +81 -0
- nat/cli/commands/validate.py +47 -0
- nat/cli/commands/workflow/__init__.py +14 -0
- nat/cli/commands/workflow/templates/__init__.py.j2 +0 -0
- nat/cli/commands/workflow/templates/config.yml.j2 +17 -0
- nat/cli/commands/workflow/templates/pyproject.toml.j2 +25 -0
- nat/cli/commands/workflow/templates/register.py.j2 +4 -0
- nat/cli/commands/workflow/templates/workflow.py.j2 +50 -0
- nat/cli/commands/workflow/workflow.py +37 -0
- nat/cli/commands/workflow/workflow_commands.py +403 -0
- nat/cli/entrypoint.py +141 -0
- nat/cli/main.py +60 -0
- nat/cli/register_workflow.py +522 -0
- nat/cli/type_registry.py +1069 -0
- nat/control_flow/__init__.py +0 -0
- nat/control_flow/register.py +20 -0
- nat/control_flow/router_agent/__init__.py +0 -0
- nat/control_flow/router_agent/agent.py +329 -0
- nat/control_flow/router_agent/prompt.py +48 -0
- nat/control_flow/router_agent/register.py +91 -0
- nat/control_flow/sequential_executor.py +166 -0
- nat/data_models/__init__.py +14 -0
- nat/data_models/agent.py +34 -0
- nat/data_models/api_server.py +843 -0
- nat/data_models/authentication.py +245 -0
- nat/data_models/common.py +171 -0
- nat/data_models/component.py +60 -0
- nat/data_models/component_ref.py +179 -0
- nat/data_models/config.py +434 -0
- nat/data_models/dataset_handler.py +169 -0
- nat/data_models/discovery_metadata.py +305 -0
- nat/data_models/embedder.py +27 -0
- nat/data_models/evaluate.py +130 -0
- nat/data_models/evaluator.py +26 -0
- nat/data_models/front_end.py +26 -0
- nat/data_models/function.py +64 -0
- nat/data_models/function_dependencies.py +80 -0
- nat/data_models/gated_field_mixin.py +242 -0
- nat/data_models/interactive.py +246 -0
- nat/data_models/intermediate_step.py +302 -0
- nat/data_models/invocation_node.py +38 -0
- nat/data_models/llm.py +27 -0
- nat/data_models/logging.py +26 -0
- nat/data_models/memory.py +27 -0
- nat/data_models/object_store.py +44 -0
- nat/data_models/optimizable.py +119 -0
- nat/data_models/optimizer.py +149 -0
- nat/data_models/profiler.py +54 -0
- nat/data_models/registry_handler.py +26 -0
- nat/data_models/retriever.py +30 -0
- nat/data_models/retry_mixin.py +35 -0
- nat/data_models/span.py +228 -0
- nat/data_models/step_adaptor.py +64 -0
- nat/data_models/streaming.py +33 -0
- nat/data_models/swe_bench_model.py +54 -0
- nat/data_models/telemetry_exporter.py +26 -0
- nat/data_models/temperature_mixin.py +44 -0
- nat/data_models/thinking_mixin.py +86 -0
- nat/data_models/top_p_mixin.py +44 -0
- nat/data_models/ttc_strategy.py +30 -0
- nat/embedder/__init__.py +0 -0
- nat/embedder/azure_openai_embedder.py +46 -0
- nat/embedder/nim_embedder.py +59 -0
- nat/embedder/openai_embedder.py +42 -0
- nat/embedder/register.py +22 -0
- nat/eval/__init__.py +14 -0
- nat/eval/config.py +62 -0
- nat/eval/dataset_handler/__init__.py +0 -0
- nat/eval/dataset_handler/dataset_downloader.py +106 -0
- nat/eval/dataset_handler/dataset_filter.py +52 -0
- nat/eval/dataset_handler/dataset_handler.py +431 -0
- nat/eval/evaluate.py +565 -0
- nat/eval/evaluator/__init__.py +14 -0
- nat/eval/evaluator/base_evaluator.py +77 -0
- nat/eval/evaluator/evaluator_model.py +58 -0
- nat/eval/intermediate_step_adapter.py +99 -0
- nat/eval/rag_evaluator/__init__.py +0 -0
- nat/eval/rag_evaluator/evaluate.py +178 -0
- nat/eval/rag_evaluator/register.py +143 -0
- nat/eval/register.py +26 -0
- nat/eval/remote_workflow.py +133 -0
- nat/eval/runners/__init__.py +14 -0
- nat/eval/runners/config.py +39 -0
- nat/eval/runners/multi_eval_runner.py +54 -0
- nat/eval/runtime_evaluator/__init__.py +14 -0
- nat/eval/runtime_evaluator/evaluate.py +123 -0
- nat/eval/runtime_evaluator/register.py +100 -0
- nat/eval/runtime_event_subscriber.py +52 -0
- nat/eval/swe_bench_evaluator/__init__.py +0 -0
- nat/eval/swe_bench_evaluator/evaluate.py +215 -0
- nat/eval/swe_bench_evaluator/register.py +36 -0
- nat/eval/trajectory_evaluator/__init__.py +0 -0
- nat/eval/trajectory_evaluator/evaluate.py +75 -0
- nat/eval/trajectory_evaluator/register.py +40 -0
- nat/eval/tunable_rag_evaluator/__init__.py +0 -0
- nat/eval/tunable_rag_evaluator/evaluate.py +242 -0
- nat/eval/tunable_rag_evaluator/register.py +52 -0
- nat/eval/usage_stats.py +41 -0
- nat/eval/utils/__init__.py +0 -0
- nat/eval/utils/eval_trace_ctx.py +89 -0
- nat/eval/utils/output_uploader.py +140 -0
- nat/eval/utils/tqdm_position_registry.py +40 -0
- nat/eval/utils/weave_eval.py +193 -0
- nat/experimental/__init__.py +0 -0
- nat/experimental/decorators/__init__.py +0 -0
- nat/experimental/decorators/experimental_warning_decorator.py +154 -0
- nat/experimental/test_time_compute/__init__.py +0 -0
- nat/experimental/test_time_compute/editing/__init__.py +0 -0
- nat/experimental/test_time_compute/editing/iterative_plan_refinement_editor.py +147 -0
- nat/experimental/test_time_compute/editing/llm_as_a_judge_editor.py +204 -0
- nat/experimental/test_time_compute/editing/motivation_aware_summarization.py +107 -0
- nat/experimental/test_time_compute/functions/__init__.py +0 -0
- nat/experimental/test_time_compute/functions/execute_score_select_function.py +105 -0
- nat/experimental/test_time_compute/functions/plan_select_execute_function.py +228 -0
- nat/experimental/test_time_compute/functions/ttc_tool_orchestration_function.py +205 -0
- nat/experimental/test_time_compute/functions/ttc_tool_wrapper_function.py +146 -0
- nat/experimental/test_time_compute/models/__init__.py +0 -0
- nat/experimental/test_time_compute/models/editor_config.py +132 -0
- nat/experimental/test_time_compute/models/scoring_config.py +112 -0
- nat/experimental/test_time_compute/models/search_config.py +120 -0
- nat/experimental/test_time_compute/models/selection_config.py +154 -0
- nat/experimental/test_time_compute/models/stage_enums.py +43 -0
- nat/experimental/test_time_compute/models/strategy_base.py +67 -0
- nat/experimental/test_time_compute/models/tool_use_config.py +41 -0
- nat/experimental/test_time_compute/models/ttc_item.py +48 -0
- nat/experimental/test_time_compute/register.py +35 -0
- nat/experimental/test_time_compute/scoring/__init__.py +0 -0
- nat/experimental/test_time_compute/scoring/llm_based_agent_scorer.py +168 -0
- nat/experimental/test_time_compute/scoring/llm_based_plan_scorer.py +168 -0
- nat/experimental/test_time_compute/scoring/motivation_aware_scorer.py +111 -0
- nat/experimental/test_time_compute/search/__init__.py +0 -0
- nat/experimental/test_time_compute/search/multi_llm_planner.py +128 -0
- nat/experimental/test_time_compute/search/multi_query_retrieval_search.py +122 -0
- nat/experimental/test_time_compute/search/single_shot_multi_plan_planner.py +128 -0
- nat/experimental/test_time_compute/selection/__init__.py +0 -0
- nat/experimental/test_time_compute/selection/best_of_n_selector.py +63 -0
- nat/experimental/test_time_compute/selection/llm_based_agent_output_selector.py +131 -0
- nat/experimental/test_time_compute/selection/llm_based_output_merging_selector.py +157 -0
- nat/experimental/test_time_compute/selection/llm_based_plan_selector.py +128 -0
- nat/experimental/test_time_compute/selection/threshold_selector.py +58 -0
- nat/front_ends/__init__.py +14 -0
- nat/front_ends/console/__init__.py +14 -0
- nat/front_ends/console/authentication_flow_handler.py +285 -0
- nat/front_ends/console/console_front_end_config.py +32 -0
- nat/front_ends/console/console_front_end_plugin.py +108 -0
- nat/front_ends/console/register.py +25 -0
- nat/front_ends/cron/__init__.py +14 -0
- nat/front_ends/fastapi/__init__.py +14 -0
- nat/front_ends/fastapi/auth_flow_handlers/__init__.py +0 -0
- nat/front_ends/fastapi/auth_flow_handlers/http_flow_handler.py +27 -0
- nat/front_ends/fastapi/auth_flow_handlers/websocket_flow_handler.py +142 -0
- nat/front_ends/fastapi/dask_client_mixin.py +65 -0
- nat/front_ends/fastapi/fastapi_front_end_config.py +272 -0
- nat/front_ends/fastapi/fastapi_front_end_controller.py +68 -0
- nat/front_ends/fastapi/fastapi_front_end_plugin.py +247 -0
- nat/front_ends/fastapi/fastapi_front_end_plugin_worker.py +1257 -0
- nat/front_ends/fastapi/html_snippets/__init__.py +14 -0
- nat/front_ends/fastapi/html_snippets/auth_code_grant_success.py +35 -0
- nat/front_ends/fastapi/intermediate_steps_subscriber.py +80 -0
- nat/front_ends/fastapi/job_store.py +602 -0
- nat/front_ends/fastapi/main.py +64 -0
- nat/front_ends/fastapi/message_handler.py +344 -0
- nat/front_ends/fastapi/message_validator.py +351 -0
- nat/front_ends/fastapi/register.py +25 -0
- nat/front_ends/fastapi/response_helpers.py +195 -0
- nat/front_ends/fastapi/step_adaptor.py +319 -0
- nat/front_ends/fastapi/utils.py +57 -0
- nat/front_ends/mcp/__init__.py +14 -0
- nat/front_ends/mcp/introspection_token_verifier.py +73 -0
- nat/front_ends/mcp/mcp_front_end_config.py +90 -0
- nat/front_ends/mcp/mcp_front_end_plugin.py +113 -0
- nat/front_ends/mcp/mcp_front_end_plugin_worker.py +268 -0
- nat/front_ends/mcp/memory_profiler.py +320 -0
- nat/front_ends/mcp/register.py +27 -0
- nat/front_ends/mcp/tool_converter.py +290 -0
- nat/front_ends/register.py +21 -0
- nat/front_ends/simple_base/__init__.py +14 -0
- nat/front_ends/simple_base/simple_front_end_plugin_base.py +56 -0
- nat/llm/__init__.py +0 -0
- nat/llm/aws_bedrock_llm.py +69 -0
- nat/llm/azure_openai_llm.py +57 -0
- nat/llm/litellm_llm.py +69 -0
- nat/llm/nim_llm.py +58 -0
- nat/llm/openai_llm.py +54 -0
- nat/llm/register.py +27 -0
- nat/llm/utils/__init__.py +14 -0
- nat/llm/utils/env_config_value.py +93 -0
- nat/llm/utils/error.py +17 -0
- nat/llm/utils/thinking.py +215 -0
- nat/memory/__init__.py +20 -0
- nat/memory/interfaces.py +183 -0
- nat/memory/models.py +112 -0
- nat/meta/pypi.md +58 -0
- nat/object_store/__init__.py +20 -0
- nat/object_store/in_memory_object_store.py +76 -0
- nat/object_store/interfaces.py +84 -0
- nat/object_store/models.py +38 -0
- nat/object_store/register.py +19 -0
- nat/observability/__init__.py +14 -0
- nat/observability/exporter/__init__.py +14 -0
- nat/observability/exporter/base_exporter.py +449 -0
- nat/observability/exporter/exporter.py +78 -0
- nat/observability/exporter/file_exporter.py +33 -0
- nat/observability/exporter/processing_exporter.py +550 -0
- nat/observability/exporter/raw_exporter.py +52 -0
- nat/observability/exporter/span_exporter.py +308 -0
- nat/observability/exporter_manager.py +335 -0
- nat/observability/mixin/__init__.py +14 -0
- nat/observability/mixin/batch_config_mixin.py +26 -0
- nat/observability/mixin/collector_config_mixin.py +23 -0
- nat/observability/mixin/file_mixin.py +288 -0
- nat/observability/mixin/file_mode.py +23 -0
- nat/observability/mixin/redaction_config_mixin.py +42 -0
- nat/observability/mixin/resource_conflict_mixin.py +134 -0
- nat/observability/mixin/serialize_mixin.py +61 -0
- nat/observability/mixin/tagging_config_mixin.py +62 -0
- nat/observability/mixin/type_introspection_mixin.py +496 -0
- nat/observability/processor/__init__.py +14 -0
- nat/observability/processor/batching_processor.py +308 -0
- nat/observability/processor/callback_processor.py +42 -0
- nat/observability/processor/falsy_batch_filter_processor.py +55 -0
- nat/observability/processor/intermediate_step_serializer.py +28 -0
- nat/observability/processor/processor.py +74 -0
- nat/observability/processor/processor_factory.py +70 -0
- nat/observability/processor/redaction/__init__.py +24 -0
- nat/observability/processor/redaction/contextual_redaction_processor.py +125 -0
- nat/observability/processor/redaction/contextual_span_redaction_processor.py +66 -0
- nat/observability/processor/redaction/redaction_processor.py +177 -0
- nat/observability/processor/redaction/span_header_redaction_processor.py +92 -0
- nat/observability/processor/span_tagging_processor.py +68 -0
- nat/observability/register.py +114 -0
- nat/observability/utils/__init__.py +14 -0
- nat/observability/utils/dict_utils.py +236 -0
- nat/observability/utils/time_utils.py +31 -0
- nat/plugins/.namespace +1 -0
- nat/profiler/__init__.py +0 -0
- nat/profiler/calc/__init__.py +14 -0
- nat/profiler/calc/calc_runner.py +626 -0
- nat/profiler/calc/calculations.py +288 -0
- nat/profiler/calc/data_models.py +188 -0
- nat/profiler/calc/plot.py +345 -0
- nat/profiler/callbacks/__init__.py +0 -0
- nat/profiler/callbacks/agno_callback_handler.py +295 -0
- nat/profiler/callbacks/base_callback_class.py +20 -0
- nat/profiler/callbacks/langchain_callback_handler.py +297 -0
- nat/profiler/callbacks/llama_index_callback_handler.py +205 -0
- nat/profiler/callbacks/semantic_kernel_callback_handler.py +238 -0
- nat/profiler/callbacks/token_usage_base_model.py +27 -0
- nat/profiler/data_frame_row.py +51 -0
- nat/profiler/data_models.py +24 -0
- nat/profiler/decorators/__init__.py +0 -0
- nat/profiler/decorators/framework_wrapper.py +180 -0
- nat/profiler/decorators/function_tracking.py +411 -0
- nat/profiler/forecasting/__init__.py +0 -0
- nat/profiler/forecasting/config.py +18 -0
- nat/profiler/forecasting/model_trainer.py +75 -0
- nat/profiler/forecasting/models/__init__.py +22 -0
- nat/profiler/forecasting/models/forecasting_base_model.py +42 -0
- nat/profiler/forecasting/models/linear_model.py +197 -0
- nat/profiler/forecasting/models/random_forest_regressor.py +269 -0
- nat/profiler/inference_metrics_model.py +28 -0
- nat/profiler/inference_optimization/__init__.py +0 -0
- nat/profiler/inference_optimization/bottleneck_analysis/__init__.py +0 -0
- nat/profiler/inference_optimization/bottleneck_analysis/nested_stack_analysis.py +460 -0
- nat/profiler/inference_optimization/bottleneck_analysis/simple_stack_analysis.py +258 -0
- nat/profiler/inference_optimization/data_models.py +386 -0
- nat/profiler/inference_optimization/experimental/__init__.py +0 -0
- nat/profiler/inference_optimization/experimental/concurrency_spike_analysis.py +468 -0
- nat/profiler/inference_optimization/experimental/prefix_span_analysis.py +404 -0
- nat/profiler/inference_optimization/llm_metrics.py +212 -0
- nat/profiler/inference_optimization/prompt_caching.py +163 -0
- nat/profiler/inference_optimization/token_uniqueness.py +107 -0
- nat/profiler/inference_optimization/workflow_runtimes.py +72 -0
- nat/profiler/intermediate_property_adapter.py +102 -0
- nat/profiler/parameter_optimization/__init__.py +0 -0
- nat/profiler/parameter_optimization/optimizable_utils.py +93 -0
- nat/profiler/parameter_optimization/optimizer_runtime.py +67 -0
- nat/profiler/parameter_optimization/parameter_optimizer.py +153 -0
- nat/profiler/parameter_optimization/parameter_selection.py +107 -0
- nat/profiler/parameter_optimization/pareto_visualizer.py +380 -0
- nat/profiler/parameter_optimization/prompt_optimizer.py +384 -0
- nat/profiler/parameter_optimization/update_helpers.py +66 -0
- nat/profiler/profile_runner.py +478 -0
- nat/profiler/utils.py +186 -0
- nat/registry_handlers/__init__.py +0 -0
- nat/registry_handlers/local/__init__.py +0 -0
- nat/registry_handlers/local/local_handler.py +176 -0
- nat/registry_handlers/local/register_local.py +37 -0
- nat/registry_handlers/metadata_factory.py +60 -0
- nat/registry_handlers/package_utils.py +570 -0
- nat/registry_handlers/pypi/__init__.py +0 -0
- nat/registry_handlers/pypi/pypi_handler.py +248 -0
- nat/registry_handlers/pypi/register_pypi.py +40 -0
- nat/registry_handlers/register.py +20 -0
- nat/registry_handlers/registry_handler_base.py +157 -0
- nat/registry_handlers/rest/__init__.py +0 -0
- nat/registry_handlers/rest/register_rest.py +56 -0
- nat/registry_handlers/rest/rest_handler.py +236 -0
- nat/registry_handlers/schemas/__init__.py +0 -0
- nat/registry_handlers/schemas/headers.py +42 -0
- nat/registry_handlers/schemas/package.py +68 -0
- nat/registry_handlers/schemas/publish.py +68 -0
- nat/registry_handlers/schemas/pull.py +82 -0
- nat/registry_handlers/schemas/remove.py +36 -0
- nat/registry_handlers/schemas/search.py +91 -0
- nat/registry_handlers/schemas/status.py +47 -0
- nat/retriever/__init__.py +0 -0
- nat/retriever/interface.py +41 -0
- nat/retriever/milvus/__init__.py +14 -0
- nat/retriever/milvus/register.py +81 -0
- nat/retriever/milvus/retriever.py +228 -0
- nat/retriever/models.py +77 -0
- nat/retriever/nemo_retriever/__init__.py +14 -0
- nat/retriever/nemo_retriever/register.py +60 -0
- nat/retriever/nemo_retriever/retriever.py +190 -0
- nat/retriever/register.py +21 -0
- nat/runtime/__init__.py +14 -0
- nat/runtime/loader.py +220 -0
- nat/runtime/runner.py +292 -0
- nat/runtime/session.py +223 -0
- nat/runtime/user_metadata.py +130 -0
- nat/settings/__init__.py +0 -0
- nat/settings/global_settings.py +329 -0
- nat/test/.namespace +1 -0
- nat/tool/__init__.py +0 -0
- nat/tool/chat_completion.py +77 -0
- nat/tool/code_execution/README.md +151 -0
- nat/tool/code_execution/__init__.py +0 -0
- nat/tool/code_execution/code_sandbox.py +267 -0
- nat/tool/code_execution/local_sandbox/.gitignore +1 -0
- nat/tool/code_execution/local_sandbox/Dockerfile.sandbox +60 -0
- nat/tool/code_execution/local_sandbox/__init__.py +13 -0
- nat/tool/code_execution/local_sandbox/local_sandbox_server.py +198 -0
- nat/tool/code_execution/local_sandbox/sandbox.requirements.txt +6 -0
- nat/tool/code_execution/local_sandbox/start_local_sandbox.sh +50 -0
- nat/tool/code_execution/register.py +74 -0
- nat/tool/code_execution/test_code_execution_sandbox.py +414 -0
- nat/tool/code_execution/utils.py +100 -0
- nat/tool/datetime_tools.py +82 -0
- nat/tool/document_search.py +141 -0
- nat/tool/github_tools.py +450 -0
- nat/tool/memory_tools/__init__.py +0 -0
- nat/tool/memory_tools/add_memory_tool.py +79 -0
- nat/tool/memory_tools/delete_memory_tool.py +66 -0
- nat/tool/memory_tools/get_memory_tool.py +72 -0
- nat/tool/nvidia_rag.py +95 -0
- nat/tool/register.py +31 -0
- nat/tool/retriever.py +95 -0
- nat/tool/server_tools.py +66 -0
- nat/utils/__init__.py +0 -0
- nat/utils/callable_utils.py +70 -0
- nat/utils/data_models/__init__.py +0 -0
- nat/utils/data_models/schema_validator.py +58 -0
- nat/utils/debugging_utils.py +43 -0
- nat/utils/decorators.py +210 -0
- nat/utils/dump_distro_mapping.py +32 -0
- nat/utils/exception_handlers/__init__.py +0 -0
- nat/utils/exception_handlers/automatic_retries.py +342 -0
- nat/utils/exception_handlers/schemas.py +114 -0
- nat/utils/io/__init__.py +0 -0
- nat/utils/io/model_processing.py +28 -0
- nat/utils/io/yaml_tools.py +119 -0
- nat/utils/log_levels.py +25 -0
- nat/utils/log_utils.py +37 -0
- nat/utils/metadata_utils.py +74 -0
- nat/utils/optional_imports.py +142 -0
- nat/utils/producer_consumer_queue.py +178 -0
- nat/utils/reactive/__init__.py +0 -0
- nat/utils/reactive/base/__init__.py +0 -0
- nat/utils/reactive/base/observable_base.py +65 -0
- nat/utils/reactive/base/observer_base.py +55 -0
- nat/utils/reactive/base/subject_base.py +79 -0
- nat/utils/reactive/observable.py +59 -0
- nat/utils/reactive/observer.py +76 -0
- nat/utils/reactive/subject.py +131 -0
- nat/utils/reactive/subscription.py +49 -0
- nat/utils/settings/__init__.py +0 -0
- nat/utils/settings/global_settings.py +195 -0
- nat/utils/string_utils.py +38 -0
- nat/utils/type_converter.py +299 -0
- nat/utils/type_utils.py +488 -0
- nat/utils/url_utils.py +27 -0
- nvidia_nat-1.1.0a20251020.dist-info/METADATA +195 -0
- nvidia_nat-1.1.0a20251020.dist-info/RECORD +480 -0
- nvidia_nat-1.1.0a20251020.dist-info/WHEEL +5 -0
- nvidia_nat-1.1.0a20251020.dist-info/entry_points.txt +22 -0
- nvidia_nat-1.1.0a20251020.dist-info/licenses/LICENSE-3rd-party.txt +5478 -0
- nvidia_nat-1.1.0a20251020.dist-info/licenses/LICENSE.md +201 -0
- nvidia_nat-1.1.0a20251020.dist-info/top_level.txt +2 -0
|
@@ -0,0 +1,66 @@
|
|
|
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
|
+
from pydantic import Field
|
|
19
|
+
|
|
20
|
+
from nat.builder.builder import Builder
|
|
21
|
+
from nat.builder.function_info import FunctionInfo
|
|
22
|
+
from nat.cli.register_workflow import register_function
|
|
23
|
+
from nat.data_models.component_ref import MemoryRef
|
|
24
|
+
from nat.data_models.function import FunctionBaseConfig
|
|
25
|
+
from nat.memory.models import DeleteMemoryInput
|
|
26
|
+
|
|
27
|
+
logger = logging.getLogger(__name__)
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
class DeleteToolConfig(FunctionBaseConfig, name="delete_memory"):
|
|
31
|
+
"""Function to delete memory from a hosted memory platform."""
|
|
32
|
+
|
|
33
|
+
description: str = Field(default="Tool to delete a memory from a hosted memory platform.",
|
|
34
|
+
description="The description of this function's use for tool calling agents.")
|
|
35
|
+
memory: MemoryRef = Field(default=MemoryRef("saas_memory"),
|
|
36
|
+
description=("Instance name of the memory client instance from the workflow "
|
|
37
|
+
"configuration object."))
|
|
38
|
+
|
|
39
|
+
|
|
40
|
+
@register_function(config_type=DeleteToolConfig)
|
|
41
|
+
async def delete_memory_tool(config: DeleteToolConfig, builder: Builder):
|
|
42
|
+
"""
|
|
43
|
+
Function to delete memory from a hosted memory platform.
|
|
44
|
+
"""
|
|
45
|
+
|
|
46
|
+
from langchain_core.tools import ToolException
|
|
47
|
+
|
|
48
|
+
# First, retrieve the memory client
|
|
49
|
+
memory_editor = await builder.get_memory_client(config.memory)
|
|
50
|
+
|
|
51
|
+
async def _arun(user_id: str) -> str:
|
|
52
|
+
"""
|
|
53
|
+
Asynchronous execution of deletion of memories.
|
|
54
|
+
"""
|
|
55
|
+
|
|
56
|
+
try:
|
|
57
|
+
|
|
58
|
+
await memory_editor.remove_items(user_id=user_id, )
|
|
59
|
+
|
|
60
|
+
return "Memories deleted!"
|
|
61
|
+
|
|
62
|
+
except Exception as e:
|
|
63
|
+
|
|
64
|
+
raise ToolException(f"Error deleting memory: {e}") from e
|
|
65
|
+
|
|
66
|
+
yield FunctionInfo.from_fn(_arun, description=config.description, input_schema=DeleteMemoryInput)
|
|
@@ -0,0 +1,72 @@
|
|
|
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
|
+
from pydantic import Field
|
|
19
|
+
|
|
20
|
+
from nat.builder.builder import Builder
|
|
21
|
+
from nat.builder.function_info import FunctionInfo
|
|
22
|
+
from nat.cli.register_workflow import register_function
|
|
23
|
+
from nat.data_models.component_ref import MemoryRef
|
|
24
|
+
from nat.data_models.function import FunctionBaseConfig
|
|
25
|
+
from nat.memory.models import SearchMemoryInput
|
|
26
|
+
|
|
27
|
+
logger = logging.getLogger(__name__)
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
class GetToolConfig(FunctionBaseConfig, name="get_memory"):
|
|
31
|
+
"""Function to get memory to a hosted memory platform."""
|
|
32
|
+
|
|
33
|
+
description: str = Field(default=("Tool to retrieve a memory about a user's "
|
|
34
|
+
"interactions to help answer questions in a personalized way."),
|
|
35
|
+
description="The description of this function's use for tool calling agents.")
|
|
36
|
+
memory: MemoryRef = Field(default=MemoryRef("saas_memory"),
|
|
37
|
+
description=("Instance name of the memory client instance from the workflow "
|
|
38
|
+
"configuration object."))
|
|
39
|
+
|
|
40
|
+
|
|
41
|
+
@register_function(config_type=GetToolConfig)
|
|
42
|
+
async def get_memory_tool(config: GetToolConfig, builder: Builder):
|
|
43
|
+
"""
|
|
44
|
+
Function to get memory to a hosted memory platform.
|
|
45
|
+
"""
|
|
46
|
+
|
|
47
|
+
import json
|
|
48
|
+
|
|
49
|
+
from langchain_core.tools import ToolException
|
|
50
|
+
|
|
51
|
+
# First, retrieve the memory client
|
|
52
|
+
memory_editor = await builder.get_memory_client(config.memory)
|
|
53
|
+
|
|
54
|
+
async def _arun(search_input: SearchMemoryInput) -> str:
|
|
55
|
+
"""
|
|
56
|
+
Asynchronous execution of collection of memories.
|
|
57
|
+
"""
|
|
58
|
+
try:
|
|
59
|
+
memories = await memory_editor.search(
|
|
60
|
+
query=search_input.query,
|
|
61
|
+
top_k=search_input.top_k,
|
|
62
|
+
user_id=search_input.user_id,
|
|
63
|
+
)
|
|
64
|
+
|
|
65
|
+
memory_str = f"Memories as a JSON: \n{json.dumps([mem.model_dump(mode='json') for mem in memories])}"
|
|
66
|
+
return memory_str
|
|
67
|
+
|
|
68
|
+
except Exception as e:
|
|
69
|
+
|
|
70
|
+
raise ToolException(f"Error retrieving memory: {e}") from e
|
|
71
|
+
|
|
72
|
+
yield FunctionInfo.from_fn(_arun, description=config.description)
|
nat/tool/nvidia_rag.py
ADDED
|
@@ -0,0 +1,95 @@
|
|
|
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 json
|
|
17
|
+
import logging
|
|
18
|
+
|
|
19
|
+
from pydantic import Field
|
|
20
|
+
|
|
21
|
+
from nat.builder.builder import Builder
|
|
22
|
+
from nat.builder.function_info import FunctionInfo
|
|
23
|
+
from nat.cli.register_workflow import register_function
|
|
24
|
+
from nat.data_models.function import FunctionBaseConfig
|
|
25
|
+
|
|
26
|
+
logger = logging.getLogger(__name__)
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
class NVIDIARAGToolConfig(FunctionBaseConfig, name="nvidia_rag"):
|
|
30
|
+
"""
|
|
31
|
+
Tool used to search the NVIDIA Developer database for documents across a variety of NVIDIA asset types.
|
|
32
|
+
"""
|
|
33
|
+
base_url: str = Field(description="The base url to the RAG service.")
|
|
34
|
+
timeout: int = Field(default=60, description="The timeout configuration to use when sending requests.")
|
|
35
|
+
document_separator: str = Field(default="\n\n", description="The delimiter to use between retrieved documents.")
|
|
36
|
+
document_prompt: str = Field(default=("-------\n\n" + "Title: {document_title}\n"
|
|
37
|
+
"Text: {page_content}\nSource URL: {document_url}"),
|
|
38
|
+
description="The prompt to use to retrieve documents from the RAG service")
|
|
39
|
+
top_k: int = Field(default=4, description="The number of results to return from the RAG service.")
|
|
40
|
+
collection_name: str = Field(default="nvidia_api_catalog",
|
|
41
|
+
description=("The name of the collection to use when retrieving documents."))
|
|
42
|
+
|
|
43
|
+
|
|
44
|
+
@register_function(config_type=NVIDIARAGToolConfig)
|
|
45
|
+
async def nvidia_rag_tool(config: NVIDIARAGToolConfig, builder: Builder):
|
|
46
|
+
import httpx
|
|
47
|
+
from langchain.prompts import PromptTemplate
|
|
48
|
+
from langchain_core.documents import Document
|
|
49
|
+
from langchain_core.prompts import aformat_document
|
|
50
|
+
|
|
51
|
+
document_prompt = PromptTemplate.from_template(config.document_prompt)
|
|
52
|
+
|
|
53
|
+
async with httpx.AsyncClient(headers={
|
|
54
|
+
"accept": "application/json", "Content-Type": "application/json"
|
|
55
|
+
},
|
|
56
|
+
timeout=config.timeout) as client:
|
|
57
|
+
|
|
58
|
+
async def runnable(query: str) -> str:
|
|
59
|
+
|
|
60
|
+
try:
|
|
61
|
+
url = f"{config.base_url}/search"
|
|
62
|
+
|
|
63
|
+
payload = {"query": query, "top_k": config.top_k, "collection_name": config.collection_name}
|
|
64
|
+
|
|
65
|
+
logger.debug("Sending request to the RAG endpoint %s.", url)
|
|
66
|
+
response = await client.post(url, content=json.dumps(payload))
|
|
67
|
+
|
|
68
|
+
response.raise_for_status()
|
|
69
|
+
|
|
70
|
+
output = response.json()
|
|
71
|
+
|
|
72
|
+
docs = [
|
|
73
|
+
Document(
|
|
74
|
+
page_content=ret["content"],
|
|
75
|
+
metadata={
|
|
76
|
+
"document_title": ret["filename"],
|
|
77
|
+
"document_url": "nemo_framework",
|
|
78
|
+
"document_full_text": ret["content"],
|
|
79
|
+
"score_rerank": ret["score"]
|
|
80
|
+
},
|
|
81
|
+
type="Document",
|
|
82
|
+
) for ret in output["chunks"]
|
|
83
|
+
]
|
|
84
|
+
|
|
85
|
+
parsed_output = config.document_separator.join(
|
|
86
|
+
[await aformat_document(doc, document_prompt) for doc in docs])
|
|
87
|
+
return parsed_output
|
|
88
|
+
except Exception as e:
|
|
89
|
+
logger.exception("Error while running the tool")
|
|
90
|
+
return f"Error while running the tool: {e}"
|
|
91
|
+
|
|
92
|
+
yield FunctionInfo.from_fn(
|
|
93
|
+
runnable,
|
|
94
|
+
description=("Search the NVIDIA Developer database for documents across a variety of "
|
|
95
|
+
"NVIDIA asset types"))
|
nat/tool/register.py
ADDED
|
@@ -0,0 +1,31 @@
|
|
|
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
|
+
# flake8: noqa
|
|
17
|
+
|
|
18
|
+
# Import any tools which need to be automatically registered here
|
|
19
|
+
from . import chat_completion
|
|
20
|
+
from . import datetime_tools
|
|
21
|
+
from . import document_search
|
|
22
|
+
from . import github_tools
|
|
23
|
+
from . import nvidia_rag
|
|
24
|
+
from . import retriever
|
|
25
|
+
from . import server_tools
|
|
26
|
+
from .code_execution import register
|
|
27
|
+
from .github_tools import github_tool
|
|
28
|
+
from .github_tools import github_files_tool
|
|
29
|
+
from .memory_tools import add_memory_tool
|
|
30
|
+
from .memory_tools import delete_memory_tool
|
|
31
|
+
from .memory_tools import get_memory_tool
|
nat/tool/retriever.py
ADDED
|
@@ -0,0 +1,95 @@
|
|
|
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 nat.builder.builder import Builder
|
|
22
|
+
from nat.builder.function_info import FunctionInfo
|
|
23
|
+
from nat.cli.register_workflow import register_function
|
|
24
|
+
from nat.data_models.component_ref import RetrieverRef
|
|
25
|
+
from nat.data_models.function import FunctionBaseConfig
|
|
26
|
+
from nat.retriever.interface import Retriever
|
|
27
|
+
from nat.retriever.models import RetrieverError
|
|
28
|
+
from nat.retriever.models import RetrieverOutput
|
|
29
|
+
|
|
30
|
+
logger = logging.getLogger(__name__)
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
class RetrieverConfig(FunctionBaseConfig, name="nat_retriever"):
|
|
34
|
+
"""
|
|
35
|
+
Retriever 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: RetrieverConfig) -> 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=RetrieverConfig)
|
|
59
|
+
async def retriever_tool(config: RetrieverConfig, builder: Builder):
|
|
60
|
+
"""
|
|
61
|
+
Configure a NAT 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: Retriever = 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
|
+
logger.error("Retriever threw an error: %s.", e)
|
|
82
|
+
raise
|
|
83
|
+
logger.exception("Retriever threw an error: %s. Returning an empty response.", e)
|
|
84
|
+
return RetrieverOutput(results=[])
|
|
85
|
+
|
|
86
|
+
yield FunctionInfo.from_fn(
|
|
87
|
+
fn=_retrieve,
|
|
88
|
+
input_schema=RetrieverInputSchema,
|
|
89
|
+
description=_get_description_from_config(config),
|
|
90
|
+
)
|
|
91
|
+
|
|
92
|
+
|
|
93
|
+
# Compatibility aliases with previous releases
|
|
94
|
+
AIQRetrieverConfig = RetrieverConfig
|
|
95
|
+
aiq_retriever_tool = retriever_tool
|
nat/tool/server_tools.py
ADDED
|
@@ -0,0 +1,66 @@
|
|
|
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 nat.builder.builder import Builder
|
|
17
|
+
from nat.builder.function_info import FunctionInfo
|
|
18
|
+
from nat.cli.register_workflow import register_function
|
|
19
|
+
from nat.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/getting_started/simple_web_query/configs/config-metadata.yml' directory to see how to define a
|
|
27
|
+
custom route using a 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 nat.builder.context import Context
|
|
41
|
+
nat_context = Context.get()
|
|
42
|
+
|
|
43
|
+
method: str | None = nat_context.metadata.method
|
|
44
|
+
url_path: str | None = nat_context.metadata.url_path
|
|
45
|
+
url_scheme: str | None = nat_context.metadata.url_scheme
|
|
46
|
+
headers: Headers | None = nat_context.metadata.headers
|
|
47
|
+
query_params: QueryParams | None = nat_context.metadata.query_params
|
|
48
|
+
path_params: dict[str, str] | None = nat_context.metadata.path_params
|
|
49
|
+
client_host: str | None = nat_context.metadata.client_host
|
|
50
|
+
client_port: int | None = nat_context.metadata.client_port
|
|
51
|
+
cookies: dict[str, str] | None = nat_context.metadata.cookies
|
|
52
|
+
conversation_id: str | None = nat_context.conversation_id
|
|
53
|
+
|
|
54
|
+
return (f"Method: {method}, "
|
|
55
|
+
f"URL Path: {url_path}, "
|
|
56
|
+
f"URL Scheme: {url_scheme}, "
|
|
57
|
+
f"Headers: {dict(headers) if headers is not None else 'None'}, "
|
|
58
|
+
f"Query Params: {dict(query_params) if query_params is not None else 'None'}, "
|
|
59
|
+
f"Path Params: {path_params}, "
|
|
60
|
+
f"Client Host: {client_host}, "
|
|
61
|
+
f"Client Port: {client_port}, "
|
|
62
|
+
f"Cookies: {cookies}, "
|
|
63
|
+
f"Conversation Id: {conversation_id}")
|
|
64
|
+
|
|
65
|
+
yield FunctionInfo.from_fn(_get_request_attributes,
|
|
66
|
+
description="Returns the acquired user defined request attributes.")
|
nat/utils/__init__.py
ADDED
|
File without changes
|
|
@@ -0,0 +1,70 @@
|
|
|
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 inspect
|
|
17
|
+
from collections.abc import Callable
|
|
18
|
+
from typing import Any
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
async def ainvoke_any(func: Callable[..., Any], *args: Any, **kwargs: Any) -> Any:
|
|
22
|
+
"""Execute any type of callable and return the result.
|
|
23
|
+
|
|
24
|
+
Handles synchronous functions, asynchronous functions, generators,
|
|
25
|
+
and async generators uniformly, returning the final result value.
|
|
26
|
+
|
|
27
|
+
Args:
|
|
28
|
+
func (Callable[..., Any]): The function to execute (sync/async function, generator, etc.)
|
|
29
|
+
|
|
30
|
+
Returns:
|
|
31
|
+
Any: The result of executing the callable
|
|
32
|
+
"""
|
|
33
|
+
# Execute the function
|
|
34
|
+
result_value = func(*args, **kwargs)
|
|
35
|
+
|
|
36
|
+
# Handle different return types
|
|
37
|
+
if inspect.iscoroutine(result_value):
|
|
38
|
+
# Async function - await the coroutine
|
|
39
|
+
return await result_value
|
|
40
|
+
|
|
41
|
+
if inspect.isgenerator(result_value):
|
|
42
|
+
# Sync generator - consume until StopIteration and get return value
|
|
43
|
+
try:
|
|
44
|
+
while True:
|
|
45
|
+
next(result_value)
|
|
46
|
+
except StopIteration as e:
|
|
47
|
+
# Return the generator's return value, or None if not provided
|
|
48
|
+
return e.value
|
|
49
|
+
|
|
50
|
+
if inspect.isasyncgen(result_value):
|
|
51
|
+
# Async generator - consume all values and return the last one
|
|
52
|
+
last_value = None
|
|
53
|
+
async for value in result_value:
|
|
54
|
+
last_value = value
|
|
55
|
+
return last_value
|
|
56
|
+
|
|
57
|
+
# Direct value from sync function (most common case)
|
|
58
|
+
return result_value
|
|
59
|
+
|
|
60
|
+
|
|
61
|
+
def is_async_callable(func: Callable[..., Any]) -> bool:
|
|
62
|
+
"""Check if a function is async (coroutine function or async generator function).
|
|
63
|
+
|
|
64
|
+
Args:
|
|
65
|
+
func (Callable[..., Any]): The function to check
|
|
66
|
+
|
|
67
|
+
Returns:
|
|
68
|
+
bool: True if the function is async, False otherwise
|
|
69
|
+
"""
|
|
70
|
+
return inspect.iscoroutinefunction(func) or inspect.isasyncgenfunction(func)
|
|
File without changes
|
|
@@ -0,0 +1,58 @@
|
|
|
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):
|
|
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):
|
|
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, encoding="utf-8") as f:
|
|
56
|
+
yaml.safe_load(f)
|
|
57
|
+
|
|
58
|
+
return value
|
|
@@ -0,0 +1,43 @@
|
|
|
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
|