nvidia-nat 1.4.0a20251120__py3-none-any.whl → 1.4.0a20260113__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 +1 -1
- nat/{front_ends/mcp → agent/auto_memory_wrapper}/__init__.py +1 -1
- nat/agent/auto_memory_wrapper/agent.py +278 -0
- nat/agent/auto_memory_wrapper/register.py +227 -0
- nat/agent/auto_memory_wrapper/state.py +30 -0
- nat/agent/base.py +1 -1
- nat/agent/dual_node.py +1 -1
- nat/agent/prompt_optimizer/prompt.py +1 -1
- nat/agent/prompt_optimizer/register.py +1 -1
- nat/agent/react_agent/agent.py +16 -9
- nat/agent/react_agent/output_parser.py +2 -2
- nat/agent/react_agent/prompt.py +3 -2
- nat/agent/react_agent/register.py +2 -2
- nat/agent/react_agent/register_per_user_agent.py +104 -0
- nat/agent/reasoning_agent/reasoning_agent.py +1 -1
- nat/agent/register.py +3 -1
- nat/agent/responses_api_agent/__init__.py +1 -1
- nat/agent/responses_api_agent/register.py +1 -1
- nat/agent/rewoo_agent/agent.py +9 -4
- nat/agent/rewoo_agent/prompt.py +1 -1
- nat/agent/rewoo_agent/register.py +1 -1
- nat/agent/tool_calling_agent/agent.py +5 -4
- nat/agent/tool_calling_agent/register.py +1 -1
- nat/authentication/__init__.py +1 -1
- nat/authentication/api_key/__init__.py +1 -1
- nat/authentication/api_key/api_key_auth_provider.py +1 -1
- nat/authentication/api_key/api_key_auth_provider_config.py +22 -7
- nat/authentication/api_key/register.py +1 -1
- nat/authentication/credential_validator/__init__.py +1 -1
- nat/authentication/credential_validator/bearer_token_validator.py +1 -1
- nat/authentication/exceptions/__init__.py +1 -1
- nat/authentication/exceptions/api_key_exceptions.py +1 -1
- nat/authentication/http_basic_auth/http_basic_auth_provider.py +1 -1
- nat/authentication/http_basic_auth/register.py +1 -1
- nat/authentication/interfaces.py +1 -1
- nat/authentication/oauth2/__init__.py +1 -1
- nat/authentication/oauth2/oauth2_auth_code_flow_provider.py +1 -1
- nat/authentication/oauth2/oauth2_auth_code_flow_provider_config.py +1 -1
- nat/authentication/oauth2/oauth2_resource_server_config.py +1 -1
- nat/authentication/oauth2/register.py +1 -1
- nat/authentication/register.py +1 -1
- nat/builder/builder.py +511 -1
- nat/builder/child_builder.py +385 -0
- nat/builder/component_utils.py +28 -4
- nat/builder/context.py +17 -1
- nat/builder/embedder.py +1 -1
- nat/builder/eval_builder.py +19 -7
- nat/builder/evaluator.py +1 -1
- nat/builder/framework_enum.py +2 -1
- nat/builder/front_end.py +1 -1
- nat/builder/function.py +40 -3
- nat/builder/function_base.py +1 -1
- nat/builder/function_info.py +1 -1
- nat/builder/intermediate_step_manager.py +1 -1
- nat/builder/llm.py +1 -1
- nat/builder/per_user_workflow_builder.py +843 -0
- nat/builder/retriever.py +1 -1
- nat/builder/sync_builder.py +571 -0
- nat/builder/user_interaction_manager.py +1 -1
- nat/builder/workflow.py +1 -1
- nat/builder/workflow_builder.py +536 -424
- nat/cli/__init__.py +1 -1
- nat/cli/cli_utils/config_override.py +1 -1
- nat/cli/cli_utils/validation.py +32 -1
- nat/cli/commands/configure/channel/add.py +1 -1
- nat/cli/commands/configure/channel/channel.py +1 -1
- nat/cli/commands/configure/channel/remove.py +1 -1
- nat/cli/commands/configure/channel/update.py +1 -1
- nat/cli/commands/configure/configure.py +1 -1
- nat/cli/commands/evaluate.py +87 -13
- nat/cli/commands/finetune.py +132 -0
- nat/cli/commands/info/__init__.py +1 -1
- nat/cli/commands/info/info.py +1 -1
- nat/cli/commands/info/list_channels.py +1 -1
- nat/cli/commands/info/list_components.py +1 -1
- nat/cli/commands/object_store/__init__.py +1 -1
- nat/cli/commands/object_store/object_store.py +1 -1
- nat/cli/commands/optimize.py +1 -1
- nat/cli/commands/{mcp → red_teaming}/__init__.py +1 -1
- nat/cli/commands/red_teaming/red_teaming.py +138 -0
- nat/cli/commands/red_teaming/red_teaming_utils.py +73 -0
- nat/cli/commands/registry/__init__.py +1 -1
- nat/cli/commands/registry/publish.py +1 -1
- nat/cli/commands/registry/pull.py +1 -1
- nat/cli/commands/registry/registry.py +1 -1
- nat/cli/commands/registry/remove.py +1 -1
- nat/cli/commands/registry/search.py +1 -1
- nat/cli/commands/sizing/__init__.py +1 -1
- nat/cli/commands/sizing/calc.py +1 -1
- nat/cli/commands/sizing/sizing.py +1 -1
- nat/cli/commands/start.py +1 -1
- nat/cli/commands/uninstall.py +1 -1
- nat/cli/commands/validate.py +1 -1
- nat/cli/commands/workflow/__init__.py +1 -1
- nat/cli/commands/workflow/workflow.py +1 -1
- nat/cli/commands/workflow/workflow_commands.py +3 -2
- nat/cli/entrypoint.py +15 -37
- nat/cli/main.py +2 -2
- nat/cli/plugin_loader.py +69 -0
- nat/cli/register_workflow.py +183 -5
- nat/cli/type_registry.py +169 -3
- nat/control_flow/register.py +1 -1
- nat/control_flow/router_agent/agent.py +1 -1
- nat/control_flow/router_agent/prompt.py +1 -1
- nat/control_flow/router_agent/register.py +1 -1
- nat/control_flow/sequential_executor.py +28 -7
- nat/data_models/__init__.py +1 -1
- nat/data_models/agent.py +1 -1
- nat/data_models/api_server.py +38 -3
- nat/data_models/authentication.py +1 -1
- nat/data_models/common.py +1 -1
- nat/data_models/component.py +7 -1
- nat/data_models/component_ref.py +34 -1
- nat/data_models/config.py +62 -1
- nat/data_models/dataset_handler.py +15 -2
- nat/data_models/discovery_metadata.py +1 -1
- nat/data_models/embedder.py +1 -1
- nat/data_models/evaluate.py +6 -1
- nat/data_models/evaluator.py +1 -1
- nat/data_models/finetuning.py +260 -0
- nat/data_models/front_end.py +1 -1
- nat/data_models/function.py +1 -1
- nat/data_models/function_dependencies.py +1 -1
- nat/data_models/gated_field_mixin.py +1 -1
- nat/data_models/interactive.py +1 -1
- nat/data_models/intermediate_step.py +29 -2
- nat/data_models/invocation_node.py +1 -1
- nat/data_models/llm.py +1 -1
- nat/data_models/logging.py +1 -1
- nat/data_models/memory.py +1 -1
- nat/data_models/middleware.py +3 -1
- nat/data_models/object_store.py +1 -1
- nat/data_models/openai_mcp.py +1 -1
- nat/data_models/optimizable.py +1 -1
- nat/data_models/optimizer.py +1 -1
- nat/data_models/profiler.py +1 -1
- nat/data_models/registry_handler.py +1 -1
- nat/data_models/retriever.py +1 -1
- nat/data_models/retry_mixin.py +1 -1
- nat/data_models/runtime_enum.py +1 -1
- nat/data_models/span.py +1 -1
- nat/data_models/step_adaptor.py +1 -1
- nat/data_models/streaming.py +1 -1
- nat/data_models/swe_bench_model.py +1 -1
- nat/data_models/telemetry_exporter.py +1 -1
- nat/data_models/thinking_mixin.py +1 -1
- nat/data_models/ttc_strategy.py +1 -1
- nat/embedder/azure_openai_embedder.py +1 -1
- nat/embedder/nim_embedder.py +1 -1
- nat/embedder/openai_embedder.py +1 -1
- nat/embedder/register.py +1 -1
- nat/eval/__init__.py +1 -1
- nat/eval/config.py +8 -1
- nat/eval/dataset_handler/dataset_downloader.py +1 -1
- nat/eval/dataset_handler/dataset_filter.py +1 -1
- nat/eval/dataset_handler/dataset_handler.py +4 -2
- nat/eval/evaluate.py +217 -80
- nat/eval/evaluator/__init__.py +1 -1
- nat/eval/evaluator/base_evaluator.py +2 -2
- nat/eval/evaluator/evaluator_model.py +3 -2
- nat/eval/intermediate_step_adapter.py +1 -1
- nat/eval/llm_validator.py +336 -0
- nat/eval/rag_evaluator/evaluate.py +17 -10
- nat/eval/rag_evaluator/register.py +1 -1
- nat/eval/red_teaming_evaluator/__init__.py +14 -0
- nat/eval/red_teaming_evaluator/data_models.py +66 -0
- nat/eval/red_teaming_evaluator/evaluate.py +327 -0
- nat/eval/red_teaming_evaluator/filter_conditions.py +75 -0
- nat/eval/red_teaming_evaluator/register.py +55 -0
- nat/eval/register.py +2 -1
- nat/eval/remote_workflow.py +1 -1
- nat/eval/runners/__init__.py +1 -1
- nat/eval/runners/config.py +1 -1
- nat/eval/runners/multi_eval_runner.py +1 -1
- nat/eval/runners/red_teaming_runner/__init__.py +24 -0
- nat/eval/runners/red_teaming_runner/config.py +282 -0
- nat/eval/runners/red_teaming_runner/report_utils.py +707 -0
- nat/eval/runners/red_teaming_runner/runner.py +867 -0
- nat/eval/runtime_evaluator/__init__.py +1 -1
- nat/eval/runtime_evaluator/evaluate.py +1 -1
- nat/eval/runtime_evaluator/register.py +1 -1
- nat/eval/runtime_event_subscriber.py +1 -1
- nat/eval/swe_bench_evaluator/evaluate.py +1 -1
- nat/eval/swe_bench_evaluator/register.py +1 -1
- nat/eval/trajectory_evaluator/evaluate.py +2 -2
- nat/eval/trajectory_evaluator/register.py +1 -1
- nat/eval/tunable_rag_evaluator/evaluate.py +5 -5
- nat/eval/tunable_rag_evaluator/register.py +1 -1
- nat/eval/usage_stats.py +1 -1
- nat/eval/utils/eval_trace_ctx.py +1 -1
- nat/eval/utils/output_uploader.py +1 -1
- nat/eval/utils/tqdm_position_registry.py +1 -1
- nat/eval/utils/weave_eval.py +1 -1
- nat/experimental/decorators/experimental_warning_decorator.py +1 -1
- nat/experimental/test_time_compute/editing/iterative_plan_refinement_editor.py +1 -1
- nat/experimental/test_time_compute/editing/llm_as_a_judge_editor.py +1 -1
- nat/experimental/test_time_compute/editing/motivation_aware_summarization.py +1 -1
- nat/experimental/test_time_compute/functions/execute_score_select_function.py +1 -1
- nat/experimental/test_time_compute/functions/multi_llm_judge_function.py +88 -0
- nat/experimental/test_time_compute/functions/plan_select_execute_function.py +1 -1
- nat/experimental/test_time_compute/functions/ttc_tool_orchestration_function.py +1 -1
- nat/experimental/test_time_compute/functions/ttc_tool_wrapper_function.py +1 -1
- nat/experimental/test_time_compute/models/editor_config.py +1 -1
- nat/experimental/test_time_compute/models/scoring_config.py +1 -1
- nat/experimental/test_time_compute/models/search_config.py +20 -2
- nat/experimental/test_time_compute/models/selection_config.py +33 -2
- nat/experimental/test_time_compute/models/stage_enums.py +1 -1
- nat/experimental/test_time_compute/models/strategy_base.py +1 -1
- nat/experimental/test_time_compute/models/tool_use_config.py +1 -1
- nat/experimental/test_time_compute/models/ttc_item.py +1 -1
- nat/experimental/test_time_compute/register.py +4 -1
- nat/experimental/test_time_compute/scoring/llm_based_agent_scorer.py +1 -1
- nat/experimental/test_time_compute/scoring/llm_based_plan_scorer.py +1 -1
- nat/experimental/test_time_compute/scoring/motivation_aware_scorer.py +1 -1
- nat/experimental/test_time_compute/search/multi_llm_generation.py +115 -0
- nat/experimental/test_time_compute/search/multi_llm_planner.py +1 -1
- nat/experimental/test_time_compute/search/multi_query_retrieval_search.py +1 -1
- nat/experimental/test_time_compute/search/single_shot_multi_plan_planner.py +1 -1
- nat/experimental/test_time_compute/selection/best_of_n_selector.py +1 -1
- nat/experimental/test_time_compute/selection/llm_based_agent_output_selector.py +1 -1
- nat/experimental/test_time_compute/selection/llm_based_output_merging_selector.py +1 -1
- nat/experimental/test_time_compute/selection/llm_based_plan_selector.py +1 -1
- nat/experimental/test_time_compute/selection/llm_judge_selection.py +127 -0
- nat/experimental/test_time_compute/selection/threshold_selector.py +1 -1
- nat/finetuning/__init__.py +24 -0
- nat/finetuning/finetuning_runtime.py +143 -0
- nat/finetuning/interfaces/__init__.py +24 -0
- nat/finetuning/interfaces/finetuning_runner.py +261 -0
- nat/finetuning/interfaces/trainer_adapter.py +103 -0
- nat/finetuning/interfaces/trajectory_builder.py +115 -0
- nat/finetuning/utils/__init__.py +15 -0
- nat/finetuning/utils/parsers/__init__.py +15 -0
- nat/finetuning/utils/parsers/adk_parser.py +141 -0
- nat/finetuning/utils/parsers/base_parser.py +238 -0
- nat/finetuning/utils/parsers/common.py +91 -0
- nat/finetuning/utils/parsers/langchain_parser.py +267 -0
- nat/finetuning/utils/parsers/llama_index_parser.py +218 -0
- nat/front_ends/__init__.py +1 -1
- nat/front_ends/console/__init__.py +1 -1
- nat/front_ends/console/authentication_flow_handler.py +1 -1
- nat/front_ends/console/console_front_end_config.py +4 -1
- nat/front_ends/console/console_front_end_plugin.py +5 -4
- nat/front_ends/console/register.py +1 -1
- nat/front_ends/cron/__init__.py +1 -1
- nat/front_ends/fastapi/__init__.py +1 -1
- nat/front_ends/fastapi/async_job.py +128 -0
- nat/front_ends/fastapi/auth_flow_handlers/http_flow_handler.py +1 -1
- nat/front_ends/fastapi/auth_flow_handlers/websocket_flow_handler.py +13 -9
- nat/front_ends/fastapi/dask_client_mixin.py +1 -1
- nat/front_ends/fastapi/fastapi_front_end_config.py +1 -1
- nat/front_ends/fastapi/fastapi_front_end_controller.py +1 -1
- nat/front_ends/fastapi/fastapi_front_end_plugin.py +25 -30
- nat/front_ends/fastapi/fastapi_front_end_plugin_worker.py +195 -60
- nat/front_ends/fastapi/html_snippets/__init__.py +1 -1
- nat/front_ends/fastapi/html_snippets/auth_code_grant_success.py +1 -1
- nat/front_ends/fastapi/intermediate_steps_subscriber.py +12 -1
- nat/front_ends/fastapi/job_store.py +23 -11
- nat/front_ends/fastapi/main.py +1 -1
- nat/front_ends/fastapi/message_handler.py +27 -4
- nat/front_ends/fastapi/message_validator.py +54 -2
- nat/front_ends/fastapi/register.py +1 -1
- nat/front_ends/fastapi/response_helpers.py +16 -15
- nat/front_ends/fastapi/step_adaptor.py +1 -1
- nat/front_ends/fastapi/utils.py +1 -1
- nat/front_ends/register.py +1 -2
- nat/front_ends/simple_base/__init__.py +1 -1
- nat/front_ends/simple_base/simple_front_end_plugin_base.py +6 -4
- nat/llm/aws_bedrock_llm.py +1 -1
- nat/llm/azure_openai_llm.py +10 -1
- nat/llm/dynamo_llm.py +363 -0
- nat/llm/huggingface_llm.py +177 -0
- nat/llm/litellm_llm.py +1 -1
- nat/llm/nim_llm.py +1 -1
- nat/llm/openai_llm.py +1 -1
- nat/llm/register.py +3 -1
- nat/llm/utils/__init__.py +1 -1
- nat/llm/utils/env_config_value.py +1 -1
- nat/llm/utils/error.py +1 -1
- nat/llm/utils/thinking.py +1 -1
- nat/memory/__init__.py +1 -1
- nat/memory/interfaces.py +1 -1
- nat/memory/models.py +1 -1
- nat/meta/pypi.md +1 -1
- nat/middleware/__init__.py +5 -5
- nat/middleware/cache/__init__.py +14 -0
- nat/middleware/{cache_middleware.py → cache/cache_middleware.py} +39 -42
- nat/middleware/cache/cache_middleware_config.py +44 -0
- nat/middleware/cache/register.py +33 -0
- nat/middleware/defense/__init__.py +14 -0
- nat/middleware/defense/defense_middleware.py +362 -0
- nat/middleware/defense/defense_middleware_content_guard.py +455 -0
- nat/middleware/defense/defense_middleware_data_models.py +91 -0
- nat/middleware/defense/defense_middleware_output_verifier.py +440 -0
- nat/middleware/defense/defense_middleware_pii.py +356 -0
- nat/middleware/defense/register.py +82 -0
- nat/middleware/dynamic/__init__.py +14 -0
- nat/middleware/dynamic/dynamic_function_middleware.py +962 -0
- nat/middleware/dynamic/dynamic_middleware_config.py +132 -0
- nat/middleware/dynamic/register.py +34 -0
- nat/middleware/function_middleware.py +236 -52
- nat/middleware/logging/__init__.py +14 -0
- nat/middleware/logging/logging_middleware.py +67 -0
- nat/middleware/logging/logging_middleware_config.py +28 -0
- nat/middleware/logging/register.py +33 -0
- nat/middleware/middleware.py +142 -28
- nat/middleware/red_teaming/__init__.py +14 -0
- nat/middleware/red_teaming/red_teaming_middleware.py +344 -0
- nat/middleware/red_teaming/red_teaming_middleware_config.py +112 -0
- nat/middleware/red_teaming/register.py +47 -0
- nat/middleware/register.py +7 -20
- nat/middleware/utils/__init__.py +14 -0
- nat/middleware/utils/workflow_inventory.py +155 -0
- nat/object_store/__init__.py +1 -1
- nat/object_store/in_memory_object_store.py +1 -1
- nat/object_store/interfaces.py +1 -1
- nat/object_store/models.py +1 -1
- nat/object_store/register.py +1 -1
- nat/observability/__init__.py +1 -1
- nat/observability/exporter/__init__.py +1 -1
- nat/observability/exporter/base_exporter.py +1 -1
- nat/observability/exporter/exporter.py +1 -1
- nat/observability/exporter/file_exporter.py +1 -1
- nat/observability/exporter/processing_exporter.py +1 -1
- nat/observability/exporter/raw_exporter.py +1 -1
- nat/observability/exporter/span_exporter.py +7 -1
- nat/observability/exporter_manager.py +1 -1
- nat/observability/mixin/__init__.py +1 -1
- nat/observability/mixin/batch_config_mixin.py +1 -1
- nat/observability/mixin/collector_config_mixin.py +1 -1
- nat/observability/mixin/file_mixin.py +1 -1
- nat/observability/mixin/file_mode.py +1 -1
- nat/observability/mixin/redaction_config_mixin.py +1 -1
- nat/observability/mixin/resource_conflict_mixin.py +1 -1
- nat/observability/mixin/serialize_mixin.py +1 -1
- nat/observability/mixin/tagging_config_mixin.py +1 -1
- nat/observability/mixin/type_introspection_mixin.py +1 -1
- nat/observability/processor/__init__.py +1 -1
- nat/observability/processor/batching_processor.py +1 -1
- nat/observability/processor/callback_processor.py +1 -1
- nat/observability/processor/falsy_batch_filter_processor.py +1 -1
- nat/observability/processor/intermediate_step_serializer.py +1 -1
- nat/observability/processor/processor.py +1 -1
- nat/observability/processor/processor_factory.py +1 -1
- nat/observability/processor/redaction/__init__.py +1 -1
- nat/observability/processor/redaction/contextual_redaction_processor.py +1 -1
- nat/observability/processor/redaction/contextual_span_redaction_processor.py +1 -1
- nat/observability/processor/redaction/redaction_processor.py +1 -1
- nat/observability/processor/redaction/span_header_redaction_processor.py +1 -1
- nat/observability/processor/span_tagging_processor.py +1 -1
- nat/observability/register.py +1 -1
- nat/observability/utils/__init__.py +1 -1
- nat/observability/utils/dict_utils.py +1 -1
- nat/observability/utils/time_utils.py +1 -1
- nat/profiler/calc/__init__.py +1 -1
- nat/profiler/calc/calc_runner.py +3 -3
- nat/profiler/calc/calculations.py +1 -1
- nat/profiler/calc/data_models.py +1 -1
- nat/profiler/calc/plot.py +30 -3
- nat/profiler/callbacks/agno_callback_handler.py +1 -1
- nat/profiler/callbacks/base_callback_class.py +1 -1
- nat/profiler/callbacks/langchain_callback_handler.py +33 -3
- nat/profiler/callbacks/llama_index_callback_handler.py +13 -10
- nat/profiler/callbacks/semantic_kernel_callback_handler.py +1 -1
- nat/profiler/callbacks/token_usage_base_model.py +1 -1
- nat/profiler/data_frame_row.py +1 -1
- nat/profiler/data_models.py +1 -1
- nat/profiler/decorators/framework_wrapper.py +16 -1
- nat/profiler/decorators/function_tracking.py +1 -1
- nat/profiler/forecasting/config.py +1 -1
- nat/profiler/forecasting/model_trainer.py +1 -1
- nat/profiler/forecasting/models/__init__.py +1 -1
- nat/profiler/forecasting/models/forecasting_base_model.py +1 -1
- nat/profiler/forecasting/models/linear_model.py +1 -1
- nat/profiler/forecasting/models/random_forest_regressor.py +1 -1
- nat/profiler/inference_metrics_model.py +1 -1
- nat/profiler/inference_optimization/bottleneck_analysis/nested_stack_analysis.py +1 -1
- nat/profiler/inference_optimization/bottleneck_analysis/simple_stack_analysis.py +1 -1
- nat/profiler/inference_optimization/data_models.py +1 -1
- nat/profiler/inference_optimization/experimental/concurrency_spike_analysis.py +1 -1
- nat/profiler/inference_optimization/experimental/prefix_span_analysis.py +1 -1
- nat/profiler/inference_optimization/llm_metrics.py +1 -1
- nat/profiler/inference_optimization/prompt_caching.py +1 -1
- nat/profiler/inference_optimization/token_uniqueness.py +1 -1
- nat/profiler/inference_optimization/workflow_runtimes.py +1 -1
- nat/profiler/intermediate_property_adapter.py +1 -1
- nat/profiler/parameter_optimization/optimizable_utils.py +1 -1
- nat/profiler/parameter_optimization/optimizer_runtime.py +1 -1
- nat/profiler/parameter_optimization/parameter_optimizer.py +1 -1
- nat/profiler/parameter_optimization/parameter_selection.py +1 -1
- nat/profiler/parameter_optimization/pareto_visualizer.py +1 -1
- nat/profiler/parameter_optimization/prompt_optimizer.py +1 -1
- nat/profiler/parameter_optimization/update_helpers.py +1 -1
- nat/profiler/profile_runner.py +1 -1
- nat/profiler/utils.py +1 -1
- nat/registry_handlers/local/local_handler.py +1 -1
- nat/registry_handlers/local/register_local.py +1 -1
- nat/registry_handlers/metadata_factory.py +1 -1
- nat/registry_handlers/package_utils.py +1 -1
- nat/registry_handlers/pypi/pypi_handler.py +1 -1
- nat/registry_handlers/pypi/register_pypi.py +1 -1
- nat/registry_handlers/register.py +1 -1
- nat/registry_handlers/registry_handler_base.py +1 -1
- nat/registry_handlers/rest/register_rest.py +1 -1
- nat/registry_handlers/rest/rest_handler.py +1 -1
- nat/registry_handlers/schemas/headers.py +1 -1
- nat/registry_handlers/schemas/package.py +1 -1
- nat/registry_handlers/schemas/publish.py +1 -1
- nat/registry_handlers/schemas/pull.py +1 -1
- nat/registry_handlers/schemas/remove.py +1 -1
- nat/registry_handlers/schemas/search.py +1 -1
- nat/registry_handlers/schemas/status.py +1 -1
- nat/retriever/interface.py +1 -1
- nat/retriever/milvus/__init__.py +1 -1
- nat/retriever/milvus/register.py +1 -1
- nat/retriever/milvus/retriever.py +1 -1
- nat/retriever/models.py +1 -1
- nat/retriever/nemo_retriever/__init__.py +1 -1
- nat/retriever/nemo_retriever/register.py +1 -1
- nat/retriever/nemo_retriever/retriever.py +5 -5
- nat/retriever/register.py +1 -1
- nat/runtime/__init__.py +1 -1
- nat/runtime/loader.py +10 -3
- nat/runtime/metrics.py +180 -0
- nat/runtime/runner.py +1 -5
- nat/runtime/session.py +451 -32
- nat/runtime/user_metadata.py +1 -1
- nat/settings/global_settings.py +1 -1
- nat/tool/chat_completion.py +1 -1
- nat/tool/code_execution/README.md +1 -1
- nat/tool/code_execution/code_sandbox.py +1 -1
- nat/tool/code_execution/local_sandbox/Dockerfile.sandbox +1 -1
- nat/tool/code_execution/local_sandbox/__init__.py +1 -1
- nat/tool/code_execution/local_sandbox/local_sandbox_server.py +1 -1
- nat/tool/code_execution/local_sandbox/start_local_sandbox.sh +1 -1
- nat/tool/code_execution/register.py +1 -1
- nat/tool/code_execution/utils.py +1 -1
- nat/tool/datetime_tools.py +1 -1
- nat/tool/document_search.py +1 -1
- nat/tool/github_tools.py +1 -1
- nat/tool/memory_tools/add_memory_tool.py +1 -1
- nat/tool/memory_tools/delete_memory_tool.py +1 -1
- nat/tool/memory_tools/get_memory_tool.py +1 -1
- nat/tool/nvidia_rag.py +2 -2
- nat/tool/register.py +1 -1
- nat/tool/retriever.py +1 -1
- nat/tool/server_tools.py +1 -1
- nat/utils/__init__.py +8 -5
- nat/utils/callable_utils.py +1 -1
- nat/utils/data_models/schema_validator.py +1 -1
- nat/utils/debugging_utils.py +1 -1
- nat/utils/decorators.py +1 -1
- nat/utils/dump_distro_mapping.py +1 -1
- nat/utils/exception_handlers/automatic_retries.py +3 -3
- nat/utils/exception_handlers/schemas.py +1 -1
- nat/utils/io/model_processing.py +1 -1
- nat/utils/io/supress_logs.py +33 -0
- nat/utils/io/yaml_tools.py +1 -1
- nat/utils/log_levels.py +1 -1
- nat/utils/log_utils.py +13 -1
- nat/utils/metadata_utils.py +1 -1
- nat/utils/optional_imports.py +1 -1
- nat/utils/producer_consumer_queue.py +1 -1
- nat/utils/reactive/base/observable_base.py +1 -1
- nat/utils/reactive/base/observer_base.py +1 -1
- nat/utils/reactive/base/subject_base.py +1 -1
- nat/utils/reactive/observable.py +1 -1
- nat/utils/reactive/observer.py +1 -1
- nat/utils/reactive/subject.py +1 -1
- nat/utils/reactive/subscription.py +1 -1
- nat/utils/responses_api.py +1 -1
- nat/utils/settings/global_settings.py +1 -1
- nat/utils/string_utils.py +1 -1
- nat/utils/type_converter.py +18 -5
- nat/utils/type_utils.py +1 -1
- nat/utils/url_utils.py +1 -1
- {nvidia_nat-1.4.0a20251120.dist-info → nvidia_nat-1.4.0a20260113.dist-info}/METADATA +39 -14
- nvidia_nat-1.4.0a20260113.dist-info/RECORD +547 -0
- nvidia_nat-1.4.0a20260113.dist-info/entry_points.txt +38 -0
- nat/cli/commands/mcp/mcp.py +0 -986
- nat/front_ends/mcp/introspection_token_verifier.py +0 -73
- nat/front_ends/mcp/mcp_front_end_config.py +0 -109
- nat/front_ends/mcp/mcp_front_end_plugin.py +0 -155
- nat/front_ends/mcp/mcp_front_end_plugin_worker.py +0 -388
- nat/front_ends/mcp/memory_profiler.py +0 -320
- nat/front_ends/mcp/register.py +0 -27
- nat/front_ends/mcp/tool_converter.py +0 -321
- nvidia_nat-1.4.0a20251120.dist-info/RECORD +0 -488
- nvidia_nat-1.4.0a20251120.dist-info/entry_points.txt +0 -23
- {nvidia_nat-1.4.0a20251120.dist-info → nvidia_nat-1.4.0a20260113.dist-info}/WHEEL +0 -0
- {nvidia_nat-1.4.0a20251120.dist-info → nvidia_nat-1.4.0a20260113.dist-info}/licenses/LICENSE-3rd-party.txt +0 -0
- {nvidia_nat-1.4.0a20251120.dist-info → nvidia_nat-1.4.0a20260113.dist-info}/licenses/LICENSE.md +0 -0
- {nvidia_nat-1.4.0a20251120.dist-info → nvidia_nat-1.4.0a20260113.dist-info}/top_level.txt +0 -0
|
@@ -1,388 +0,0 @@
|
|
|
1
|
-
# SPDX-FileCopyrightText: Copyright (c) 2025, NVIDIA CORPORATION & AFFILIATES. All rights reserved.
|
|
2
|
-
# SPDX-License-Identifier: Apache-2.0
|
|
3
|
-
#
|
|
4
|
-
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
-
# you may not use this file except in compliance with the License.
|
|
6
|
-
# You may obtain a copy of the License at
|
|
7
|
-
#
|
|
8
|
-
# http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
-
#
|
|
10
|
-
# Unless required by applicable law or agreed to in writing, software
|
|
11
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
-
# See the License for the specific language governing permissions and
|
|
14
|
-
# limitations under the License.
|
|
15
|
-
|
|
16
|
-
import logging
|
|
17
|
-
from abc import ABC
|
|
18
|
-
from abc import abstractmethod
|
|
19
|
-
from collections.abc import Mapping
|
|
20
|
-
from typing import TYPE_CHECKING
|
|
21
|
-
from typing import Any
|
|
22
|
-
|
|
23
|
-
from mcp.server.fastmcp import FastMCP
|
|
24
|
-
from starlette.exceptions import HTTPException
|
|
25
|
-
from starlette.requests import Request
|
|
26
|
-
|
|
27
|
-
if TYPE_CHECKING:
|
|
28
|
-
from fastapi import FastAPI
|
|
29
|
-
|
|
30
|
-
from nat.builder.function import Function
|
|
31
|
-
from nat.builder.function_base import FunctionBase
|
|
32
|
-
from nat.builder.workflow import Workflow
|
|
33
|
-
from nat.builder.workflow_builder import WorkflowBuilder
|
|
34
|
-
from nat.data_models.config import Config
|
|
35
|
-
from nat.front_ends.mcp.mcp_front_end_config import MCPFrontEndConfig
|
|
36
|
-
from nat.front_ends.mcp.memory_profiler import MemoryProfiler
|
|
37
|
-
|
|
38
|
-
logger = logging.getLogger(__name__)
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
class MCPFrontEndPluginWorkerBase(ABC):
|
|
42
|
-
"""Base class for MCP front end plugin workers.
|
|
43
|
-
|
|
44
|
-
This abstract base class provides shared utilities and defines the contract
|
|
45
|
-
for MCP worker implementations. Most users should inherit from
|
|
46
|
-
MCPFrontEndPluginWorker instead of this class directly.
|
|
47
|
-
"""
|
|
48
|
-
|
|
49
|
-
def __init__(self, config: Config):
|
|
50
|
-
"""Initialize the MCP worker with configuration.
|
|
51
|
-
|
|
52
|
-
Args:
|
|
53
|
-
config: The full NAT configuration
|
|
54
|
-
"""
|
|
55
|
-
self.full_config = config
|
|
56
|
-
self.front_end_config: MCPFrontEndConfig = config.general.front_end
|
|
57
|
-
|
|
58
|
-
# Initialize memory profiler if enabled
|
|
59
|
-
self.memory_profiler = MemoryProfiler(enabled=self.front_end_config.enable_memory_profiling,
|
|
60
|
-
log_interval=self.front_end_config.memory_profile_interval,
|
|
61
|
-
top_n=self.front_end_config.memory_profile_top_n,
|
|
62
|
-
log_level=self.front_end_config.memory_profile_log_level)
|
|
63
|
-
|
|
64
|
-
def _setup_health_endpoint(self, mcp: FastMCP):
|
|
65
|
-
"""Set up the HTTP health endpoint that exercises MCP ping handler."""
|
|
66
|
-
|
|
67
|
-
@mcp.custom_route("/health", methods=["GET"])
|
|
68
|
-
async def health_check(_request: Request):
|
|
69
|
-
"""HTTP health check using server's internal ping handler"""
|
|
70
|
-
from starlette.responses import JSONResponse
|
|
71
|
-
|
|
72
|
-
try:
|
|
73
|
-
from mcp.types import PingRequest
|
|
74
|
-
|
|
75
|
-
# Create a ping request
|
|
76
|
-
ping_request = PingRequest(method="ping")
|
|
77
|
-
|
|
78
|
-
# Call the ping handler directly (same one that responds to MCP pings)
|
|
79
|
-
await mcp._mcp_server.request_handlers[PingRequest](ping_request)
|
|
80
|
-
|
|
81
|
-
return JSONResponse({
|
|
82
|
-
"status": "healthy",
|
|
83
|
-
"error": None,
|
|
84
|
-
"server_name": mcp.name,
|
|
85
|
-
})
|
|
86
|
-
|
|
87
|
-
except Exception as e:
|
|
88
|
-
return JSONResponse({
|
|
89
|
-
"status": "unhealthy",
|
|
90
|
-
"error": str(e),
|
|
91
|
-
"server_name": mcp.name,
|
|
92
|
-
},
|
|
93
|
-
status_code=503)
|
|
94
|
-
|
|
95
|
-
@abstractmethod
|
|
96
|
-
async def create_mcp_server(self) -> FastMCP:
|
|
97
|
-
"""Create and configure the MCP server instance.
|
|
98
|
-
|
|
99
|
-
This is the main extension point. Plugins can return FastMCP or any subclass
|
|
100
|
-
to customize server behavior (for example, add authentication, custom transports).
|
|
101
|
-
|
|
102
|
-
Returns:
|
|
103
|
-
FastMCP instance or a subclass with custom behavior
|
|
104
|
-
"""
|
|
105
|
-
...
|
|
106
|
-
|
|
107
|
-
@abstractmethod
|
|
108
|
-
async def add_routes(self, mcp: FastMCP, builder: WorkflowBuilder):
|
|
109
|
-
"""Add routes to the MCP server.
|
|
110
|
-
|
|
111
|
-
Plugins must implement this method. Most plugins can call
|
|
112
|
-
_default_add_routes() for standard behavior and then add
|
|
113
|
-
custom enhancements.
|
|
114
|
-
|
|
115
|
-
Args:
|
|
116
|
-
mcp: The FastMCP server instance
|
|
117
|
-
builder: The workflow builder instance
|
|
118
|
-
"""
|
|
119
|
-
...
|
|
120
|
-
|
|
121
|
-
async def _default_add_routes(self, mcp: FastMCP, builder: WorkflowBuilder):
|
|
122
|
-
"""Default route registration logic - reusable by subclasses.
|
|
123
|
-
|
|
124
|
-
This is a protected helper method that plugins can call to get
|
|
125
|
-
standard route registration behavior. Plugins typically call this
|
|
126
|
-
from their add_routes() implementation and then add custom features.
|
|
127
|
-
|
|
128
|
-
This method:
|
|
129
|
-
- Sets up the health endpoint
|
|
130
|
-
- Builds the workflow and extracts all functions
|
|
131
|
-
- Filters functions based on tool_names config
|
|
132
|
-
- Registers each function as an MCP tool
|
|
133
|
-
- Sets up debug endpoints for tool introspection
|
|
134
|
-
|
|
135
|
-
Args:
|
|
136
|
-
mcp: The FastMCP server instance
|
|
137
|
-
builder: The workflow builder instance
|
|
138
|
-
"""
|
|
139
|
-
from nat.front_ends.mcp.tool_converter import register_function_with_mcp
|
|
140
|
-
|
|
141
|
-
# Set up the health endpoint
|
|
142
|
-
self._setup_health_endpoint(mcp)
|
|
143
|
-
|
|
144
|
-
# Build the workflow and register all functions with MCP
|
|
145
|
-
workflow = await builder.build()
|
|
146
|
-
|
|
147
|
-
# Get all functions from the workflow
|
|
148
|
-
functions = await self._get_all_functions(workflow)
|
|
149
|
-
|
|
150
|
-
# Filter functions based on tool_names if provided
|
|
151
|
-
if self.front_end_config.tool_names:
|
|
152
|
-
logger.info("Filtering functions based on tool_names: %s", self.front_end_config.tool_names)
|
|
153
|
-
filtered_functions: dict[str, Function] = {}
|
|
154
|
-
for function_name, function in functions.items():
|
|
155
|
-
if function_name in self.front_end_config.tool_names:
|
|
156
|
-
# Treat current tool_names as function names, so check if the function name is in the list
|
|
157
|
-
filtered_functions[function_name] = function
|
|
158
|
-
elif any(function_name.startswith(f"{group_name}.") for group_name in self.front_end_config.tool_names):
|
|
159
|
-
# Treat tool_names as function group names, so check if the function name starts with the group name
|
|
160
|
-
filtered_functions[function_name] = function
|
|
161
|
-
else:
|
|
162
|
-
logger.debug("Skipping function %s as it's not in tool_names", function_name)
|
|
163
|
-
functions = filtered_functions
|
|
164
|
-
|
|
165
|
-
# Register each function with MCP, passing workflow context for observability
|
|
166
|
-
for function_name, function in functions.items():
|
|
167
|
-
register_function_with_mcp(mcp, function_name, function, workflow, self.memory_profiler)
|
|
168
|
-
|
|
169
|
-
# Add a simple fallback function if no functions were found
|
|
170
|
-
if not functions:
|
|
171
|
-
raise RuntimeError("No functions found in workflow. Please check your configuration.")
|
|
172
|
-
|
|
173
|
-
# After registration, expose debug endpoints for tool/schema inspection
|
|
174
|
-
self._setup_debug_endpoints(mcp, functions)
|
|
175
|
-
|
|
176
|
-
async def _get_all_functions(self, workflow: Workflow) -> dict[str, Function]:
|
|
177
|
-
"""Get all functions from the workflow.
|
|
178
|
-
|
|
179
|
-
Args:
|
|
180
|
-
workflow: The NAT workflow.
|
|
181
|
-
|
|
182
|
-
Returns:
|
|
183
|
-
Dict mapping function names to Function objects.
|
|
184
|
-
"""
|
|
185
|
-
functions: dict[str, Function] = {}
|
|
186
|
-
|
|
187
|
-
# Extract all functions from the workflow
|
|
188
|
-
functions.update(workflow.functions)
|
|
189
|
-
for function_group in workflow.function_groups.values():
|
|
190
|
-
functions.update(await function_group.get_accessible_functions())
|
|
191
|
-
|
|
192
|
-
if workflow.config.workflow.workflow_alias:
|
|
193
|
-
functions[workflow.config.workflow.workflow_alias] = workflow
|
|
194
|
-
else:
|
|
195
|
-
functions[workflow.config.workflow.type] = workflow
|
|
196
|
-
|
|
197
|
-
return functions
|
|
198
|
-
|
|
199
|
-
async def add_root_level_routes(self, wrapper_app: "FastAPI", mcp: FastMCP) -> None:
|
|
200
|
-
"""Add routes to the wrapper FastAPI app (optional extension point).
|
|
201
|
-
|
|
202
|
-
This method is called when base_path is configured and a wrapper
|
|
203
|
-
FastAPI app is created to mount the MCP server. Plugins can override
|
|
204
|
-
this to add routes to the wrapper app at the root level, outside the
|
|
205
|
-
mounted MCP server path.
|
|
206
|
-
|
|
207
|
-
Common use cases:
|
|
208
|
-
- OAuth discovery endpoints (e.g., /.well-known/oauth-protected-resource)
|
|
209
|
-
- Health checks at root level
|
|
210
|
-
- Static file serving
|
|
211
|
-
- Custom authentication/authorization endpoints
|
|
212
|
-
|
|
213
|
-
Default implementation does nothing, making this an optional extension point.
|
|
214
|
-
|
|
215
|
-
Args:
|
|
216
|
-
wrapper_app: The FastAPI wrapper application that mounts the MCP server
|
|
217
|
-
mcp: The FastMCP server instance (already mounted at base_path)
|
|
218
|
-
"""
|
|
219
|
-
pass # Default: no additional root-level routes
|
|
220
|
-
|
|
221
|
-
def _setup_debug_endpoints(self, mcp: FastMCP, functions: Mapping[str, FunctionBase]) -> None:
|
|
222
|
-
"""Set up HTTP debug endpoints for introspecting tools and schemas.
|
|
223
|
-
|
|
224
|
-
Exposes:
|
|
225
|
-
- GET /debug/tools/list: List tools. Optional query param `name` (one or more, repeatable or comma separated)
|
|
226
|
-
selects a subset and returns details for those tools.
|
|
227
|
-
- GET /debug/memory/stats: Get current memory profiling statistics (read-only)
|
|
228
|
-
"""
|
|
229
|
-
|
|
230
|
-
@mcp.custom_route("/debug/tools/list", methods=["GET"])
|
|
231
|
-
async def list_tools(request: Request):
|
|
232
|
-
"""HTTP list tools endpoint."""
|
|
233
|
-
|
|
234
|
-
from starlette.responses import JSONResponse
|
|
235
|
-
|
|
236
|
-
from nat.front_ends.mcp.tool_converter import get_function_description
|
|
237
|
-
|
|
238
|
-
# Query params
|
|
239
|
-
# Support repeated names and comma-separated lists
|
|
240
|
-
names_param_list = set(request.query_params.getlist("name"))
|
|
241
|
-
names: list[str] = []
|
|
242
|
-
for raw in names_param_list:
|
|
243
|
-
# if p.strip() is empty, it won't be included in the list!
|
|
244
|
-
parts = [p.strip() for p in raw.split(",") if p.strip()]
|
|
245
|
-
names.extend(parts)
|
|
246
|
-
detail_raw = request.query_params.get("detail")
|
|
247
|
-
|
|
248
|
-
def _parse_detail_param(detail_param: str | None, has_names: bool) -> bool:
|
|
249
|
-
if detail_param is None:
|
|
250
|
-
if has_names:
|
|
251
|
-
return True
|
|
252
|
-
return False
|
|
253
|
-
v = detail_param.strip().lower()
|
|
254
|
-
if v in ("0", "false", "no", "off"):
|
|
255
|
-
return False
|
|
256
|
-
if v in ("1", "true", "yes", "on"):
|
|
257
|
-
return True
|
|
258
|
-
# For invalid values, default based on whether names are present
|
|
259
|
-
return has_names
|
|
260
|
-
|
|
261
|
-
# Helper function to build the input schema info
|
|
262
|
-
def _build_schema_info(fn: FunctionBase) -> dict[str, Any] | None:
|
|
263
|
-
schema = getattr(fn, "input_schema", None)
|
|
264
|
-
if schema is None:
|
|
265
|
-
return None
|
|
266
|
-
|
|
267
|
-
# check if schema is a ChatRequest
|
|
268
|
-
schema_name = getattr(schema, "__name__", "")
|
|
269
|
-
schema_qualname = getattr(schema, "__qualname__", "")
|
|
270
|
-
if "ChatRequest" in schema_name or "ChatRequest" in schema_qualname:
|
|
271
|
-
# Simplified interface used by MCP wrapper for ChatRequest
|
|
272
|
-
return {
|
|
273
|
-
"type": "object",
|
|
274
|
-
"properties": {
|
|
275
|
-
"query": {
|
|
276
|
-
"type": "string", "description": "User query string"
|
|
277
|
-
}
|
|
278
|
-
},
|
|
279
|
-
"required": ["query"],
|
|
280
|
-
"title": "ChatRequestQuery",
|
|
281
|
-
}
|
|
282
|
-
|
|
283
|
-
# Pydantic models provide model_json_schema
|
|
284
|
-
if schema is not None and hasattr(schema, "model_json_schema"):
|
|
285
|
-
return schema.model_json_schema()
|
|
286
|
-
|
|
287
|
-
return None
|
|
288
|
-
|
|
289
|
-
def _build_final_json(functions_to_include: Mapping[str, FunctionBase],
|
|
290
|
-
include_schemas: bool = False) -> dict[str, Any]:
|
|
291
|
-
tools = []
|
|
292
|
-
for name, fn in functions_to_include.items():
|
|
293
|
-
list_entry: dict[str, Any] = {
|
|
294
|
-
"name": name, "description": get_function_description(fn), "is_workflow": hasattr(fn, "run")
|
|
295
|
-
}
|
|
296
|
-
if include_schemas:
|
|
297
|
-
list_entry["schema"] = _build_schema_info(fn)
|
|
298
|
-
tools.append(list_entry)
|
|
299
|
-
|
|
300
|
-
return {
|
|
301
|
-
"count": len(tools),
|
|
302
|
-
"tools": tools,
|
|
303
|
-
"server_name": mcp.name,
|
|
304
|
-
}
|
|
305
|
-
|
|
306
|
-
if names:
|
|
307
|
-
# Return selected tools
|
|
308
|
-
try:
|
|
309
|
-
functions_to_include = {n: functions[n] for n in names}
|
|
310
|
-
except KeyError as e:
|
|
311
|
-
raise HTTPException(status_code=404, detail=f"Tool \"{e.args[0]}\" not found.") from e
|
|
312
|
-
else:
|
|
313
|
-
functions_to_include = functions
|
|
314
|
-
|
|
315
|
-
# Default for listing all: detail defaults to False unless explicitly set true
|
|
316
|
-
return JSONResponse(
|
|
317
|
-
_build_final_json(functions_to_include, _parse_detail_param(detail_raw, has_names=bool(names))))
|
|
318
|
-
|
|
319
|
-
# Memory profiling endpoint (read-only)
|
|
320
|
-
@mcp.custom_route("/debug/memory/stats", methods=["GET"])
|
|
321
|
-
async def get_memory_stats(_request: Request):
|
|
322
|
-
"""Get current memory profiling statistics."""
|
|
323
|
-
from starlette.responses import JSONResponse
|
|
324
|
-
|
|
325
|
-
stats = self.memory_profiler.get_stats()
|
|
326
|
-
return JSONResponse(stats)
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
class MCPFrontEndPluginWorker(MCPFrontEndPluginWorkerBase):
|
|
330
|
-
"""Default MCP server worker implementation.
|
|
331
|
-
|
|
332
|
-
Inherit from this class to create custom MCP workers that extend or modify
|
|
333
|
-
server behavior. Override create_mcp_server() to use a different server type,
|
|
334
|
-
and override add_routes() to add custom functionality.
|
|
335
|
-
|
|
336
|
-
Example:
|
|
337
|
-
class CustomWorker(MCPFrontEndPluginWorker):
|
|
338
|
-
async def create_mcp_server(self):
|
|
339
|
-
# Return custom MCP server instance
|
|
340
|
-
return MyCustomFastMCP(...)
|
|
341
|
-
|
|
342
|
-
async def add_routes(self, mcp, builder):
|
|
343
|
-
# Get default routes
|
|
344
|
-
await super().add_routes(mcp, builder)
|
|
345
|
-
# Add custom features
|
|
346
|
-
self._add_my_custom_features(mcp)
|
|
347
|
-
"""
|
|
348
|
-
|
|
349
|
-
async def create_mcp_server(self) -> FastMCP:
|
|
350
|
-
"""Create default MCP server with optional authentication.
|
|
351
|
-
|
|
352
|
-
Returns:
|
|
353
|
-
FastMCP instance configured with settings from NAT config
|
|
354
|
-
"""
|
|
355
|
-
# Handle auth if configured
|
|
356
|
-
auth_settings = None
|
|
357
|
-
token_verifier = None
|
|
358
|
-
|
|
359
|
-
if self.front_end_config.server_auth:
|
|
360
|
-
from mcp.server.auth.settings import AuthSettings
|
|
361
|
-
from pydantic import AnyHttpUrl
|
|
362
|
-
|
|
363
|
-
server_url = f"http://{self.front_end_config.host}:{self.front_end_config.port}"
|
|
364
|
-
auth_settings = AuthSettings(issuer_url=AnyHttpUrl(self.front_end_config.server_auth.issuer_url),
|
|
365
|
-
required_scopes=self.front_end_config.server_auth.scopes,
|
|
366
|
-
resource_server_url=AnyHttpUrl(server_url))
|
|
367
|
-
|
|
368
|
-
# Create token verifier
|
|
369
|
-
from nat.front_ends.mcp.introspection_token_verifier import IntrospectionTokenVerifier
|
|
370
|
-
|
|
371
|
-
token_verifier = IntrospectionTokenVerifier(self.front_end_config.server_auth)
|
|
372
|
-
|
|
373
|
-
return FastMCP(name=self.front_end_config.name,
|
|
374
|
-
host=self.front_end_config.host,
|
|
375
|
-
port=self.front_end_config.port,
|
|
376
|
-
debug=self.front_end_config.debug,
|
|
377
|
-
auth=auth_settings,
|
|
378
|
-
token_verifier=token_verifier)
|
|
379
|
-
|
|
380
|
-
async def add_routes(self, mcp: FastMCP, builder: WorkflowBuilder):
|
|
381
|
-
"""Add default routes to the MCP server.
|
|
382
|
-
|
|
383
|
-
Args:
|
|
384
|
-
mcp: The FastMCP server instance
|
|
385
|
-
builder: The workflow builder instance
|
|
386
|
-
"""
|
|
387
|
-
# Use the default implementation from base class to add the tools to the MCP server
|
|
388
|
-
await self._default_add_routes(mcp, builder)
|