@ai-setting/roy-agent-core 1.0.0
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.
- package/dist/index.js +99145 -0
- package/package.json +114 -0
- package/src/config/config-component.test.ts +627 -0
- package/src/config/config-component.ts +906 -0
- package/src/config/config-parser.test.ts +319 -0
- package/src/config/config-parser.ts +203 -0
- package/src/config/decentralized-config.test.ts +740 -0
- package/src/config/env-key.ts +210 -0
- package/src/config/env-source.test.ts +252 -0
- package/src/config/env-source.ts +301 -0
- package/src/config/file-source.test.ts +357 -0
- package/src/config/file-source.ts +421 -0
- package/src/config/index.ts +24 -0
- package/src/config/protocol-resolver.test.ts +217 -0
- package/src/config/protocol-resolver.ts +228 -0
- package/src/env/agent/agent-component.abort.test.ts +511 -0
- package/src/env/agent/agent-component.record-session.test.ts +349 -0
- package/src/env/agent/agent-component.test.ts +1389 -0
- package/src/env/agent/agent-component.tool-error.test.ts +327 -0
- package/src/env/agent/agent-component.ts +1711 -0
- package/src/env/agent/agent-config-registration.test.ts +226 -0
- package/src/env/agent/agent-config-registration.ts +46 -0
- package/src/env/agent/agent-reminder-plugin.integration.test.ts +243 -0
- package/src/env/agent/index.ts +10 -0
- package/src/env/agent/summary-agent.parse-hint.test.ts +360 -0
- package/src/env/agent/summary-agent.ts +508 -0
- package/src/env/agent/types.ts +536 -0
- package/src/env/commands/commands-component.test.ts +364 -0
- package/src/env/commands/commands-component.ts +604 -0
- package/src/env/commands/commands-config-registration.test.ts +198 -0
- package/src/env/commands/commands-config-registration.ts +38 -0
- package/src/env/commands/index.ts +21 -0
- package/src/env/commands/parser.test.ts +203 -0
- package/src/env/commands/parser.ts +115 -0
- package/src/env/commands/types.ts +184 -0
- package/src/env/commands-prompt-integration.test.ts +243 -0
- package/src/env/component-env.test.ts +119 -0
- package/src/env/component.ts +335 -0
- package/src/env/constants.test.ts +72 -0
- package/src/env/constants.ts +123 -0
- package/src/env/debug/debug-component.test.ts +114 -0
- package/src/env/debug/debug-component.ts +547 -0
- package/src/env/debug/formatters/index.ts +9 -0
- package/src/env/debug/formatters/repl-formatter.test.ts +139 -0
- package/src/env/debug/formatters/repl-formatter.ts +358 -0
- package/src/env/debug/formatters/trace-formatter.test.ts +119 -0
- package/src/env/debug/formatters/trace-formatter.ts +191 -0
- package/src/env/debug/formatters/tree-formatter.test.ts +107 -0
- package/src/env/debug/formatters/tree-formatter.ts +325 -0
- package/src/env/debug/index.ts +38 -0
- package/src/env/debug/parser/regex-parser.test.ts +201 -0
- package/src/env/debug/parser/regex-parser.ts +196 -0
- package/src/env/debug/parser/span-builder.test.ts +241 -0
- package/src/env/debug/parser/span-builder.ts +386 -0
- package/src/env/debug/reader/log-reader.test.ts +170 -0
- package/src/env/debug/reader/log-reader.ts +186 -0
- package/src/env/debug/reader/span-db-reader.test.ts +118 -0
- package/src/env/debug/reader/span-db-reader.ts +201 -0
- package/src/env/debug/types.test.ts +187 -0
- package/src/env/debug/types.ts +171 -0
- package/src/env/environment-init.test.ts +183 -0
- package/src/env/environment-lifecycle.test.ts +516 -0
- package/src/env/environment-service.test.ts +332 -0
- package/src/env/environment.handle-query.test.ts +96 -0
- package/src/env/environment.test.ts +232 -0
- package/src/env/environment.ts +708 -0
- package/src/env/errors.test.ts +165 -0
- package/src/env/errors.ts +157 -0
- package/src/env/event-source/event-source-agent-handler.test.ts +193 -0
- package/src/env/event-source/event-source-agent-handler.ts +111 -0
- package/src/env/event-source/event-source-component.process-cleanup.test.ts +236 -0
- package/src/env/event-source/event-source-component.stop.test.ts +346 -0
- package/src/env/event-source/event-source-component.test.ts +1207 -0
- package/src/env/event-source/event-source-component.ts +1379 -0
- package/src/env/event-source/event-source-config-registration.test.ts +242 -0
- package/src/env/event-source/event-source-config-registration.ts +37 -0
- package/src/env/event-source/event-source-integration.test.ts +320 -0
- package/src/env/event-source/event-source-platform.test.ts +630 -0
- package/src/env/event-source/types.ts +298 -0
- package/src/env/hook/global-hook-manager.ts +162 -0
- package/src/env/hook/hook-manager.test.ts +374 -0
- package/src/env/hook/hook-manager.ts +309 -0
- package/src/env/hook/index.ts +38 -0
- package/src/env/hook/types.ts +138 -0
- package/src/env/index.ts +144 -0
- package/src/env/interface.ts +203 -0
- package/src/env/llm/hooks.test.ts +293 -0
- package/src/env/llm/hooks.ts +316 -0
- package/src/env/llm/index.ts +61 -0
- package/src/env/llm/invoke-threshold-check.test.ts +88 -0
- package/src/env/llm/invoke-timeout.test.ts +54 -0
- package/src/env/llm/invoke.test.ts +71 -0
- package/src/env/llm/invoke.ts +1039 -0
- package/src/env/llm/llm-config.test.ts +523 -0
- package/src/env/llm/llm.test.ts +233 -0
- package/src/env/llm/llm.ts +568 -0
- package/src/env/llm/provider.test.ts +182 -0
- package/src/env/llm/provider.ts +108 -0
- package/src/env/llm/transform.test.ts +251 -0
- package/src/env/llm/transform.ts +286 -0
- package/src/env/llm/types.test.ts +580 -0
- package/src/env/llm/types.ts +424 -0
- package/src/env/log-trace/decorator-otel.test.ts +182 -0
- package/src/env/log-trace/decorator.ts +230 -0
- package/src/env/log-trace/index.ts +79 -0
- package/src/env/log-trace/log-trace-component.test.ts +242 -0
- package/src/env/log-trace/log-trace-component.ts +497 -0
- package/src/env/log-trace/log-trace-config-registration.test.ts +348 -0
- package/src/env/log-trace/log-trace-config-registration.ts +45 -0
- package/src/env/log-trace/logger.test.ts +149 -0
- package/src/env/log-trace/logger.ts +522 -0
- package/src/env/log-trace/opentelemetry/cli-propagation.test.ts +147 -0
- package/src/env/log-trace/opentelemetry/cli-propagation.ts +194 -0
- package/src/env/log-trace/opentelemetry/integration.test.ts +668 -0
- package/src/env/log-trace/opentelemetry/mod.ts +25 -0
- package/src/env/log-trace/opentelemetry/propagation-env.test.ts +181 -0
- package/src/env/log-trace/opentelemetry/propagation-env.ts +136 -0
- package/src/env/log-trace/opentelemetry/propagation.test.ts +259 -0
- package/src/env/log-trace/opentelemetry/propagation.ts +215 -0
- package/src/env/log-trace/opentelemetry/tracer-provider-context.test.ts +166 -0
- package/src/env/log-trace/opentelemetry/tracer-provider.test.ts +379 -0
- package/src/env/log-trace/opentelemetry/tracer-provider.ts +612 -0
- package/src/env/log-trace/span-storage.test.ts +145 -0
- package/src/env/log-trace/span-storage.ts +230 -0
- package/src/env/log-trace/trace-context.test.ts +187 -0
- package/src/env/log-trace/trace-context.ts +162 -0
- package/src/env/log-trace/types.test.ts +63 -0
- package/src/env/log-trace/types.ts +172 -0
- package/src/env/mcp/README.md +244 -0
- package/src/env/mcp/__integration__/mcp-component.integration.test.ts +373 -0
- package/src/env/mcp/config.test.ts +74 -0
- package/src/env/mcp/config.ts +116 -0
- package/src/env/mcp/index.ts +41 -0
- package/src/env/mcp/loader.test.ts +161 -0
- package/src/env/mcp/loader.ts +209 -0
- package/src/env/mcp/mcp-component.test.ts +111 -0
- package/src/env/mcp/mcp-component.ts +358 -0
- package/src/env/mcp/mcp-config-registration.test.ts +304 -0
- package/src/env/mcp/mcp-config-registration.ts +50 -0
- package/src/env/mcp/scanner.test.ts +170 -0
- package/src/env/mcp/scanner.ts +246 -0
- package/src/env/mcp/tool/adapter.test.ts +520 -0
- package/src/env/mcp/tool/adapter.ts +521 -0
- package/src/env/mcp/tool/index.ts +5 -0
- package/src/env/mcp/types.test.ts +171 -0
- package/src/env/mcp/types.ts +79 -0
- package/src/env/memory/README.md +177 -0
- package/src/env/memory/built-in/index.ts +59 -0
- package/src/env/memory/built-in/recall-memory.ts +103 -0
- package/src/env/memory/built-in/record-memory.ts +148 -0
- package/src/env/memory/index.ts +20 -0
- package/src/env/memory/memory-component.test.ts +239 -0
- package/src/env/memory/memory-component.ts +503 -0
- package/src/env/memory/memory-config-registration.test.ts +67 -0
- package/src/env/memory/memory-config-registration.ts +48 -0
- package/src/env/memory/memory-config.ts +45 -0
- package/src/env/memory/memory-file.test.ts +268 -0
- package/src/env/memory/plugin/index.ts +48 -0
- package/src/env/memory/plugin/memory-agent.test.ts +249 -0
- package/src/env/memory/plugin/memory-agent.ts +365 -0
- package/src/env/memory/plugin/memory-manager.ts +198 -0
- package/src/env/memory/plugin/memory-plugin-agent.test.ts +145 -0
- package/src/env/memory/plugin/memory-plugin.ts +210 -0
- package/src/env/memory/plugin/plugin-simplified.test.ts +51 -0
- package/src/env/memory/plugin/recall-memory.test.ts +106 -0
- package/src/env/memory/plugin/recall-memory.ts +53 -0
- package/src/env/memory/plugin/types.ts +101 -0
- package/src/env/memory/tools/memory-agent-tools.ts +228 -0
- package/src/env/memory/types.ts +85 -0
- package/src/env/paths.ts +118 -0
- package/src/env/prompt/index.ts +18 -0
- package/src/env/prompt/memory-prompts.test.ts +91 -0
- package/src/env/prompt/prompt-component.test.ts +491 -0
- package/src/env/prompt/prompt-component.ts +619 -0
- package/src/env/prompt/prompt-config-registration.test.ts +213 -0
- package/src/env/prompt/prompt-config-registration.ts +39 -0
- package/src/env/prompt/prompts-index.ts +504 -0
- package/src/env/prompt/renderer.ts +67 -0
- package/src/env/prompt/types.ts +136 -0
- package/src/env/session/hooks.ts +18 -0
- package/src/env/session/index.ts +37 -0
- package/src/env/session/search-query-parser.test.ts +425 -0
- package/src/env/session/search-query-parser.ts +171 -0
- package/src/env/session/session-checkpoint.test.ts +523 -0
- package/src/env/session/session-component.extract-recent-messages.test.ts +209 -0
- package/src/env/session/session-component.test.ts +132 -0
- package/src/env/session/session-component.ts +1249 -0
- package/src/env/session/session-config-registration.test.ts +138 -0
- package/src/env/session/session-config-registration.ts +52 -0
- package/src/env/session/session-message-converter.test.ts +763 -0
- package/src/env/session/session-message-converter.ts +415 -0
- package/src/env/session/session-message-e2e.test.ts +448 -0
- package/src/env/session/session-search.test.ts +391 -0
- package/src/env/session/session-store.test.ts +362 -0
- package/src/env/session/session-store.ts +141 -0
- package/src/env/session/storage/index.ts +6 -0
- package/src/env/session/storage/memory.ts +502 -0
- package/src/env/session/storage/sqlite.ts +794 -0
- package/src/env/session/types.ts +742 -0
- package/src/env/skill/config.ts +39 -0
- package/src/env/skill/index.ts +6 -0
- package/src/env/skill/parser.test.ts +116 -0
- package/src/env/skill/parser.ts +77 -0
- package/src/env/skill/scanner.test.ts +211 -0
- package/src/env/skill/scanner.ts +119 -0
- package/src/env/skill/skill-component.test.ts +234 -0
- package/src/env/skill/skill-component.ts +352 -0
- package/src/env/skill/skill-config-registration.test.ts +60 -0
- package/src/env/skill/skill-config-registration.ts +43 -0
- package/src/env/skill/tool/index.ts +1 -0
- package/src/env/skill/tool/skill-tool.test.ts +100 -0
- package/src/env/skill/tool/skill-tool.ts +72 -0
- package/src/env/skill/types.ts +64 -0
- package/src/env/task/delegate/delegate-tool.test.ts +498 -0
- package/src/env/task/delegate/delegate-tool.ts +1014 -0
- package/src/env/task/delegate/index.ts +18 -0
- package/src/env/task/delegate/stop-tool.test.ts +140 -0
- package/src/env/task/delegate/stop-tool.ts +119 -0
- package/src/env/task/delegate/task-events.test.ts +178 -0
- package/src/env/task/delegate/task-events.ts +143 -0
- package/src/env/task/hooks/contexts.test.ts +92 -0
- package/src/env/task/hooks/contexts.ts +192 -0
- package/src/env/task/hooks/index.ts +23 -0
- package/src/env/task/hooks/task-hook-points.test.ts +32 -0
- package/src/env/task/hooks/task-hook-points.ts +54 -0
- package/src/env/task/index.ts +7 -0
- package/src/env/task/plugins/index.ts +13 -0
- package/src/env/task/plugins/task-plugin.test.ts +74 -0
- package/src/env/task/plugins/task-plugin.ts +89 -0
- package/src/env/task/plugins/task-tag-plugin.test.ts +377 -0
- package/src/env/task/plugins/task-tag-plugin.ts +319 -0
- package/src/env/task/plugins/task-workflow-extractor.integration.test.ts +226 -0
- package/src/env/task/plugins/workflow-extractor-agent.test.ts +107 -0
- package/src/env/task/plugins/workflow-extractor-agent.ts +225 -0
- package/src/env/task/storage/index.ts +6 -0
- package/src/env/task/storage/sqlite-task-store.test.ts +283 -0
- package/src/env/task/storage/sqlite-task-store.ts +903 -0
- package/src/env/task/storage/task-search.test.ts +291 -0
- package/src/env/task/tag-service.test.ts +198 -0
- package/src/env/task/tag-service.ts +264 -0
- package/src/env/task/task-component.test.ts +193 -0
- package/src/env/task/task-component.ts +658 -0
- package/src/env/task/task-config-registration.test.ts +57 -0
- package/src/env/task/task-config-registration.ts +37 -0
- package/src/env/task/task-types.test.ts +137 -0
- package/src/env/task/tools/complete-tool.ts +44 -0
- package/src/env/task/tools/create-tool.ts +49 -0
- package/src/env/task/tools/delete-tool.ts +43 -0
- package/src/env/task/tools/get-tool.ts +59 -0
- package/src/env/task/tools/index.ts +10 -0
- package/src/env/task/tools/list-tool.ts +40 -0
- package/src/env/task/tools/operation/create-tool.ts +48 -0
- package/src/env/task/tools/operation/delete-tool.ts +43 -0
- package/src/env/task/tools/operation/get-tool.ts +43 -0
- package/src/env/task/tools/operation/index.ts +9 -0
- package/src/env/task/tools/operation/list-tool.ts +40 -0
- package/src/env/task/tools/operation/operation-tools.test.ts +274 -0
- package/src/env/task/tools/operation/operation-types.ts +75 -0
- package/src/env/task/tools/operation/update-tool.ts +47 -0
- package/src/env/task/tools/task-tools.test.ts +203 -0
- package/src/env/task/tools/task-types.test.ts +75 -0
- package/src/env/task/tools/task-types.ts +68 -0
- package/src/env/task/tools/update-tool.ts +70 -0
- package/src/env/task/types.ts +160 -0
- package/src/env/tool/built-in/bash.ts +201 -0
- package/src/env/tool/built-in/echo.ts +29 -0
- package/src/env/tool/built-in/edit-file.test.ts +136 -0
- package/src/env/tool/built-in/edit-file.ts +92 -0
- package/src/env/tool/built-in/glob.test.ts +94 -0
- package/src/env/tool/built-in/glob.ts +65 -0
- package/src/env/tool/built-in/grep.test.ts +122 -0
- package/src/env/tool/built-in/grep.ts +108 -0
- package/src/env/tool/built-in/index.ts +44 -0
- package/src/env/tool/built-in/read-file.test.ts +84 -0
- package/src/env/tool/built-in/read-file.ts +75 -0
- package/src/env/tool/built-in/write-file.test.ts +119 -0
- package/src/env/tool/built-in/write-file.ts +68 -0
- package/src/env/tool/index.ts +24 -0
- package/src/env/tool/registry.test.ts +257 -0
- package/src/env/tool/registry.ts +167 -0
- package/src/env/tool/tool-component.test.ts +559 -0
- package/src/env/tool/tool-component.ts +563 -0
- package/src/env/tool/tool-config-registration.test.ts +249 -0
- package/src/env/tool/tool-config-registration.ts +46 -0
- package/src/env/tool/types.ts +267 -0
- package/src/env/tool/validator.test.ts +143 -0
- package/src/env/tool/validator.ts +44 -0
- package/src/env/types.ts +180 -0
- package/src/env/workflow/ask-user-tool-registration.test.ts +216 -0
- package/src/env/workflow/complex-workflow.integration.test.ts +1900 -0
- package/src/env/workflow/decorators/decorator-node.ts +229 -0
- package/src/env/workflow/decorators/decorator.test.ts +196 -0
- package/src/env/workflow/decorators/edge.ts +82 -0
- package/src/env/workflow/decorators/index.ts +31 -0
- package/src/env/workflow/decorators/node-as.ts +98 -0
- package/src/env/workflow/decorators/workflow.ts +54 -0
- package/src/env/workflow/engine/dag-manager.test.ts +570 -0
- package/src/env/workflow/engine/dag-manager.ts +594 -0
- package/src/env/workflow/engine/engine.ts +1422 -0
- package/src/env/workflow/engine/event-bus.test.ts +359 -0
- package/src/env/workflow/engine/event-bus.ts +156 -0
- package/src/env/workflow/engine/executor-agent-session.test.ts +84 -0
- package/src/env/workflow/engine/executor.test.ts +619 -0
- package/src/env/workflow/engine/executor.ts +593 -0
- package/src/env/workflow/engine/index.ts +24 -0
- package/src/env/workflow/engine/node-registry.test.ts +560 -0
- package/src/env/workflow/engine/node-registry.ts +289 -0
- package/src/env/workflow/engine/resume-removed.test.ts +22 -0
- package/src/env/workflow/engine/scheduler.test.ts +715 -0
- package/src/env/workflow/engine/scheduler.ts +318 -0
- package/src/env/workflow/engine/workflow-engine.test.ts +815 -0
- package/src/env/workflow/extractor/workflow-converter.ts +306 -0
- package/src/env/workflow/fixtures.ts +380 -0
- package/src/env/workflow/index.ts +38 -0
- package/src/env/workflow/integration/run-resume-unified.test.ts +186 -0
- package/src/env/workflow/integration/service-integration.test.ts +267 -0
- package/src/env/workflow/metadata/keys.ts +12 -0
- package/src/env/workflow/nodes/agent-component-adapter.test.ts +318 -0
- package/src/env/workflow/nodes/agent-component-adapter.ts +448 -0
- package/src/env/workflow/nodes/agent-node.test.ts +371 -0
- package/src/env/workflow/nodes/agent-node.ts +598 -0
- package/src/env/workflow/nodes/ask-user-node.ts +113 -0
- package/src/env/workflow/nodes/condition-node.ts +200 -0
- package/src/env/workflow/nodes/index.ts +9 -0
- package/src/env/workflow/nodes/merge-node.ts +141 -0
- package/src/env/workflow/nodes/skill-node.test.ts +253 -0
- package/src/env/workflow/nodes/skill-node.ts +393 -0
- package/src/env/workflow/nodes/tool-node.test.ts +251 -0
- package/src/env/workflow/nodes/tool-node.ts +493 -0
- package/src/env/workflow/nodes/workflow-llm-history.test.ts +455 -0
- package/src/env/workflow/nodes/workflow-node.test.ts +315 -0
- package/src/env/workflow/nodes/workflow-node.ts +311 -0
- package/src/env/workflow/service/index.ts +27 -0
- package/src/env/workflow/service/registry.test.ts +133 -0
- package/src/env/workflow/service/registry.ts +71 -0
- package/src/env/workflow/service/workflow-service.test.ts +310 -0
- package/src/env/workflow/service/workflow-service.ts +393 -0
- package/src/env/workflow/storage/index.ts +28 -0
- package/src/env/workflow/storage/mock-repositories.ts +385 -0
- package/src/env/workflow/storage/sqlite.test.ts +179 -0
- package/src/env/workflow/storage/sqlite.ts +163 -0
- package/src/env/workflow/storage/workflow-repo.test.ts +780 -0
- package/src/env/workflow/storage/workflow-repo.ts +342 -0
- package/src/env/workflow/tools/ask-user-tool.ts +82 -0
- package/src/env/workflow/tools/index.ts +26 -0
- package/src/env/workflow/tools/run-workflow.test.ts +352 -0
- package/src/env/workflow/tools/run-workflow.ts +214 -0
- package/src/env/workflow/types/context.ts +18 -0
- package/src/env/workflow/types/decorators-types.ts +198 -0
- package/src/env/workflow/types/event.test.ts +515 -0
- package/src/env/workflow/types/event.ts +193 -0
- package/src/env/workflow/types/index.ts +49 -0
- package/src/env/workflow/types/run.test.ts +437 -0
- package/src/env/workflow/types/run.ts +173 -0
- package/src/env/workflow/types/workflow-hil.ts +114 -0
- package/src/env/workflow/types/workflow-message.test.ts +138 -0
- package/src/env/workflow/types/workflow-message.ts +196 -0
- package/src/env/workflow/types/workflow-session.test.ts +95 -0
- package/src/env/workflow/types/workflow-session.ts +59 -0
- package/src/env/workflow/types/workflow.test.ts +495 -0
- package/src/env/workflow/types/workflow.ts +195 -0
- package/src/env/workflow/types_compat.ts +51 -0
- package/src/env/workflow/utils/create-workflow.ts +47 -0
- package/src/env/workflow/utils/execution-state.ts +245 -0
- package/src/env/workflow/utils/index.ts +18 -0
- package/src/env/workflow/utils/node-registry-helper.ts +58 -0
- package/src/env/workflow/utils/recovery-validator.test.ts +460 -0
- package/src/env/workflow/utils/recovery-validator.ts +377 -0
- package/src/env/workflow/utils/session-parser.test.ts +111 -0
- package/src/env/workflow/utils/session-parser.ts +94 -0
- package/src/env/workflow/utils/session-recovery.test.ts +334 -0
- package/src/env/workflow/utils/session-recovery.ts +188 -0
- package/src/env/workflow/utils/template-resolver.test.ts +258 -0
- package/src/env/workflow/utils/template-resolver.ts +436 -0
- package/src/env/workflow/utils/validation-rules.ts +149 -0
- package/src/env/workflow/workflow-component.ts +544 -0
- package/src/index.ts +422 -0
- package/src/utils/id.ts +21 -0
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { ZodError } from "zod";
|
|
2
|
+
import type { Tool, ValidationResult } from "./types";
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* 工具参数验证器
|
|
6
|
+
*/
|
|
7
|
+
export class ToolValidator {
|
|
8
|
+
/**
|
|
9
|
+
* 验证参数
|
|
10
|
+
*/
|
|
11
|
+
async validate(tool: Tool, args: Record<string, unknown>): Promise<ValidationResult> {
|
|
12
|
+
try {
|
|
13
|
+
// 使用 Zod 验证参数
|
|
14
|
+
const parsed = await tool.parameters.parseAsync(args);
|
|
15
|
+
return {
|
|
16
|
+
success: true,
|
|
17
|
+
data: parsed as Record<string, unknown>,
|
|
18
|
+
};
|
|
19
|
+
} catch (error) {
|
|
20
|
+
if (error instanceof ZodError) {
|
|
21
|
+
const errorMessage = tool.formatValidationError
|
|
22
|
+
? tool.formatValidationError(error)
|
|
23
|
+
: this.formatError(error);
|
|
24
|
+
return {
|
|
25
|
+
success: false,
|
|
26
|
+
error: `Invalid arguments for tool '${tool.name}': ${errorMessage}`,
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
return {
|
|
30
|
+
success: false,
|
|
31
|
+
error: `Validation error: ${error}`,
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
/**
|
|
37
|
+
* 格式化 Zod 错误
|
|
38
|
+
*/
|
|
39
|
+
private formatError(error: ZodError): string {
|
|
40
|
+
return error.errors
|
|
41
|
+
.map((e) => `${e.path.join(".")}: ${e.message}`)
|
|
42
|
+
.join("; ");
|
|
43
|
+
}
|
|
44
|
+
}
|
package/src/env/types.ts
ADDED
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @fileoverview Environment types and interfaces
|
|
3
|
+
*
|
|
4
|
+
* 定义 Environment 的核心类型,包括:
|
|
5
|
+
* - Environment 配置
|
|
6
|
+
* - EnvEvent 事件类型
|
|
7
|
+
*/
|
|
8
|
+
|
|
9
|
+
// ============================================================================
|
|
10
|
+
// Environment Types
|
|
11
|
+
// ============================================================================
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Environment Config
|
|
15
|
+
*/
|
|
16
|
+
export interface EnvironmentConfig {
|
|
17
|
+
/** 环境名称 */
|
|
18
|
+
name: string;
|
|
19
|
+
/** 环境版本 */
|
|
20
|
+
version: string;
|
|
21
|
+
/** 是否启用 */
|
|
22
|
+
enabled: boolean;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* BaseEnvironment 配置
|
|
27
|
+
*/
|
|
28
|
+
export interface BaseEnvironmentConfig {
|
|
29
|
+
/** 环境名称 */
|
|
30
|
+
name?: string;
|
|
31
|
+
/** 环境版本 */
|
|
32
|
+
version?: string;
|
|
33
|
+
/** 是否启用 */
|
|
34
|
+
enabled?: boolean;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
// ============================================================================
|
|
38
|
+
// EnvEvent Types
|
|
39
|
+
// ============================================================================
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* EnvEvent 元信息
|
|
43
|
+
*/
|
|
44
|
+
export interface EnvEventMetadata {
|
|
45
|
+
/** 触发事件的 session ID */
|
|
46
|
+
trigger_session_id?: string;
|
|
47
|
+
/** 触发事件的 agent ID */
|
|
48
|
+
trigger_agent_id?: string;
|
|
49
|
+
/** Agent 名称 */
|
|
50
|
+
trigger_agent_name?: string;
|
|
51
|
+
/** 环境名称 */
|
|
52
|
+
env_name?: string;
|
|
53
|
+
/** 事件来源 */
|
|
54
|
+
source?: string;
|
|
55
|
+
/** 其他元数据 */
|
|
56
|
+
[key: string]: unknown;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
/**
|
|
60
|
+
* EnvEvent
|
|
61
|
+
*
|
|
62
|
+
* 统一的事件机制,用于:
|
|
63
|
+
* - Stream 事件(stream.start, stream.text, stream.completed 等)
|
|
64
|
+
* - 工具调用事件(tool.call, tool.result 等)
|
|
65
|
+
* - 会话事件(session.created, session.updated 等)
|
|
66
|
+
* - Agent 事件(agent.thinking, agent.acting 等)
|
|
67
|
+
*/
|
|
68
|
+
export interface EnvEvent<T = unknown> {
|
|
69
|
+
/** 事件 ID */
|
|
70
|
+
id: string;
|
|
71
|
+
/** 事件类型 */
|
|
72
|
+
type: string;
|
|
73
|
+
/** 时间戳 */
|
|
74
|
+
timestamp: number;
|
|
75
|
+
/** 元信息 */
|
|
76
|
+
metadata: EnvEventMetadata;
|
|
77
|
+
/** 事件负载 */
|
|
78
|
+
payload: T;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
/**
|
|
82
|
+
* EnvEvent Handler
|
|
83
|
+
*/
|
|
84
|
+
export type EnvEventHandler = (event: EnvEvent) => void | Promise<void>;
|
|
85
|
+
|
|
86
|
+
/**
|
|
87
|
+
* EnvEvent 创建参数(部分属性,可选)
|
|
88
|
+
*
|
|
89
|
+
* 用于 pushEnvEvent 方法,允许传入部分属性,自动补全必填字段
|
|
90
|
+
*/
|
|
91
|
+
export interface EnvEventInput {
|
|
92
|
+
/** 事件类型(必填) */
|
|
93
|
+
type: string;
|
|
94
|
+
/** 事件 ID(可选,自动生成) */
|
|
95
|
+
id?: string;
|
|
96
|
+
/** 时间戳(可选,自动生成) */
|
|
97
|
+
timestamp?: number;
|
|
98
|
+
/** 元信息(可选,自动创建) */
|
|
99
|
+
metadata?: EnvEventMetadata;
|
|
100
|
+
/** 事件负载(可选) */
|
|
101
|
+
payload?: unknown;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
// ============================================================================
|
|
105
|
+
// Context Types
|
|
106
|
+
// ============================================================================
|
|
107
|
+
|
|
108
|
+
/**
|
|
109
|
+
* Action 类型
|
|
110
|
+
*/
|
|
111
|
+
export interface Action {
|
|
112
|
+
/** Action 类型 */
|
|
113
|
+
type: string;
|
|
114
|
+
/** Action 参数 */
|
|
115
|
+
params?: Record<string, unknown>;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
/**
|
|
119
|
+
* Tool Result
|
|
120
|
+
*/
|
|
121
|
+
export interface ToolResult {
|
|
122
|
+
/** 是否成功 */
|
|
123
|
+
success: boolean;
|
|
124
|
+
/** 输出内容 */
|
|
125
|
+
output: string | Record<string, unknown>;
|
|
126
|
+
/** 错误信息 */
|
|
127
|
+
error?: string;
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
/**
|
|
131
|
+
* Context
|
|
132
|
+
*/
|
|
133
|
+
export interface Context {
|
|
134
|
+
/** 会话 ID */
|
|
135
|
+
sessionId?: string;
|
|
136
|
+
/** 用户 ID */
|
|
137
|
+
userId?: string;
|
|
138
|
+
/** 工作目录 */
|
|
139
|
+
workdir?: string;
|
|
140
|
+
/** 中断信号 */
|
|
141
|
+
abort?: AbortSignal;
|
|
142
|
+
/** 元数据 */
|
|
143
|
+
metadata?: Record<string, unknown>;
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
// ============================================================================
|
|
147
|
+
// Hook Context Types
|
|
148
|
+
// ============================================================================
|
|
149
|
+
|
|
150
|
+
/**
|
|
151
|
+
* Session Hook 上下文
|
|
152
|
+
*/
|
|
153
|
+
export interface SessionHookContext {
|
|
154
|
+
/** Session 对象 */
|
|
155
|
+
session?: {
|
|
156
|
+
id: string;
|
|
157
|
+
title?: string;
|
|
158
|
+
metadata?: Record<string, unknown>;
|
|
159
|
+
};
|
|
160
|
+
/** 操作选项 */
|
|
161
|
+
options?: Record<string, unknown>;
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
/**
|
|
165
|
+
* Log Context(日志上下文)
|
|
166
|
+
*/
|
|
167
|
+
export interface LogContext {
|
|
168
|
+
/** 日志级别 */
|
|
169
|
+
level: string;
|
|
170
|
+
/** 日志类别 */
|
|
171
|
+
category: string;
|
|
172
|
+
/** 日志消息 */
|
|
173
|
+
message: string;
|
|
174
|
+
/** 时间戳 */
|
|
175
|
+
timestamp: number;
|
|
176
|
+
/** 调用位置 */
|
|
177
|
+
callerLocation?: string;
|
|
178
|
+
/** 其他元数据 */
|
|
179
|
+
[key: string]: unknown;
|
|
180
|
+
}
|
|
@@ -0,0 +1,216 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @fileoverview AskUserTool Registration Tests
|
|
3
|
+
*
|
|
4
|
+
* Tests to verify that ask_user tool is only registered in Workflow AgentNode context,
|
|
5
|
+
* NOT in default agent or sub agent (delegate task) contexts.
|
|
6
|
+
*
|
|
7
|
+
* Design:
|
|
8
|
+
* - ask_user tool should NOT be available to default agent
|
|
9
|
+
* - ask_user tool should NOT be available to sub agent (delegate task)
|
|
10
|
+
* - ask_user tool should ONLY be available in Workflow AgentNode when workflow is running
|
|
11
|
+
*/
|
|
12
|
+
|
|
13
|
+
import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
|
|
14
|
+
import { z } from 'zod';
|
|
15
|
+
|
|
16
|
+
// Mock the ask_user tool
|
|
17
|
+
const mockAskUserTool = {
|
|
18
|
+
name: 'ask_user',
|
|
19
|
+
description: 'Ask user for input',
|
|
20
|
+
parameters: z.object({
|
|
21
|
+
query: z.string().describe('The question to ask'),
|
|
22
|
+
options: z.array(z.string()).optional(),
|
|
23
|
+
}),
|
|
24
|
+
execute: vi.fn().mockImplementation(() => {
|
|
25
|
+
throw new Error('AskUserError - should not be called in this test');
|
|
26
|
+
}),
|
|
27
|
+
metadata: { category: 'workflow', tags: ['human-in-loop'] },
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
describe('AskUserTool Registration', () => {
|
|
31
|
+
describe('ToolComponent registration behavior', () => {
|
|
32
|
+
it('should NOT register ask_user tool by default', () => {
|
|
33
|
+
// The ask_user tool should NOT be pre-registered to ToolComponent
|
|
34
|
+
// This test documents the expected behavior
|
|
35
|
+
|
|
36
|
+
// Setup: Create a mock ToolComponent
|
|
37
|
+
const registeredTools = new Map<string, any>();
|
|
38
|
+
const mockToolComponent = {
|
|
39
|
+
register: vi.fn((tool: any) => {
|
|
40
|
+
registeredTools.set(tool.name, tool);
|
|
41
|
+
}),
|
|
42
|
+
registerMany: vi.fn((tools: any[]) => {
|
|
43
|
+
tools.forEach((tool: any) => {
|
|
44
|
+
registeredTools.set(tool.name, tool);
|
|
45
|
+
});
|
|
46
|
+
}),
|
|
47
|
+
getTool: vi.fn((name: string) => registeredTools.get(name)),
|
|
48
|
+
listTools: vi.fn(() => Array.from(registeredTools.keys())),
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
// Verify: ask_user is NOT registered by default
|
|
52
|
+
expect(mockToolComponent.getTool('ask_user')).toBeUndefined();
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
it('should document that ask_user is workflow-only', () => {
|
|
56
|
+
// This test documents the design:
|
|
57
|
+
// - ask_user tool is only available in Workflow AgentNode context
|
|
58
|
+
// - It should NOT be available to default agent
|
|
59
|
+
// - It should NOT be available to sub agent (delegate task)
|
|
60
|
+
|
|
61
|
+
const toolScope = {
|
|
62
|
+
availableIn: {
|
|
63
|
+
defaultAgent: false,
|
|
64
|
+
subAgent: false,
|
|
65
|
+
workflowAgentNode: true, // Only when workflow is running
|
|
66
|
+
},
|
|
67
|
+
registrationPoint: 'AgentNode options (not init time)',
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
expect(toolScope.availableIn.defaultAgent).toBe(false);
|
|
71
|
+
expect(toolScope.availableIn.subAgent).toBe(false);
|
|
72
|
+
expect(toolScope.availableIn.workflowAgentNode).toBe(true);
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
describe('AgentNode with ask_user in allowedTools', () => {
|
|
77
|
+
it('should include ask_user in allowedTools when running workflow agent', () => {
|
|
78
|
+
// Test that when Workflow AgentNode runs, it should have ask_user in allowedTools
|
|
79
|
+
// This is set in the AgentNode.execute() method when building AgentConfig
|
|
80
|
+
|
|
81
|
+
const agentConfig = {
|
|
82
|
+
type: 'general',
|
|
83
|
+
prompt: 'Test prompt',
|
|
84
|
+
// ask_user should be explicitly allowed for workflow agents
|
|
85
|
+
options: {
|
|
86
|
+
allowedTools: ['ask_user'],
|
|
87
|
+
},
|
|
88
|
+
};
|
|
89
|
+
|
|
90
|
+
expect(agentConfig.options.allowedTools).toContain('ask_user');
|
|
91
|
+
});
|
|
92
|
+
|
|
93
|
+
it('should NOT include ask_user for non-workflow agents', () => {
|
|
94
|
+
// Test that regular agents (default agent, sub agent) should NOT have ask_user
|
|
95
|
+
|
|
96
|
+
// Default agent - no allowedTools in options
|
|
97
|
+
const defaultAgentConfig = {
|
|
98
|
+
type: 'general',
|
|
99
|
+
prompt: 'Test prompt',
|
|
100
|
+
// No options.allowedTools - uses default tool list
|
|
101
|
+
};
|
|
102
|
+
|
|
103
|
+
// Sub agent (delegate task) - should not have ask_user
|
|
104
|
+
const subAgentConfig = {
|
|
105
|
+
type: 'delegate',
|
|
106
|
+
prompt: 'Delegate task',
|
|
107
|
+
// No options.allowedTools
|
|
108
|
+
};
|
|
109
|
+
|
|
110
|
+
// These configs should NOT have ask_user in their allowed tools
|
|
111
|
+
expect(defaultAgentConfig.options?.allowedTools).toBeUndefined();
|
|
112
|
+
expect(subAgentConfig.options?.allowedTools).toBeUndefined();
|
|
113
|
+
});
|
|
114
|
+
});
|
|
115
|
+
|
|
116
|
+
describe('WorkflowComponent initialization', () => {
|
|
117
|
+
it('should NOT register ask_user tool during init', () => {
|
|
118
|
+
// WorkflowComponent.init() should NOT call registerAskUserTool()
|
|
119
|
+
// This documents the expected behavior after refactoring
|
|
120
|
+
|
|
121
|
+
// The registerAskUserTool method exists but should NOT be called during init
|
|
122
|
+
// It has been removed from the init() and initSqliteService() methods
|
|
123
|
+
const shouldNotRegisterDuringInit = true; // This is the expected behavior
|
|
124
|
+
|
|
125
|
+
expect(shouldNotRegisterDuringInit).toBe(true);
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
it('should register ask_user only via AgentNode options', () => {
|
|
129
|
+
// The new design:
|
|
130
|
+
// - ask_user is not registered globally
|
|
131
|
+
// - AgentNode adds allowedTools: ['ask_user'] to its options when building AgentConfig
|
|
132
|
+
// - AgentComponentAdapter passes this to AgentContext
|
|
133
|
+
// - AgentComponent uses AgentContext.allowedTools to filter tools
|
|
134
|
+
|
|
135
|
+
const registrationPoints = {
|
|
136
|
+
duringInit: false,
|
|
137
|
+
viaAgentNodeOptions: true,
|
|
138
|
+
};
|
|
139
|
+
|
|
140
|
+
expect(registrationPoints.duringInit).toBe(false);
|
|
141
|
+
expect(registrationPoints.viaAgentNodeOptions).toBe(true);
|
|
142
|
+
});
|
|
143
|
+
});
|
|
144
|
+
|
|
145
|
+
describe('AgentContext.allowedTools propagation', () => {
|
|
146
|
+
it('should pass allowedTools from AgentNode to AgentContext', () => {
|
|
147
|
+
// Test the data flow:
|
|
148
|
+
// AgentNode (options.allowedTools: ['ask_user'])
|
|
149
|
+
// -> AgentComponentAdapter passes to context.allowedTools
|
|
150
|
+
// -> AgentContext (allowedTools: ['ask_user'])
|
|
151
|
+
// -> AgentComponent.run()
|
|
152
|
+
|
|
153
|
+
const agentNodeOptions = {
|
|
154
|
+
timeout: 60000,
|
|
155
|
+
model: 'gpt-4',
|
|
156
|
+
allowedTools: ['ask_user'],
|
|
157
|
+
};
|
|
158
|
+
|
|
159
|
+
// AgentComponentAdapter builds AgentContext
|
|
160
|
+
const agentContext = {
|
|
161
|
+
sessionId: 'test-session',
|
|
162
|
+
allowedTools: agentNodeOptions.allowedTools, // Pass through from options
|
|
163
|
+
deniedTools: agentNodeOptions.deniedTools,
|
|
164
|
+
};
|
|
165
|
+
|
|
166
|
+
expect(agentContext.allowedTools).toEqual(['ask_user']);
|
|
167
|
+
expect(agentContext.allowedTools).toBe(agentNodeOptions.allowedTools);
|
|
168
|
+
});
|
|
169
|
+
|
|
170
|
+
it('should NOT pass allowedTools for non-workflow agents', () => {
|
|
171
|
+
// Default agent and sub agent should NOT have allowedTools set in context
|
|
172
|
+
|
|
173
|
+
const defaultAgentContext = {
|
|
174
|
+
sessionId: 'default-session',
|
|
175
|
+
// No allowedTools - uses default tool list
|
|
176
|
+
};
|
|
177
|
+
|
|
178
|
+
const subAgentContext = {
|
|
179
|
+
sessionId: 'sub-agent-session',
|
|
180
|
+
// No allowedTools - uses default tool list
|
|
181
|
+
};
|
|
182
|
+
|
|
183
|
+
expect(defaultAgentContext.allowedTools).toBeUndefined();
|
|
184
|
+
expect(subAgentContext.allowedTools).toBeUndefined();
|
|
185
|
+
});
|
|
186
|
+
});
|
|
187
|
+
});
|
|
188
|
+
|
|
189
|
+
describe('AskUserTool Scope Enforcement', () => {
|
|
190
|
+
it('should enforce ask_user scope: workflow-only', () => {
|
|
191
|
+
// Document the scope rules:
|
|
192
|
+
// 1. Default Agent - NO access to ask_user
|
|
193
|
+
// 2. Sub Agent (delegate task) - NO access to ask_user
|
|
194
|
+
// 3. Workflow AgentNode - ONLY access when workflow is running
|
|
195
|
+
|
|
196
|
+
const toolScopeMatrix = {
|
|
197
|
+
defaultAgent: {
|
|
198
|
+
canAccess: false,
|
|
199
|
+
reason: 'ask_user is workflow-specific functionality',
|
|
200
|
+
},
|
|
201
|
+
subAgent: {
|
|
202
|
+
canAccess: false,
|
|
203
|
+
reason: 'delegate task is for autonomous execution, no human interruption',
|
|
204
|
+
},
|
|
205
|
+
workflowAgentNode: {
|
|
206
|
+
canAccess: true,
|
|
207
|
+
condition: 'only when workflow is running',
|
|
208
|
+
reason: 'enables human-in-loop for workflow pause/resume',
|
|
209
|
+
},
|
|
210
|
+
};
|
|
211
|
+
|
|
212
|
+
expect(toolScopeMatrix.defaultAgent.canAccess).toBe(false);
|
|
213
|
+
expect(toolScopeMatrix.subAgent.canAccess).toBe(false);
|
|
214
|
+
expect(toolScopeMatrix.workflowAgentNode.canAccess).toBe(true);
|
|
215
|
+
});
|
|
216
|
+
});
|