@n8n/instance-ai 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/LICENSE.md +88 -0
- package/dist/agent/instance-agent.d.ts +3 -0
- package/dist/agent/instance-agent.js +215 -0
- package/dist/agent/instance-agent.js.map +1 -0
- package/dist/agent/register-with-mastra.d.ts +3 -0
- package/dist/agent/register-with-mastra.js +19 -0
- package/dist/agent/register-with-mastra.js.map +1 -0
- package/dist/agent/sanitize-mcp-schemas.d.ts +2 -0
- package/dist/agent/sanitize-mcp-schemas.js +91 -0
- package/dist/agent/sanitize-mcp-schemas.js.map +1 -0
- package/dist/agent/sub-agent-factory.d.ts +14 -0
- package/dist/agent/sub-agent-factory.js +48 -0
- package/dist/agent/sub-agent-factory.js.map +1 -0
- package/dist/agent/system-prompt.d.ts +13 -0
- package/dist/agent/system-prompt.js +226 -0
- package/dist/agent/system-prompt.js.map +1 -0
- package/dist/build.tsbuildinfo +1 -0
- package/dist/compaction/compaction-helper.d.ts +9 -0
- package/dist/compaction/compaction-helper.js +58 -0
- package/dist/compaction/compaction-helper.js.map +1 -0
- package/dist/compaction/index.d.ts +2 -0
- package/dist/compaction/index.js +6 -0
- package/dist/compaction/index.js.map +1 -0
- package/dist/domain-access/domain-access-tracker.d.ts +9 -0
- package/dist/domain-access/domain-access-tracker.js +46 -0
- package/dist/domain-access/domain-access-tracker.js.map +1 -0
- package/dist/domain-access/domain-gating.d.ts +65 -0
- package/dist/domain-access/domain-gating.js +68 -0
- package/dist/domain-access/domain-gating.js.map +1 -0
- package/dist/domain-access/index.d.ts +4 -0
- package/dist/domain-access/index.js +11 -0
- package/dist/domain-access/index.js.map +1 -0
- package/dist/event-bus/event-bus.interface.d.ts +15 -0
- package/dist/event-bus/event-bus.interface.js +3 -0
- package/dist/event-bus/event-bus.interface.js.map +1 -0
- package/dist/event-bus/index.d.ts +1 -0
- package/dist/event-bus/index.js +3 -0
- package/dist/event-bus/index.js.map +1 -0
- package/dist/index.d.ts +46 -0
- package/dist/index.js +89 -0
- package/dist/index.js.map +1 -0
- package/dist/mcp/mcp-client-manager.d.ts +6 -0
- package/dist/mcp/mcp-client-manager.js +34 -0
- package/dist/mcp/mcp-client-manager.js.map +1 -0
- package/dist/memory/memory-config.d.ts +3 -0
- package/dist/memory/memory-config.js +29 -0
- package/dist/memory/memory-config.js.map +1 -0
- package/dist/memory/title-utils.d.ts +3 -0
- package/dist/memory/title-utils.js +42 -0
- package/dist/memory/title-utils.js.map +1 -0
- package/dist/memory/working-memory-template.d.ts +1 -0
- package/dist/memory/working-memory-template.js +25 -0
- package/dist/memory/working-memory-template.js.map +1 -0
- package/dist/planned-tasks/planned-task-service.d.ts +33 -0
- package/dist/planned-tasks/planned-task-service.js +151 -0
- package/dist/planned-tasks/planned-task-service.js.map +1 -0
- package/dist/runtime/background-task-manager.d.ts +53 -0
- package/dist/runtime/background-task-manager.js +127 -0
- package/dist/runtime/background-task-manager.js.map +1 -0
- package/dist/runtime/resumable-stream-executor.d.ts +75 -0
- package/dist/runtime/resumable-stream-executor.js +1552 -0
- package/dist/runtime/resumable-stream-executor.js.map +1 -0
- package/dist/runtime/run-state-registry.d.ts +109 -0
- package/dist/runtime/run-state-registry.js +210 -0
- package/dist/runtime/run-state-registry.js.map +1 -0
- package/dist/runtime/stream-runner.d.ts +27 -0
- package/dist/runtime/stream-runner.js +87 -0
- package/dist/runtime/stream-runner.js.map +1 -0
- package/dist/runtime/working-memory-tracing.d.ts +19 -0
- package/dist/runtime/working-memory-tracing.js +111 -0
- package/dist/runtime/working-memory-tracing.js.map +1 -0
- package/dist/storage/agent-tree-snapshot.d.ts +7 -0
- package/dist/storage/agent-tree-snapshot.js +3 -0
- package/dist/storage/agent-tree-snapshot.js.map +1 -0
- package/dist/storage/index.d.ts +10 -0
- package/dist/storage/index.js +17 -0
- package/dist/storage/index.js.map +1 -0
- package/dist/storage/iteration-log.d.ts +30 -0
- package/dist/storage/iteration-log.js +31 -0
- package/dist/storage/iteration-log.js.map +1 -0
- package/dist/storage/mastra-iteration-log-storage.d.ts +10 -0
- package/dist/storage/mastra-iteration-log-storage.js +57 -0
- package/dist/storage/mastra-iteration-log-storage.js.map +1 -0
- package/dist/storage/mastra-task-storage.d.ts +9 -0
- package/dist/storage/mastra-task-storage.js +35 -0
- package/dist/storage/mastra-task-storage.js.map +1 -0
- package/dist/storage/planned-task-storage.d.ts +10 -0
- package/dist/storage/planned-task-storage.js +97 -0
- package/dist/storage/planned-task-storage.js.map +1 -0
- package/dist/storage/thread-patch.d.ts +16 -0
- package/dist/storage/thread-patch.js +50 -0
- package/dist/storage/thread-patch.js.map +1 -0
- package/dist/storage/workflow-loop-storage.d.ts +217 -0
- package/dist/storage/workflow-loop-storage.js +59 -0
- package/dist/storage/workflow-loop-storage.js.map +1 -0
- package/dist/stream/consume-with-hitl.d.ts +22 -0
- package/dist/stream/consume-with-hitl.js +29 -0
- package/dist/stream/consume-with-hitl.js.map +1 -0
- package/dist/stream/map-chunk.d.ts +2 -0
- package/dist/stream/map-chunk.js +224 -0
- package/dist/stream/map-chunk.js.map +1 -0
- package/dist/tools/best-practices/get-best-practices.tool.d.ts +12 -0
- package/dist/tools/best-practices/get-best-practices.tool.js +64 -0
- package/dist/tools/best-practices/get-best-practices.tool.js.map +1 -0
- package/dist/tools/best-practices/guides/chatbot.d.ts +1 -0
- package/dist/tools/best-practices/guides/chatbot.js +111 -0
- package/dist/tools/best-practices/guides/chatbot.js.map +1 -0
- package/dist/tools/best-practices/guides/content-generation.d.ts +1 -0
- package/dist/tools/best-practices/guides/content-generation.js +108 -0
- package/dist/tools/best-practices/guides/content-generation.js.map +1 -0
- package/dist/tools/best-practices/guides/data-extraction.d.ts +1 -0
- package/dist/tools/best-practices/guides/data-extraction.js +115 -0
- package/dist/tools/best-practices/guides/data-extraction.js.map +1 -0
- package/dist/tools/best-practices/guides/data-persistence.d.ts +1 -0
- package/dist/tools/best-practices/guides/data-persistence.js +198 -0
- package/dist/tools/best-practices/guides/data-persistence.js.map +1 -0
- package/dist/tools/best-practices/guides/data-transformation.d.ts +1 -0
- package/dist/tools/best-practices/guides/data-transformation.js +139 -0
- package/dist/tools/best-practices/guides/data-transformation.js.map +1 -0
- package/dist/tools/best-practices/guides/document-processing.d.ts +1 -0
- package/dist/tools/best-practices/guides/document-processing.js +326 -0
- package/dist/tools/best-practices/guides/document-processing.js.map +1 -0
- package/dist/tools/best-practices/guides/form-input.d.ts +1 -0
- package/dist/tools/best-practices/guides/form-input.js +166 -0
- package/dist/tools/best-practices/guides/form-input.js.map +1 -0
- package/dist/tools/best-practices/guides/notification.d.ts +1 -0
- package/dist/tools/best-practices/guides/notification.js +128 -0
- package/dist/tools/best-practices/guides/notification.js.map +1 -0
- package/dist/tools/best-practices/guides/scheduling.d.ts +1 -0
- package/dist/tools/best-practices/guides/scheduling.js +145 -0
- package/dist/tools/best-practices/guides/scheduling.js.map +1 -0
- package/dist/tools/best-practices/guides/scraping-and-research.d.ts +1 -0
- package/dist/tools/best-practices/guides/scraping-and-research.js +151 -0
- package/dist/tools/best-practices/guides/scraping-and-research.js.map +1 -0
- package/dist/tools/best-practices/guides/triage.d.ts +1 -0
- package/dist/tools/best-practices/guides/triage.js +142 -0
- package/dist/tools/best-practices/guides/triage.js.map +1 -0
- package/dist/tools/best-practices/index.d.ts +2 -0
- package/dist/tools/best-practices/index.js +34 -0
- package/dist/tools/best-practices/index.js.map +1 -0
- package/dist/tools/best-practices/techniques.d.ts +20 -0
- package/dist/tools/best-practices/techniques.js +40 -0
- package/dist/tools/best-practices/techniques.js.map +1 -0
- package/dist/tools/credentials/delete-credential.tool.d.ts +21 -0
- package/dist/tools/credentials/delete-credential.tool.js +51 -0
- package/dist/tools/credentials/delete-credential.tool.js.map +1 -0
- package/dist/tools/credentials/get-credential.tool.d.ts +4 -0
- package/dist/tools/credentials/get-credential.tool.js +26 -0
- package/dist/tools/credentials/get-credential.tool.js.map +1 -0
- package/dist/tools/credentials/list-credentials.tool.d.ts +6 -0
- package/dist/tools/credentials/list-credentials.tool.js +30 -0
- package/dist/tools/credentials/list-credentials.tool.js.map +1 -0
- package/dist/tools/credentials/search-credential-types.tool.d.ts +6 -0
- package/dist/tools/credentials/search-credential-types.tool.js +44 -0
- package/dist/tools/credentials/search-credential-types.tool.js.map +1 -0
- package/dist/tools/credentials/setup-credentials.tool.d.ts +73 -0
- package/dist/tools/credentials/setup-credentials.tool.js +134 -0
- package/dist/tools/credentials/setup-credentials.tool.js.map +1 -0
- package/dist/tools/credentials/test-credential.tool.d.ts +7 -0
- package/dist/tools/credentials/test-credential.tool.js +30 -0
- package/dist/tools/credentials/test-credential.tool.js.map +1 -0
- package/dist/tools/data-tables/add-data-table-column.tool.d.ts +27 -0
- package/dist/tools/data-tables/add-data-table-column.tool.js +60 -0
- package/dist/tools/data-tables/add-data-table-column.tool.js.map +1 -0
- package/dist/tools/data-tables/create-data-table.tool.d.ts +36 -0
- package/dist/tools/data-tables/create-data-table.tool.js +79 -0
- package/dist/tools/data-tables/create-data-table.tool.js.map +1 -0
- package/dist/tools/data-tables/delete-data-table-column.tool.d.ts +21 -0
- package/dist/tools/data-tables/delete-data-table-column.tool.js +48 -0
- package/dist/tools/data-tables/delete-data-table-column.tool.js.map +1 -0
- package/dist/tools/data-tables/delete-data-table-rows.tool.d.ts +29 -0
- package/dist/tools/data-tables/delete-data-table-rows.tool.js +63 -0
- package/dist/tools/data-tables/delete-data-table-rows.tool.js.map +1 -0
- package/dist/tools/data-tables/delete-data-table.tool.d.ts +20 -0
- package/dist/tools/data-tables/delete-data-table.tool.js +46 -0
- package/dist/tools/data-tables/delete-data-table.tool.js.map +1 -0
- package/dist/tools/data-tables/get-data-table-schema.tool.d.ts +11 -0
- package/dist/tools/data-tables/get-data-table-schema.tool.js +27 -0
- package/dist/tools/data-tables/get-data-table-schema.tool.js.map +1 -0
- package/dist/tools/data-tables/insert-data-table-rows.tool.d.ts +21 -0
- package/dist/tools/data-tables/insert-data-table-rows.tool.js +52 -0
- package/dist/tools/data-tables/insert-data-table-rows.tool.js.map +1 -0
- package/dist/tools/data-tables/list-data-tables.tool.d.ts +6 -0
- package/dist/tools/data-tables/list-data-tables.tool.js +32 -0
- package/dist/tools/data-tables/list-data-tables.tool.js.map +1 -0
- package/dist/tools/data-tables/query-data-table-rows.tool.d.ts +21 -0
- package/dist/tools/data-tables/query-data-table-rows.tool.js +54 -0
- package/dist/tools/data-tables/query-data-table-rows.tool.js.map +1 -0
- package/dist/tools/data-tables/rename-data-table-column.tool.d.ts +22 -0
- package/dist/tools/data-tables/rename-data-table-column.tool.js +49 -0
- package/dist/tools/data-tables/rename-data-table-column.tool.js.map +1 -0
- package/dist/tools/data-tables/update-data-table-rows.tool.d.ts +29 -0
- package/dist/tools/data-tables/update-data-table-rows.tool.js +57 -0
- package/dist/tools/data-tables/update-data-table-rows.tool.js.map +1 -0
- package/dist/tools/executions/debug-execution.tool.d.ts +4 -0
- package/dist/tools/executions/debug-execution.tool.js +41 -0
- package/dist/tools/executions/debug-execution.tool.js.map +1 -0
- package/dist/tools/executions/get-execution.tool.d.ts +4 -0
- package/dist/tools/executions/get-execution.tool.js +26 -0
- package/dist/tools/executions/get-execution.tool.js.map +1 -0
- package/dist/tools/executions/get-node-output.tool.d.ts +7 -0
- package/dist/tools/executions/get-node-output.tool.js +44 -0
- package/dist/tools/executions/get-node-output.tool.js.map +1 -0
- package/dist/tools/executions/list-executions.tool.d.ts +8 -0
- package/dist/tools/executions/list-executions.tool.js +45 -0
- package/dist/tools/executions/list-executions.tool.js.map +1 -0
- package/dist/tools/executions/run-workflow.tool.d.ts +24 -0
- package/dist/tools/executions/run-workflow.tool.js +82 -0
- package/dist/tools/executions/run-workflow.tool.js.map +1 -0
- package/dist/tools/executions/stop-execution.tool.d.ts +7 -0
- package/dist/tools/executions/stop-execution.tool.js +22 -0
- package/dist/tools/executions/stop-execution.tool.js.map +1 -0
- package/dist/tools/filesystem/create-tools-from-mcp-server.d.ts +3 -0
- package/dist/tools/filesystem/create-tools-from-mcp-server.js +61 -0
- package/dist/tools/filesystem/create-tools-from-mcp-server.js.map +1 -0
- package/dist/tools/filesystem/get-file-tree.tool.d.ts +22 -0
- package/dist/tools/filesystem/get-file-tree.tool.js +64 -0
- package/dist/tools/filesystem/get-file-tree.tool.js.map +1 -0
- package/dist/tools/filesystem/list-files.tool.d.ts +30 -0
- package/dist/tools/filesystem/list-files.tool.js +100 -0
- package/dist/tools/filesystem/list-files.tool.js.map +1 -0
- package/dist/tools/filesystem/read-file.tool.d.ts +25 -0
- package/dist/tools/filesystem/read-file.tool.js +83 -0
- package/dist/tools/filesystem/read-file.tool.js.map +1 -0
- package/dist/tools/filesystem/search-files.tool.d.ts +31 -0
- package/dist/tools/filesystem/search-files.tool.js +96 -0
- package/dist/tools/filesystem/search-files.tool.js.map +1 -0
- package/dist/tools/index.d.ts +2385 -0
- package/dist/tools/index.js +195 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/nodes/explore-node-resources.tool.d.ts +21 -0
- package/dist/tools/nodes/explore-node-resources.tool.js +71 -0
- package/dist/tools/nodes/explore-node-resources.tool.js.map +1 -0
- package/dist/tools/nodes/get-node-description.tool.d.ts +23 -0
- package/dist/tools/nodes/get-node-description.tool.js +52 -0
- package/dist/tools/nodes/get-node-description.tool.js.map +1 -0
- package/dist/tools/nodes/get-node-type-definition.tool.d.ts +17 -0
- package/dist/tools/nodes/get-node-type-definition.tool.js +73 -0
- package/dist/tools/nodes/get-node-type-definition.tool.js.map +1 -0
- package/dist/tools/nodes/get-suggested-nodes.tool.d.ts +14 -0
- package/dist/tools/nodes/get-suggested-nodes.tool.js +54 -0
- package/dist/tools/nodes/get-suggested-nodes.tool.js.map +1 -0
- package/dist/tools/nodes/list-nodes.tool.d.ts +6 -0
- package/dist/tools/nodes/list-nodes.tool.js +33 -0
- package/dist/tools/nodes/list-nodes.tool.js.map +1 -0
- package/dist/tools/nodes/node-search-engine.d.ts +18 -0
- package/dist/tools/nodes/node-search-engine.js +266 -0
- package/dist/tools/nodes/node-search-engine.js.map +1 -0
- package/dist/tools/nodes/node-search-engine.types.d.ts +38 -0
- package/dist/tools/nodes/node-search-engine.types.js +18 -0
- package/dist/tools/nodes/node-search-engine.types.js.map +1 -0
- package/dist/tools/nodes/search-nodes.tool.d.ts +28 -0
- package/dist/tools/nodes/search-nodes.tool.js +87 -0
- package/dist/tools/nodes/search-nodes.tool.js.map +1 -0
- package/dist/tools/nodes/suggested-nodes-data.d.ts +11 -0
- package/dist/tools/nodes/suggested-nodes-data.js +326 -0
- package/dist/tools/nodes/suggested-nodes-data.js.map +1 -0
- package/dist/tools/orchestration/browser-credential-setup.tool.d.ts +14 -0
- package/dist/tools/orchestration/browser-credential-setup.tool.js +429 -0
- package/dist/tools/orchestration/browser-credential-setup.tool.js.map +1 -0
- package/dist/tools/orchestration/build-workflow-agent.prompt.d.ts +2 -0
- package/dist/tools/orchestration/build-workflow-agent.prompt.js +836 -0
- package/dist/tools/orchestration/build-workflow-agent.prompt.js.map +1 -0
- package/dist/tools/orchestration/build-workflow-agent.tool.d.ts +23 -0
- package/dist/tools/orchestration/build-workflow-agent.tool.js +503 -0
- package/dist/tools/orchestration/build-workflow-agent.tool.js.map +1 -0
- package/dist/tools/orchestration/cancel-background-task.tool.d.ts +6 -0
- package/dist/tools/orchestration/cancel-background-task.tool.js +24 -0
- package/dist/tools/orchestration/cancel-background-task.tool.js.map +1 -0
- package/dist/tools/orchestration/correct-background-task.tool.d.ts +7 -0
- package/dist/tools/orchestration/correct-background-task.tool.js +41 -0
- package/dist/tools/orchestration/correct-background-task.tool.js.map +1 -0
- package/dist/tools/orchestration/data-table-agent.prompt.d.ts +1 -0
- package/dist/tools/orchestration/data-table-agent.prompt.js +29 -0
- package/dist/tools/orchestration/data-table-agent.prompt.js.map +1 -0
- package/dist/tools/orchestration/data-table-agent.tool.d.ts +21 -0
- package/dist/tools/orchestration/data-table-agent.tool.js +171 -0
- package/dist/tools/orchestration/data-table-agent.tool.js.map +1 -0
- package/dist/tools/orchestration/delegate.schemas.d.ts +32 -0
- package/dist/tools/orchestration/delegate.schemas.js +29 -0
- package/dist/tools/orchestration/delegate.schemas.js.map +1 -0
- package/dist/tools/orchestration/delegate.tool.d.ts +27 -0
- package/dist/tools/orchestration/delegate.tool.js +307 -0
- package/dist/tools/orchestration/delegate.tool.js.map +1 -0
- package/dist/tools/orchestration/display-utils.d.ts +1 -0
- package/dist/tools/orchestration/display-utils.js +8 -0
- package/dist/tools/orchestration/display-utils.js.map +1 -0
- package/dist/tools/orchestration/plan.tool.d.ts +45 -0
- package/dist/tools/orchestration/plan.tool.js +99 -0
- package/dist/tools/orchestration/plan.tool.js.map +1 -0
- package/dist/tools/orchestration/report-verification-verdict.tool.d.ts +14 -0
- package/dist/tools/orchestration/report-verification-verdict.tool.js +66 -0
- package/dist/tools/orchestration/report-verification-verdict.tool.js.map +1 -0
- package/dist/tools/orchestration/research-agent-prompt.d.ts +1 -0
- package/dist/tools/orchestration/research-agent-prompt.js +28 -0
- package/dist/tools/orchestration/research-agent-prompt.js.map +1 -0
- package/dist/tools/orchestration/research-with-agent.tool.d.ts +23 -0
- package/dist/tools/orchestration/research-with-agent.tool.js +160 -0
- package/dist/tools/orchestration/research-with-agent.tool.js.map +1 -0
- package/dist/tools/orchestration/tracing-utils.d.ts +20 -0
- package/dist/tools/orchestration/tracing-utils.js +102 -0
- package/dist/tools/orchestration/tracing-utils.js.map +1 -0
- package/dist/tools/orchestration/update-tasks.tool.d.ts +10 -0
- package/dist/tools/orchestration/update-tasks.tool.js +26 -0
- package/dist/tools/orchestration/update-tasks.tool.js.map +1 -0
- package/dist/tools/orchestration/verify-built-workflow.tool.d.ts +13 -0
- package/dist/tools/orchestration/verify-built-workflow.tool.js +58 -0
- package/dist/tools/orchestration/verify-built-workflow.tool.js.map +1 -0
- package/dist/tools/shared/ask-user.tool.d.ts +61 -0
- package/dist/tools/shared/ask-user.tool.js +98 -0
- package/dist/tools/shared/ask-user.tool.js.map +1 -0
- package/dist/tools/templates/search-template-parameters.tool.d.ts +11 -0
- package/dist/tools/templates/search-template-parameters.tool.js +55 -0
- package/dist/tools/templates/search-template-parameters.tool.js.map +1 -0
- package/dist/tools/templates/search-template-structures.tool.d.ts +12 -0
- package/dist/tools/templates/search-template-structures.tool.js +45 -0
- package/dist/tools/templates/search-template-structures.tool.js.map +1 -0
- package/dist/tools/templates/template-api.d.ts +21 -0
- package/dist/tools/templates/template-api.js +104 -0
- package/dist/tools/templates/template-api.js.map +1 -0
- package/dist/tools/templates/types.d.ts +52 -0
- package/dist/tools/templates/types.js +37 -0
- package/dist/tools/templates/types.js.map +1 -0
- package/dist/tools/utils/mermaid.utils.d.ts +15 -0
- package/dist/tools/utils/mermaid.utils.js +622 -0
- package/dist/tools/utils/mermaid.utils.js.map +1 -0
- package/dist/tools/utils/node-configuration.utils.d.ts +6 -0
- package/dist/tools/utils/node-configuration.utils.js +77 -0
- package/dist/tools/utils/node-configuration.utils.js.map +1 -0
- package/dist/tools/web-research/fetch-url.tool.d.ts +27 -0
- package/dist/tools/web-research/fetch-url.tool.js +116 -0
- package/dist/tools/web-research/fetch-url.tool.js.map +1 -0
- package/dist/tools/web-research/index.d.ts +1 -0
- package/dist/tools/web-research/index.js +6 -0
- package/dist/tools/web-research/index.js.map +1 -0
- package/dist/tools/web-research/sanitize-web-content.d.ts +3 -0
- package/dist/tools/web-research/sanitize-web-content.js +36 -0
- package/dist/tools/web-research/sanitize-web-content.js.map +1 -0
- package/dist/tools/web-research/web-search.tool.d.ts +6 -0
- package/dist/tools/web-research/web-search.tool.js +57 -0
- package/dist/tools/web-research/web-search.tool.js.map +1 -0
- package/dist/tools/workflows/apply-workflow-credentials.tool.d.ts +10 -0
- package/dist/tools/workflows/apply-workflow-credentials.tool.js +87 -0
- package/dist/tools/workflows/apply-workflow-credentials.tool.js.map +1 -0
- package/dist/tools/workflows/build-workflow.tool.d.ts +16 -0
- package/dist/tools/workflows/build-workflow.tool.js +163 -0
- package/dist/tools/workflows/build-workflow.tool.js.map +1 -0
- package/dist/tools/workflows/delete-workflow.tool.d.ts +21 -0
- package/dist/tools/workflows/delete-workflow.tool.js +51 -0
- package/dist/tools/workflows/delete-workflow.tool.js.map +1 -0
- package/dist/tools/workflows/get-workflow-as-code.tool.d.ts +14 -0
- package/dist/tools/workflows/get-workflow-as-code.tool.js +37 -0
- package/dist/tools/workflows/get-workflow-as-code.tool.js.map +1 -0
- package/dist/tools/workflows/get-workflow-version.tool.d.ts +21 -0
- package/dist/tools/workflows/get-workflow-version.tool.js +38 -0
- package/dist/tools/workflows/get-workflow-version.tool.js.map +1 -0
- package/dist/tools/workflows/get-workflow.tool.d.ts +18 -0
- package/dist/tools/workflows/get-workflow.tool.js +36 -0
- package/dist/tools/workflows/get-workflow.tool.js.map +1 -0
- package/dist/tools/workflows/list-workflow-versions.tool.d.ts +8 -0
- package/dist/tools/workflows/list-workflow-versions.tool.js +47 -0
- package/dist/tools/workflows/list-workflow-versions.tool.js.map +1 -0
- package/dist/tools/workflows/list-workflows.tool.d.ts +14 -0
- package/dist/tools/workflows/list-workflows.tool.js +42 -0
- package/dist/tools/workflows/list-workflows.tool.js.map +1 -0
- package/dist/tools/workflows/materialize-node-type.tool.d.ts +23 -0
- package/dist/tools/workflows/materialize-node-type.tool.js +105 -0
- package/dist/tools/workflows/materialize-node-type.tool.js.map +1 -0
- package/dist/tools/workflows/publish-workflow.tool.d.ts +24 -0
- package/dist/tools/workflows/publish-workflow.tool.js +92 -0
- package/dist/tools/workflows/publish-workflow.tool.js.map +1 -0
- package/dist/tools/workflows/resolve-credentials.d.ts +14 -0
- package/dist/tools/workflows/resolve-credentials.js +89 -0
- package/dist/tools/workflows/resolve-credentials.js.map +1 -0
- package/dist/tools/workflows/restore-workflow-version.tool.d.ts +22 -0
- package/dist/tools/workflows/restore-workflow-version.tool.js +65 -0
- package/dist/tools/workflows/restore-workflow-version.tool.js.map +1 -0
- package/dist/tools/workflows/setup-workflow.schema.d.ts +331 -0
- package/dist/tools/workflows/setup-workflow.schema.js +21 -0
- package/dist/tools/workflows/setup-workflow.schema.js.map +1 -0
- package/dist/tools/workflows/setup-workflow.service.d.ts +40 -0
- package/dist/tools/workflows/setup-workflow.service.js +470 -0
- package/dist/tools/workflows/setup-workflow.service.js.map +1 -0
- package/dist/tools/workflows/setup-workflow.tool.d.ts +150 -0
- package/dist/tools/workflows/setup-workflow.tool.js +219 -0
- package/dist/tools/workflows/setup-workflow.tool.js.map +1 -0
- package/dist/tools/workflows/submit-workflow.tool.d.ts +33 -0
- package/dist/tools/workflows/submit-workflow.tool.js +258 -0
- package/dist/tools/workflows/submit-workflow.tool.js.map +1 -0
- package/dist/tools/workflows/unpublish-workflow.tool.d.ts +22 -0
- package/dist/tools/workflows/unpublish-workflow.tool.js +61 -0
- package/dist/tools/workflows/unpublish-workflow.tool.js.map +1 -0
- package/dist/tools/workflows/update-workflow-version.tool.d.ts +9 -0
- package/dist/tools/workflows/update-workflow-version.tool.js +35 -0
- package/dist/tools/workflows/update-workflow-version.tool.js.map +1 -0
- package/dist/tools/workflows/write-sandbox-file.tool.d.ts +13 -0
- package/dist/tools/workflows/write-sandbox-file.tool.js +53 -0
- package/dist/tools/workflows/write-sandbox-file.tool.js.map +1 -0
- package/dist/tools/workspace/cleanup-test-executions.tool.d.ts +22 -0
- package/dist/tools/workspace/cleanup-test-executions.tool.js +58 -0
- package/dist/tools/workspace/cleanup-test-executions.tool.js.map +1 -0
- package/dist/tools/workspace/create-folder.tool.d.ts +24 -0
- package/dist/tools/workspace/create-folder.tool.js +59 -0
- package/dist/tools/workspace/create-folder.tool.js.map +1 -0
- package/dist/tools/workspace/delete-folder.tool.d.ts +24 -0
- package/dist/tools/workspace/delete-folder.tool.js +60 -0
- package/dist/tools/workspace/delete-folder.tool.js.map +1 -0
- package/dist/tools/workspace/list-folders.tool.d.ts +6 -0
- package/dist/tools/workspace/list-folders.tool.js +26 -0
- package/dist/tools/workspace/list-folders.tool.js.map +1 -0
- package/dist/tools/workspace/list-projects.tool.d.ts +4 -0
- package/dist/tools/workspace/list-projects.tool.js +24 -0
- package/dist/tools/workspace/list-projects.tool.js.map +1 -0
- package/dist/tools/workspace/list-tags.tool.d.ts +7 -0
- package/dist/tools/workspace/list-tags.tool.js +23 -0
- package/dist/tools/workspace/list-tags.tool.js.map +1 -0
- package/dist/tools/workspace/move-workflow-to-folder.tool.d.ts +23 -0
- package/dist/tools/workspace/move-workflow-to-folder.tool.js +56 -0
- package/dist/tools/workspace/move-workflow-to-folder.tool.js.map +1 -0
- package/dist/tools/workspace/tag-workflow.tool.d.ts +22 -0
- package/dist/tools/workspace/tag-workflow.tool.js +52 -0
- package/dist/tools/workspace/tag-workflow.tool.js.map +1 -0
- package/dist/tracing/langsmith-tracing.d.ts +56 -0
- package/dist/tracing/langsmith-tracing.js +810 -0
- package/dist/tracing/langsmith-tracing.js.map +1 -0
- package/dist/types.d.ts +709 -0
- package/dist/types.js +3 -0
- package/dist/types.js.map +1 -0
- package/dist/utils/agent-tree.d.ts +3 -0
- package/dist/utils/agent-tree.js +23 -0
- package/dist/utils/agent-tree.js.map +1 -0
- package/dist/utils/format-timestamp.d.ts +1 -0
- package/dist/utils/format-timestamp.js +19 -0
- package/dist/utils/format-timestamp.js.map +1 -0
- package/dist/utils/stream-helpers.d.ts +15 -0
- package/dist/utils/stream-helpers.js +26 -0
- package/dist/utils/stream-helpers.js.map +1 -0
- package/dist/workflow-builder/extract-code.d.ts +5 -0
- package/dist/workflow-builder/extract-code.js +105 -0
- package/dist/workflow-builder/extract-code.js.map +1 -0
- package/dist/workflow-builder/index.d.ts +5 -0
- package/dist/workflow-builder/index.js +19 -0
- package/dist/workflow-builder/index.js.map +1 -0
- package/dist/workflow-builder/parse-validate.d.ts +6 -0
- package/dist/workflow-builder/parse-validate.js +49 -0
- package/dist/workflow-builder/parse-validate.js.map +1 -0
- package/dist/workflow-builder/patch-code.d.ts +14 -0
- package/dist/workflow-builder/patch-code.js +117 -0
- package/dist/workflow-builder/patch-code.js.map +1 -0
- package/dist/workflow-builder/sdk-prompt-sections.d.ts +4 -0
- package/dist/workflow-builder/sdk-prompt-sections.js +517 -0
- package/dist/workflow-builder/sdk-prompt-sections.js.map +1 -0
- package/dist/workflow-builder/types.d.ts +11 -0
- package/dist/workflow-builder/types.js +3 -0
- package/dist/workflow-builder/types.js.map +1 -0
- package/dist/workflow-loop/guidance.d.ts +5 -0
- package/dist/workflow-loop/guidance.js +37 -0
- package/dist/workflow-loop/guidance.js.map +1 -0
- package/dist/workflow-loop/index.d.ts +5 -0
- package/dist/workflow-loop/index.js +25 -0
- package/dist/workflow-loop/index.js.map +1 -0
- package/dist/workflow-loop/runtime.d.ts +8 -0
- package/dist/workflow-loop/runtime.js +40 -0
- package/dist/workflow-loop/runtime.js.map +1 -0
- package/dist/workflow-loop/workflow-loop-controller.d.ts +11 -0
- package/dist/workflow-loop/workflow-loop-controller.js +212 -0
- package/dist/workflow-loop/workflow-loop-controller.js.map +1 -0
- package/dist/workflow-loop/workflow-loop-state.d.ts +189 -0
- package/dist/workflow-loop/workflow-loop-state.js +77 -0
- package/dist/workflow-loop/workflow-loop-state.js.map +1 -0
- package/dist/workflow-loop/workflow-task-service.d.ts +13 -0
- package/dist/workflow-loop/workflow-task-service.js +35 -0
- package/dist/workflow-loop/workflow-task-service.js.map +1 -0
- package/dist/workspace/builder-sandbox-factory.d.ts +25 -0
- package/dist/workspace/builder-sandbox-factory.js +199 -0
- package/dist/workspace/builder-sandbox-factory.js.map +1 -0
- package/dist/workspace/create-workspace.d.ts +33 -0
- package/dist/workspace/create-workspace.js +56 -0
- package/dist/workspace/create-workspace.js.map +1 -0
- package/dist/workspace/daytona-filesystem.d.ts +25 -0
- package/dist/workspace/daytona-filesystem.js +109 -0
- package/dist/workspace/daytona-filesystem.js.map +1 -0
- package/dist/workspace/n8n-sandbox-client.d.ts +105 -0
- package/dist/workspace/n8n-sandbox-client.js +335 -0
- package/dist/workspace/n8n-sandbox-client.js.map +1 -0
- package/dist/workspace/n8n-sandbox-filesystem.d.ts +25 -0
- package/dist/workspace/n8n-sandbox-filesystem.js +128 -0
- package/dist/workspace/n8n-sandbox-filesystem.js.map +1 -0
- package/dist/workspace/n8n-sandbox-image-manager.d.ts +5 -0
- package/dist/workspace/n8n-sandbox-image-manager.js +25 -0
- package/dist/workspace/n8n-sandbox-image-manager.js.map +1 -0
- package/dist/workspace/n8n-sandbox-sandbox.d.ts +27 -0
- package/dist/workspace/n8n-sandbox-sandbox.js +103 -0
- package/dist/workspace/n8n-sandbox-sandbox.js.map +1 -0
- package/dist/workspace/sandbox-fs.d.ts +9 -0
- package/dist/workspace/sandbox-fs.js +43 -0
- package/dist/workspace/sandbox-fs.js.map +1 -0
- package/dist/workspace/sandbox-setup.d.ts +11 -0
- package/dist/workspace/sandbox-setup.js +139 -0
- package/dist/workspace/sandbox-setup.js.map +1 -0
- package/dist/workspace/snapshot-manager.d.ts +8 -0
- package/dist/workspace/snapshot-manager.js +31 -0
- package/dist/workspace/snapshot-manager.js.map +1 -0
- package/package.json +54 -0
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createUpdateWorkflowVersionTool = createUpdateWorkflowVersionTool;
|
|
4
|
+
const tools_1 = require("@mastra/core/tools");
|
|
5
|
+
const zod_1 = require("zod");
|
|
6
|
+
function createUpdateWorkflowVersionTool(context) {
|
|
7
|
+
return (0, tools_1.createTool)({
|
|
8
|
+
id: 'update-workflow-version',
|
|
9
|
+
description: 'Update the name or description of a workflow version. Use to label versions ' +
|
|
10
|
+
'with meaningful names (e.g. "v1 – initial release") or add descriptions ' +
|
|
11
|
+
'explaining what changed. Only available when the named-versions license feature is active.',
|
|
12
|
+
inputSchema: zod_1.z.object({
|
|
13
|
+
workflowId: zod_1.z.string().describe('ID of the workflow'),
|
|
14
|
+
versionId: zod_1.z.string().describe('ID of the version to update'),
|
|
15
|
+
name: zod_1.z.string().nullable().optional().describe('New name for the version (null to clear)'),
|
|
16
|
+
description: zod_1.z
|
|
17
|
+
.string()
|
|
18
|
+
.nullable()
|
|
19
|
+
.optional()
|
|
20
|
+
.describe('New description for the version (null to clear)'),
|
|
21
|
+
}),
|
|
22
|
+
outputSchema: zod_1.z.object({
|
|
23
|
+
success: zod_1.z.boolean(),
|
|
24
|
+
error: zod_1.z.string().optional(),
|
|
25
|
+
}),
|
|
26
|
+
execute: async (input) => {
|
|
27
|
+
await context.workflowService.updateVersion(input.workflowId, input.versionId, {
|
|
28
|
+
name: input.name,
|
|
29
|
+
description: input.description,
|
|
30
|
+
});
|
|
31
|
+
return { success: true };
|
|
32
|
+
},
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=update-workflow-version.tool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"update-workflow-version.tool.js","sourceRoot":"","sources":["../../../src/tools/workflows/update-workflow-version.tool.ts"],"names":[],"mappings":";;AAKA,0EA6BC;AAlCD,8CAAgD;AAChD,6BAAwB;AAIxB,SAAgB,+BAA+B,CAAC,OAA0B;IACzE,OAAO,IAAA,kBAAU,EAAC;QACjB,EAAE,EAAE,yBAAyB;QAC7B,WAAW,EACV,8EAA8E;YAC9E,0EAA0E;YAC1E,4FAA4F;QAC7F,WAAW,EAAE,OAAC,CAAC,MAAM,CAAC;YACrB,UAAU,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,oBAAoB,CAAC;YACrD,SAAS,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,6BAA6B,CAAC;YAC7D,IAAI,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,0CAA0C,CAAC;YAC3F,WAAW,EAAE,OAAC;iBACZ,MAAM,EAAE;iBACR,QAAQ,EAAE;iBACV,QAAQ,EAAE;iBACV,QAAQ,CAAC,iDAAiD,CAAC;SAC7D,CAAC;QACF,YAAY,EAAE,OAAC,CAAC,MAAM,CAAC;YACtB,OAAO,EAAE,OAAC,CAAC,OAAO,EAAE;YACpB,KAAK,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;SAC5B,CAAC;QACF,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE;YACxB,MAAM,OAAO,CAAC,eAAe,CAAC,aAAc,CAAC,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,SAAS,EAAE;gBAC/E,IAAI,EAAE,KAAK,CAAC,IAAI;gBAChB,WAAW,EAAE,KAAK,CAAC,WAAW;aAC9B,CAAC,CAAC;YACH,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;QAC1B,CAAC;KACD,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { Workspace } from '@mastra/core/workspace';
|
|
2
|
+
export declare function createWriteSandboxFileTool(workspace: Workspace): import("@mastra/core/tools").Tool<{
|
|
3
|
+
content: string;
|
|
4
|
+
filePath: string;
|
|
5
|
+
}, {
|
|
6
|
+
success: boolean;
|
|
7
|
+
path: string;
|
|
8
|
+
error: string;
|
|
9
|
+
} | {
|
|
10
|
+
success: boolean;
|
|
11
|
+
path: string;
|
|
12
|
+
error?: undefined;
|
|
13
|
+
}, unknown, unknown, import("@mastra/core/tools").ToolExecutionContext<unknown, unknown, unknown>, "write-file", unknown>;
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.createWriteSandboxFileTool = createWriteSandboxFileTool;
|
|
7
|
+
const tools_1 = require("@mastra/core/tools");
|
|
8
|
+
const node_path_1 = __importDefault(require("node:path"));
|
|
9
|
+
const zod_1 = require("zod");
|
|
10
|
+
const sandbox_fs_1 = require("../../workspace/sandbox-fs");
|
|
11
|
+
const sandbox_setup_1 = require("../../workspace/sandbox-setup");
|
|
12
|
+
function createWriteSandboxFileTool(workspace) {
|
|
13
|
+
return (0, tools_1.createTool)({
|
|
14
|
+
id: 'write-file',
|
|
15
|
+
description: 'Write content to a file in the sandbox workspace. Creates parent directories automatically. ' +
|
|
16
|
+
'Use this to write workflow code to ~/workspace/src/workflow.ts.',
|
|
17
|
+
inputSchema: zod_1.z.object({
|
|
18
|
+
filePath: zod_1.z
|
|
19
|
+
.string()
|
|
20
|
+
.describe('Absolute path or path relative to ~/workspace/ (e.g. "src/workflow.ts")'),
|
|
21
|
+
content: zod_1.z.string().describe('The file content to write'),
|
|
22
|
+
}),
|
|
23
|
+
outputSchema: zod_1.z.object({
|
|
24
|
+
success: zod_1.z.boolean(),
|
|
25
|
+
path: zod_1.z.string(),
|
|
26
|
+
error: zod_1.z.string().optional(),
|
|
27
|
+
}),
|
|
28
|
+
execute: async ({ filePath, content }) => {
|
|
29
|
+
try {
|
|
30
|
+
const root = await (0, sandbox_setup_1.getWorkspaceRoot)(workspace);
|
|
31
|
+
const absPath = filePath.startsWith('/') ? filePath : `${root}/${filePath}`;
|
|
32
|
+
const normalized = node_path_1.default.posix.normalize(absPath);
|
|
33
|
+
if (normalized !== root && !normalized.startsWith(root + '/')) {
|
|
34
|
+
return {
|
|
35
|
+
success: false,
|
|
36
|
+
path: filePath,
|
|
37
|
+
error: `Path must be within workspace root (${root})`,
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
await (0, sandbox_fs_1.writeFileViaSandbox)(workspace, normalized, content);
|
|
41
|
+
return { success: true, path: normalized };
|
|
42
|
+
}
|
|
43
|
+
catch (error) {
|
|
44
|
+
return {
|
|
45
|
+
success: false,
|
|
46
|
+
path: filePath,
|
|
47
|
+
error: error instanceof Error ? error.message : 'Failed to write file',
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
},
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
//# sourceMappingURL=write-sandbox-file.tool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"write-sandbox-file.tool.js","sourceRoot":"","sources":["../../../src/tools/workflows/write-sandbox-file.tool.ts"],"names":[],"mappings":";;;;;AAgBA,gEA6CC;AArDD,8CAAgD;AAEhD,0DAA6B;AAC7B,6BAAwB;AAExB,2DAAiE;AACjE,iEAAiE;AAEjE,SAAgB,0BAA0B,CAAC,SAAoB;IAC9D,OAAO,IAAA,kBAAU,EAAC;QACjB,EAAE,EAAE,YAAY;QAChB,WAAW,EACV,8FAA8F;YAC9F,iEAAiE;QAClE,WAAW,EAAE,OAAC,CAAC,MAAM,CAAC;YACrB,QAAQ,EAAE,OAAC;iBACT,MAAM,EAAE;iBACR,QAAQ,CAAC,yEAAyE,CAAC;YACrF,OAAO,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,2BAA2B,CAAC;SACzD,CAAC;QACF,YAAY,EAAE,OAAC,CAAC,MAAM,CAAC;YACtB,OAAO,EAAE,OAAC,CAAC,OAAO,EAAE;YACpB,IAAI,EAAE,OAAC,CAAC,MAAM,EAAE;YAChB,KAAK,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;SAC5B,CAAC;QACF,OAAO,EAAE,KAAK,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,EAAE,EAAE;YACxC,IAAI,CAAC;gBACJ,MAAM,IAAI,GAAG,MAAM,IAAA,gCAAgB,EAAC,SAAS,CAAC,CAAC;gBAG/C,MAAM,OAAO,GAAG,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,IAAI,IAAI,QAAQ,EAAE,CAAC;gBAG5E,MAAM,UAAU,GAAG,mBAAI,CAAC,KAAK,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;gBACjD,IAAI,UAAU,KAAK,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,GAAG,GAAG,CAAC,EAAE,CAAC;oBAC/D,OAAO;wBACN,OAAO,EAAE,KAAK;wBACd,IAAI,EAAE,QAAQ;wBACd,KAAK,EAAE,uCAAuC,IAAI,GAAG;qBACrD,CAAC;gBACH,CAAC;gBAED,MAAM,IAAA,gCAAmB,EAAC,SAAS,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC;gBAC1D,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC;YAC5C,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBAChB,OAAO;oBACN,OAAO,EAAE,KAAK;oBACd,IAAI,EAAE,QAAQ;oBACd,KAAK,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,sBAAsB;iBACtE,CAAC;YACH,CAAC;QACF,CAAC;KACD,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { InstanceAiContext } from '../../types';
|
|
2
|
+
export declare function createCleanupTestExecutionsTool(context: InstanceAiContext): import("@mastra/core/tools").Tool<{
|
|
3
|
+
workflowId: string;
|
|
4
|
+
workflowName?: string | undefined;
|
|
5
|
+
olderThanHours?: number | undefined;
|
|
6
|
+
}, {
|
|
7
|
+
deletedCount: number;
|
|
8
|
+
denied?: boolean | undefined;
|
|
9
|
+
reason?: string | undefined;
|
|
10
|
+
}, {
|
|
11
|
+
message: string;
|
|
12
|
+
requestId: string;
|
|
13
|
+
severity: "destructive" | "warning" | "info";
|
|
14
|
+
}, {
|
|
15
|
+
approved: boolean;
|
|
16
|
+
}, import("@mastra/core/tools").ToolExecutionContext<{
|
|
17
|
+
message: string;
|
|
18
|
+
requestId: string;
|
|
19
|
+
severity: "destructive" | "warning" | "info";
|
|
20
|
+
}, {
|
|
21
|
+
approved: boolean;
|
|
22
|
+
}, unknown>, "cleanup-test-executions", unknown>;
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createCleanupTestExecutionsTool = createCleanupTestExecutionsTool;
|
|
4
|
+
const tools_1 = require("@mastra/core/tools");
|
|
5
|
+
const api_types_1 = require("@n8n/api-types");
|
|
6
|
+
const nanoid_1 = require("nanoid");
|
|
7
|
+
const zod_1 = require("zod");
|
|
8
|
+
function createCleanupTestExecutionsTool(context) {
|
|
9
|
+
return (0, tools_1.createTool)({
|
|
10
|
+
id: 'cleanup-test-executions',
|
|
11
|
+
description: 'Delete manual/test execution records for a workflow. Defaults to executions older than 1 hour. Requires confirmation.',
|
|
12
|
+
inputSchema: zod_1.z.object({
|
|
13
|
+
workflowId: zod_1.z.string().describe('ID of the workflow whose test executions to clean up'),
|
|
14
|
+
workflowName: zod_1.z
|
|
15
|
+
.string()
|
|
16
|
+
.optional()
|
|
17
|
+
.describe('Name of the workflow (for confirmation message)'),
|
|
18
|
+
olderThanHours: zod_1.z
|
|
19
|
+
.number()
|
|
20
|
+
.optional()
|
|
21
|
+
.describe('Only delete executions older than this many hours. Defaults to 1.'),
|
|
22
|
+
}),
|
|
23
|
+
outputSchema: zod_1.z.object({
|
|
24
|
+
deletedCount: zod_1.z.number(),
|
|
25
|
+
denied: zod_1.z.boolean().optional(),
|
|
26
|
+
reason: zod_1.z.string().optional(),
|
|
27
|
+
}),
|
|
28
|
+
suspendSchema: zod_1.z.object({
|
|
29
|
+
requestId: zod_1.z.string(),
|
|
30
|
+
message: zod_1.z.string(),
|
|
31
|
+
severity: api_types_1.instanceAiConfirmationSeveritySchema,
|
|
32
|
+
}),
|
|
33
|
+
resumeSchema: zod_1.z.object({
|
|
34
|
+
approved: zod_1.z.boolean(),
|
|
35
|
+
}),
|
|
36
|
+
execute: async (input, ctx) => {
|
|
37
|
+
const { resumeData, suspend } = ctx?.agent ?? {};
|
|
38
|
+
const needsApproval = context.permissions?.cleanupTestExecutions !== 'always_allow';
|
|
39
|
+
if (needsApproval && (resumeData === undefined || resumeData === null)) {
|
|
40
|
+
const hours = input.olderThanHours ?? 1;
|
|
41
|
+
await suspend?.({
|
|
42
|
+
requestId: (0, nanoid_1.nanoid)(),
|
|
43
|
+
message: `Delete test executions for workflow "${input.workflowName ?? input.workflowId}" older than ${hours} hour(s)?`,
|
|
44
|
+
severity: 'warning',
|
|
45
|
+
});
|
|
46
|
+
return { deletedCount: 0 };
|
|
47
|
+
}
|
|
48
|
+
if (resumeData !== undefined && resumeData !== null && !resumeData.approved) {
|
|
49
|
+
return { deletedCount: 0, denied: true, reason: 'User denied the action' };
|
|
50
|
+
}
|
|
51
|
+
const result = await context.workspaceService.cleanupTestExecutions(input.workflowId, {
|
|
52
|
+
olderThanHours: input.olderThanHours,
|
|
53
|
+
});
|
|
54
|
+
return { deletedCount: result.deletedCount };
|
|
55
|
+
},
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
//# sourceMappingURL=cleanup-test-executions.tool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cleanup-test-executions.tool.js","sourceRoot":"","sources":["../../../src/tools/workspace/cleanup-test-executions.tool.ts"],"names":[],"mappings":";;AAOA,0EAyDC;AAhED,8CAAgD;AAChD,8CAAsE;AACtE,mCAAgC;AAChC,6BAAwB;AAIxB,SAAgB,+BAA+B,CAAC,OAA0B;IACzE,OAAO,IAAA,kBAAU,EAAC;QACjB,EAAE,EAAE,yBAAyB;QAC7B,WAAW,EACV,uHAAuH;QACxH,WAAW,EAAE,OAAC,CAAC,MAAM,CAAC;YACrB,UAAU,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,sDAAsD,CAAC;YACvF,YAAY,EAAE,OAAC;iBACb,MAAM,EAAE;iBACR,QAAQ,EAAE;iBACV,QAAQ,CAAC,iDAAiD,CAAC;YAC7D,cAAc,EAAE,OAAC;iBACf,MAAM,EAAE;iBACR,QAAQ,EAAE;iBACV,QAAQ,CAAC,mEAAmE,CAAC;SAC/E,CAAC;QACF,YAAY,EAAE,OAAC,CAAC,MAAM,CAAC;YACtB,YAAY,EAAE,OAAC,CAAC,MAAM,EAAE;YACxB,MAAM,EAAE,OAAC,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE;YAC9B,MAAM,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;SAC7B,CAAC;QACF,aAAa,EAAE,OAAC,CAAC,MAAM,CAAC;YACvB,SAAS,EAAE,OAAC,CAAC,MAAM,EAAE;YACrB,OAAO,EAAE,OAAC,CAAC,MAAM,EAAE;YACnB,QAAQ,EAAE,gDAAoC;SAC9C,CAAC;QACF,YAAY,EAAE,OAAC,CAAC,MAAM,CAAC;YACtB,QAAQ,EAAE,OAAC,CAAC,OAAO,EAAE;SACrB,CAAC;QACF,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE;YAC7B,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,GAAG,GAAG,EAAE,KAAK,IAAI,EAAE,CAAC;YAEjD,MAAM,aAAa,GAAG,OAAO,CAAC,WAAW,EAAE,qBAAqB,KAAK,cAAc,CAAC;YAGpF,IAAI,aAAa,IAAI,CAAC,UAAU,KAAK,SAAS,IAAI,UAAU,KAAK,IAAI,CAAC,EAAE,CAAC;gBACxE,MAAM,KAAK,GAAG,KAAK,CAAC,cAAc,IAAI,CAAC,CAAC;gBACxC,MAAM,OAAO,EAAE,CAAC;oBACf,SAAS,EAAE,IAAA,eAAM,GAAE;oBACnB,OAAO,EAAE,wCAAwC,KAAK,CAAC,YAAY,IAAI,KAAK,CAAC,UAAU,gBAAgB,KAAK,WAAW;oBACvH,QAAQ,EAAE,SAAkB;iBAC5B,CAAC,CAAC;gBACH,OAAO,EAAE,YAAY,EAAE,CAAC,EAAE,CAAC;YAC5B,CAAC;YAGD,IAAI,UAAU,KAAK,SAAS,IAAI,UAAU,KAAK,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;gBAC7E,OAAO,EAAE,YAAY,EAAE,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,wBAAwB,EAAE,CAAC;YAC5E,CAAC;YAGD,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,gBAAiB,CAAC,qBAAqB,CAAC,KAAK,CAAC,UAAU,EAAE;gBACtF,cAAc,EAAE,KAAK,CAAC,cAAc;aACpC,CAAC,CAAC;YACH,OAAO,EAAE,YAAY,EAAE,MAAM,CAAC,YAAY,EAAE,CAAC;QAC9C,CAAC;KACD,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { InstanceAiContext } from '../../types';
|
|
2
|
+
export declare function createCreateFolderTool(context: InstanceAiContext): import("@mastra/core/tools").Tool<{
|
|
3
|
+
name: string;
|
|
4
|
+
projectId: string;
|
|
5
|
+
parentFolderId?: string | undefined;
|
|
6
|
+
}, import("../../types").FolderSummary | {
|
|
7
|
+
id: string;
|
|
8
|
+
name: string;
|
|
9
|
+
parentFolderId: null;
|
|
10
|
+
denied: boolean;
|
|
11
|
+
reason: string;
|
|
12
|
+
}, {
|
|
13
|
+
message: string;
|
|
14
|
+
requestId: string;
|
|
15
|
+
severity: "destructive" | "warning" | "info";
|
|
16
|
+
}, {
|
|
17
|
+
approved: boolean;
|
|
18
|
+
}, import("@mastra/core/tools").ToolExecutionContext<{
|
|
19
|
+
message: string;
|
|
20
|
+
requestId: string;
|
|
21
|
+
severity: "destructive" | "warning" | "info";
|
|
22
|
+
}, {
|
|
23
|
+
approved: boolean;
|
|
24
|
+
}, unknown>, "create-folder", unknown>;
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createCreateFolderTool = createCreateFolderTool;
|
|
4
|
+
const tools_1 = require("@mastra/core/tools");
|
|
5
|
+
const api_types_1 = require("@n8n/api-types");
|
|
6
|
+
const nanoid_1 = require("nanoid");
|
|
7
|
+
const zod_1 = require("zod");
|
|
8
|
+
function createCreateFolderTool(context) {
|
|
9
|
+
return (0, tools_1.createTool)({
|
|
10
|
+
id: 'create-folder',
|
|
11
|
+
description: 'Create a new folder in a project. Supports nesting via parentFolderId.',
|
|
12
|
+
inputSchema: zod_1.z.object({
|
|
13
|
+
name: zod_1.z.string().describe('Name for the new folder'),
|
|
14
|
+
projectId: zod_1.z.string().describe('ID of the project to create the folder in'),
|
|
15
|
+
parentFolderId: zod_1.z
|
|
16
|
+
.string()
|
|
17
|
+
.optional()
|
|
18
|
+
.describe('ID of the parent folder for nesting. Omit for root-level folder.'),
|
|
19
|
+
}),
|
|
20
|
+
outputSchema: zod_1.z.object({
|
|
21
|
+
id: zod_1.z.string(),
|
|
22
|
+
name: zod_1.z.string(),
|
|
23
|
+
parentFolderId: zod_1.z.string().nullable(),
|
|
24
|
+
denied: zod_1.z.boolean().optional(),
|
|
25
|
+
reason: zod_1.z.string().optional(),
|
|
26
|
+
}),
|
|
27
|
+
suspendSchema: zod_1.z.object({
|
|
28
|
+
requestId: zod_1.z.string(),
|
|
29
|
+
message: zod_1.z.string(),
|
|
30
|
+
severity: api_types_1.instanceAiConfirmationSeveritySchema,
|
|
31
|
+
}),
|
|
32
|
+
resumeSchema: zod_1.z.object({
|
|
33
|
+
approved: zod_1.z.boolean(),
|
|
34
|
+
}),
|
|
35
|
+
execute: async (input, ctx) => {
|
|
36
|
+
const { resumeData, suspend } = ctx?.agent ?? {};
|
|
37
|
+
const needsApproval = context.permissions?.createFolder !== 'always_allow';
|
|
38
|
+
if (needsApproval && (resumeData === undefined || resumeData === null)) {
|
|
39
|
+
await suspend?.({
|
|
40
|
+
requestId: (0, nanoid_1.nanoid)(),
|
|
41
|
+
message: `Create folder "${input.name}" in project "${input.projectId}"?`,
|
|
42
|
+
severity: 'info',
|
|
43
|
+
});
|
|
44
|
+
return { id: '', name: '', parentFolderId: null };
|
|
45
|
+
}
|
|
46
|
+
if (resumeData !== undefined && resumeData !== null && !resumeData.approved) {
|
|
47
|
+
return {
|
|
48
|
+
id: '',
|
|
49
|
+
name: '',
|
|
50
|
+
parentFolderId: null,
|
|
51
|
+
denied: true,
|
|
52
|
+
reason: 'User denied the action',
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
return await context.workspaceService.createFolder(input.name, input.projectId, input.parentFolderId);
|
|
56
|
+
},
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
//# sourceMappingURL=create-folder.tool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-folder.tool.js","sourceRoot":"","sources":["../../../src/tools/workspace/create-folder.tool.ts"],"names":[],"mappings":";;AAOA,wDA8DC;AArED,8CAAgD;AAChD,8CAAsE;AACtE,mCAAgC;AAChC,6BAAwB;AAIxB,SAAgB,sBAAsB,CAAC,OAA0B;IAChE,OAAO,IAAA,kBAAU,EAAC;QACjB,EAAE,EAAE,eAAe;QACnB,WAAW,EAAE,wEAAwE;QACrF,WAAW,EAAE,OAAC,CAAC,MAAM,CAAC;YACrB,IAAI,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,yBAAyB,CAAC;YACpD,SAAS,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,2CAA2C,CAAC;YAC3E,cAAc,EAAE,OAAC;iBACf,MAAM,EAAE;iBACR,QAAQ,EAAE;iBACV,QAAQ,CAAC,kEAAkE,CAAC;SAC9E,CAAC;QACF,YAAY,EAAE,OAAC,CAAC,MAAM,CAAC;YACtB,EAAE,EAAE,OAAC,CAAC,MAAM,EAAE;YACd,IAAI,EAAE,OAAC,CAAC,MAAM,EAAE;YAChB,cAAc,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YACrC,MAAM,EAAE,OAAC,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE;YAC9B,MAAM,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;SAC7B,CAAC;QACF,aAAa,EAAE,OAAC,CAAC,MAAM,CAAC;YACvB,SAAS,EAAE,OAAC,CAAC,MAAM,EAAE;YACrB,OAAO,EAAE,OAAC,CAAC,MAAM,EAAE;YACnB,QAAQ,EAAE,gDAAoC;SAC9C,CAAC;QACF,YAAY,EAAE,OAAC,CAAC,MAAM,CAAC;YACtB,QAAQ,EAAE,OAAC,CAAC,OAAO,EAAE;SACrB,CAAC;QACF,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE;YAC7B,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,GAAG,GAAG,EAAE,KAAK,IAAI,EAAE,CAAC;YAEjD,MAAM,aAAa,GAAG,OAAO,CAAC,WAAW,EAAE,YAAY,KAAK,cAAc,CAAC;YAG3E,IAAI,aAAa,IAAI,CAAC,UAAU,KAAK,SAAS,IAAI,UAAU,KAAK,IAAI,CAAC,EAAE,CAAC;gBACxE,MAAM,OAAO,EAAE,CAAC;oBACf,SAAS,EAAE,IAAA,eAAM,GAAE;oBACnB,OAAO,EAAE,kBAAkB,KAAK,CAAC,IAAI,iBAAiB,KAAK,CAAC,SAAS,IAAI;oBACzE,QAAQ,EAAE,MAAe;iBACzB,CAAC,CAAC;gBAEH,OAAO,EAAE,EAAE,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,cAAc,EAAE,IAAI,EAAE,CAAC;YACnD,CAAC;YAGD,IAAI,UAAU,KAAK,SAAS,IAAI,UAAU,KAAK,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;gBAC7E,OAAO;oBACN,EAAE,EAAE,EAAE;oBACN,IAAI,EAAE,EAAE;oBACR,cAAc,EAAE,IAAI;oBACpB,MAAM,EAAE,IAAI;oBACZ,MAAM,EAAE,wBAAwB;iBAChC,CAAC;YACH,CAAC;YAGD,OAAO,MAAM,OAAO,CAAC,gBAAiB,CAAC,YAAa,CACnD,KAAK,CAAC,IAAI,EACV,KAAK,CAAC,SAAS,EACf,KAAK,CAAC,cAAc,CACpB,CAAC;QACH,CAAC;KACD,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { InstanceAiContext } from '../../types';
|
|
2
|
+
export declare function createDeleteFolderTool(context: InstanceAiContext): import("@mastra/core/tools").Tool<{
|
|
3
|
+
projectId: string;
|
|
4
|
+
folderId: string;
|
|
5
|
+
folderName?: string | undefined;
|
|
6
|
+
transferToFolderId?: string | undefined;
|
|
7
|
+
transferToFolderName?: string | undefined;
|
|
8
|
+
}, {
|
|
9
|
+
success: boolean;
|
|
10
|
+
denied?: boolean | undefined;
|
|
11
|
+
reason?: string | undefined;
|
|
12
|
+
}, {
|
|
13
|
+
message: string;
|
|
14
|
+
requestId: string;
|
|
15
|
+
severity: "destructive" | "warning" | "info";
|
|
16
|
+
}, {
|
|
17
|
+
approved: boolean;
|
|
18
|
+
}, import("@mastra/core/tools").ToolExecutionContext<{
|
|
19
|
+
message: string;
|
|
20
|
+
requestId: string;
|
|
21
|
+
severity: "destructive" | "warning" | "info";
|
|
22
|
+
}, {
|
|
23
|
+
approved: boolean;
|
|
24
|
+
}, unknown>, "delete-folder", unknown>;
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createDeleteFolderTool = createDeleteFolderTool;
|
|
4
|
+
const tools_1 = require("@mastra/core/tools");
|
|
5
|
+
const api_types_1 = require("@n8n/api-types");
|
|
6
|
+
const nanoid_1 = require("nanoid");
|
|
7
|
+
const zod_1 = require("zod");
|
|
8
|
+
function createDeleteFolderTool(context) {
|
|
9
|
+
return (0, tools_1.createTool)({
|
|
10
|
+
id: 'delete-folder',
|
|
11
|
+
description: 'Delete a folder. Without transferToFolderId, contents are flattened to root and archived. With transferToFolderId, contents are moved first. Requires confirmation.',
|
|
12
|
+
inputSchema: zod_1.z.object({
|
|
13
|
+
folderId: zod_1.z.string().describe('ID of the folder to delete'),
|
|
14
|
+
folderName: zod_1.z.string().optional().describe('Name of the folder (for confirmation message)'),
|
|
15
|
+
projectId: zod_1.z.string().describe('ID of the project the folder belongs to'),
|
|
16
|
+
transferToFolderId: zod_1.z
|
|
17
|
+
.string()
|
|
18
|
+
.optional()
|
|
19
|
+
.describe('ID of a folder to move contents into before deletion. If omitted, contents are flattened to project root and archived.'),
|
|
20
|
+
transferToFolderName: zod_1.z
|
|
21
|
+
.string()
|
|
22
|
+
.optional()
|
|
23
|
+
.describe('Name of the transfer folder (for confirmation message)'),
|
|
24
|
+
}),
|
|
25
|
+
outputSchema: zod_1.z.object({
|
|
26
|
+
success: zod_1.z.boolean(),
|
|
27
|
+
denied: zod_1.z.boolean().optional(),
|
|
28
|
+
reason: zod_1.z.string().optional(),
|
|
29
|
+
}),
|
|
30
|
+
suspendSchema: zod_1.z.object({
|
|
31
|
+
requestId: zod_1.z.string(),
|
|
32
|
+
message: zod_1.z.string(),
|
|
33
|
+
severity: api_types_1.instanceAiConfirmationSeveritySchema,
|
|
34
|
+
}),
|
|
35
|
+
resumeSchema: zod_1.z.object({
|
|
36
|
+
approved: zod_1.z.boolean(),
|
|
37
|
+
}),
|
|
38
|
+
execute: async (input, ctx) => {
|
|
39
|
+
const { resumeData, suspend } = ctx?.agent ?? {};
|
|
40
|
+
const needsApproval = context.permissions?.deleteFolder !== 'always_allow';
|
|
41
|
+
if (needsApproval && (resumeData === undefined || resumeData === null)) {
|
|
42
|
+
const transferNote = input.transferToFolderId
|
|
43
|
+
? ` Contents will be moved to folder "${input.transferToFolderName ?? input.transferToFolderId}".`
|
|
44
|
+
: ' Contents will be flattened to project root and archived.';
|
|
45
|
+
await suspend?.({
|
|
46
|
+
requestId: (0, nanoid_1.nanoid)(),
|
|
47
|
+
message: `Delete folder "${input.folderName ?? input.folderId}"?${transferNote}`,
|
|
48
|
+
severity: 'destructive',
|
|
49
|
+
});
|
|
50
|
+
return { success: false };
|
|
51
|
+
}
|
|
52
|
+
if (resumeData !== undefined && resumeData !== null && !resumeData.approved) {
|
|
53
|
+
return { success: false, denied: true, reason: 'User denied the action' };
|
|
54
|
+
}
|
|
55
|
+
await context.workspaceService.deleteFolder(input.folderId, input.projectId, input.transferToFolderId);
|
|
56
|
+
return { success: true };
|
|
57
|
+
},
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=delete-folder.tool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delete-folder.tool.js","sourceRoot":"","sources":["../../../src/tools/workspace/delete-folder.tool.ts"],"names":[],"mappings":";;AAOA,wDAkEC;AAzED,8CAAgD;AAChD,8CAAsE;AACtE,mCAAgC;AAChC,6BAAwB;AAIxB,SAAgB,sBAAsB,CAAC,OAA0B;IAChE,OAAO,IAAA,kBAAU,EAAC;QACjB,EAAE,EAAE,eAAe;QACnB,WAAW,EACV,qKAAqK;QACtK,WAAW,EAAE,OAAC,CAAC,MAAM,CAAC;YACrB,QAAQ,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,4BAA4B,CAAC;YAC3D,UAAU,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,+CAA+C,CAAC;YAC3F,SAAS,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,yCAAyC,CAAC;YACzE,kBAAkB,EAAE,OAAC;iBACnB,MAAM,EAAE;iBACR,QAAQ,EAAE;iBACV,QAAQ,CACR,wHAAwH,CACxH;YACF,oBAAoB,EAAE,OAAC;iBACrB,MAAM,EAAE;iBACR,QAAQ,EAAE;iBACV,QAAQ,CAAC,wDAAwD,CAAC;SACpE,CAAC;QACF,YAAY,EAAE,OAAC,CAAC,MAAM,CAAC;YACtB,OAAO,EAAE,OAAC,CAAC,OAAO,EAAE;YACpB,MAAM,EAAE,OAAC,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE;YAC9B,MAAM,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;SAC7B,CAAC;QACF,aAAa,EAAE,OAAC,CAAC,MAAM,CAAC;YACvB,SAAS,EAAE,OAAC,CAAC,MAAM,EAAE;YACrB,OAAO,EAAE,OAAC,CAAC,MAAM,EAAE;YACnB,QAAQ,EAAE,gDAAoC;SAC9C,CAAC;QACF,YAAY,EAAE,OAAC,CAAC,MAAM,CAAC;YACtB,QAAQ,EAAE,OAAC,CAAC,OAAO,EAAE;SACrB,CAAC;QACF,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE;YAC7B,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,GAAG,GAAG,EAAE,KAAK,IAAI,EAAE,CAAC;YAEjD,MAAM,aAAa,GAAG,OAAO,CAAC,WAAW,EAAE,YAAY,KAAK,cAAc,CAAC;YAG3E,IAAI,aAAa,IAAI,CAAC,UAAU,KAAK,SAAS,IAAI,UAAU,KAAK,IAAI,CAAC,EAAE,CAAC;gBACxE,MAAM,YAAY,GAAG,KAAK,CAAC,kBAAkB;oBAC5C,CAAC,CAAC,sCAAsC,KAAK,CAAC,oBAAoB,IAAI,KAAK,CAAC,kBAAkB,IAAI;oBAClG,CAAC,CAAC,2DAA2D,CAAC;gBAC/D,MAAM,OAAO,EAAE,CAAC;oBACf,SAAS,EAAE,IAAA,eAAM,GAAE;oBACnB,OAAO,EAAE,kBAAkB,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC,QAAQ,KAAK,YAAY,EAAE;oBAChF,QAAQ,EAAE,aAAsB;iBAChC,CAAC,CAAC;gBAEH,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;YAC3B,CAAC;YAGD,IAAI,UAAU,KAAK,SAAS,IAAI,UAAU,KAAK,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;gBAC7E,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,wBAAwB,EAAE,CAAC;YAC3E,CAAC;YAGD,MAAM,OAAO,CAAC,gBAAiB,CAAC,YAAa,CAC5C,KAAK,CAAC,QAAQ,EACd,KAAK,CAAC,SAAS,EACf,KAAK,CAAC,kBAAkB,CACxB,CAAC;YACF,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;QAC1B,CAAC;KACD,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { InstanceAiContext } from '../../types';
|
|
2
|
+
export declare function createListFoldersTool(context: InstanceAiContext): import("@mastra/core/tools").Tool<{
|
|
3
|
+
projectId: string;
|
|
4
|
+
}, {
|
|
5
|
+
folders: import("../../types").FolderSummary[];
|
|
6
|
+
}, unknown, unknown, import("@mastra/core/tools").ToolExecutionContext<unknown, unknown, unknown>, "list-folders", unknown>;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createListFoldersTool = createListFoldersTool;
|
|
4
|
+
const tools_1 = require("@mastra/core/tools");
|
|
5
|
+
const zod_1 = require("zod");
|
|
6
|
+
function createListFoldersTool(context) {
|
|
7
|
+
return (0, tools_1.createTool)({
|
|
8
|
+
id: 'list-folders',
|
|
9
|
+
description: 'List folders in a project. Use this to understand the existing folder structure before organizing workflows.',
|
|
10
|
+
inputSchema: zod_1.z.object({
|
|
11
|
+
projectId: zod_1.z.string().describe('ID of the project to list folders in'),
|
|
12
|
+
}),
|
|
13
|
+
outputSchema: zod_1.z.object({
|
|
14
|
+
folders: zod_1.z.array(zod_1.z.object({
|
|
15
|
+
id: zod_1.z.string(),
|
|
16
|
+
name: zod_1.z.string(),
|
|
17
|
+
parentFolderId: zod_1.z.string().nullable(),
|
|
18
|
+
})),
|
|
19
|
+
}),
|
|
20
|
+
execute: async (input) => {
|
|
21
|
+
const folders = await context.workspaceService.listFolders(input.projectId);
|
|
22
|
+
return { folders };
|
|
23
|
+
},
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=list-folders.tool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"list-folders.tool.js","sourceRoot":"","sources":["../../../src/tools/workspace/list-folders.tool.ts"],"names":[],"mappings":";;AAKA,sDAsBC;AA3BD,8CAAgD;AAChD,6BAAwB;AAIxB,SAAgB,qBAAqB,CAAC,OAA0B;IAC/D,OAAO,IAAA,kBAAU,EAAC;QACjB,EAAE,EAAE,cAAc;QAClB,WAAW,EACV,8GAA8G;QAC/G,WAAW,EAAE,OAAC,CAAC,MAAM,CAAC;YACrB,SAAS,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,sCAAsC,CAAC;SACtE,CAAC;QACF,YAAY,EAAE,OAAC,CAAC,MAAM,CAAC;YACtB,OAAO,EAAE,OAAC,CAAC,KAAK,CACf,OAAC,CAAC,MAAM,CAAC;gBACR,EAAE,EAAE,OAAC,CAAC,MAAM,EAAE;gBACd,IAAI,EAAE,OAAC,CAAC,MAAM,EAAE;gBAChB,cAAc,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;aACrC,CAAC,CACF;SACD,CAAC;QACF,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE;YACxB,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,gBAAiB,CAAC,WAAY,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YAC9E,OAAO,EAAE,OAAO,EAAE,CAAC;QACpB,CAAC;KACD,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { InstanceAiContext } from '../../types';
|
|
2
|
+
export declare function createListProjectsTool(context: InstanceAiContext): import("@mastra/core/tools").Tool<{}, {
|
|
3
|
+
projects: import("../../types").ProjectSummary[];
|
|
4
|
+
}, unknown, unknown, import("@mastra/core/tools").ToolExecutionContext<unknown, unknown, unknown>, "list-projects", unknown>;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createListProjectsTool = createListProjectsTool;
|
|
4
|
+
const tools_1 = require("@mastra/core/tools");
|
|
5
|
+
const zod_1 = require("zod");
|
|
6
|
+
function createListProjectsTool(context) {
|
|
7
|
+
return (0, tools_1.createTool)({
|
|
8
|
+
id: 'list-projects',
|
|
9
|
+
description: 'List all projects accessible to the current user. Use this to discover project IDs before managing folders or organizing workflows within a project.',
|
|
10
|
+
inputSchema: zod_1.z.object({}),
|
|
11
|
+
outputSchema: zod_1.z.object({
|
|
12
|
+
projects: zod_1.z.array(zod_1.z.object({
|
|
13
|
+
id: zod_1.z.string(),
|
|
14
|
+
name: zod_1.z.string(),
|
|
15
|
+
type: zod_1.z.enum(['personal', 'team']),
|
|
16
|
+
})),
|
|
17
|
+
}),
|
|
18
|
+
execute: async () => {
|
|
19
|
+
const projects = await context.workspaceService.listProjects();
|
|
20
|
+
return { projects };
|
|
21
|
+
},
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=list-projects.tool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"list-projects.tool.js","sourceRoot":"","sources":["../../../src/tools/workspace/list-projects.tool.ts"],"names":[],"mappings":";;AAKA,wDAoBC;AAzBD,8CAAgD;AAChD,6BAAwB;AAIxB,SAAgB,sBAAsB,CAAC,OAA0B;IAChE,OAAO,IAAA,kBAAU,EAAC;QACjB,EAAE,EAAE,eAAe;QACnB,WAAW,EACV,sJAAsJ;QACvJ,WAAW,EAAE,OAAC,CAAC,MAAM,CAAC,EAAE,CAAC;QACzB,YAAY,EAAE,OAAC,CAAC,MAAM,CAAC;YACtB,QAAQ,EAAE,OAAC,CAAC,KAAK,CAChB,OAAC,CAAC,MAAM,CAAC;gBACR,EAAE,EAAE,OAAC,CAAC,MAAM,EAAE;gBACd,IAAI,EAAE,OAAC,CAAC,MAAM,EAAE;gBAChB,IAAI,EAAE,OAAC,CAAC,IAAI,CAAC,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;aAClC,CAAC,CACF;SACD,CAAC;QACF,OAAO,EAAE,KAAK,IAAI,EAAE;YACnB,MAAM,QAAQ,GAAG,MAAM,OAAO,CAAC,gBAAiB,CAAC,YAAY,EAAE,CAAC;YAChE,OAAO,EAAE,QAAQ,EAAE,CAAC;QACrB,CAAC;KACD,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { InstanceAiContext } from '../../types';
|
|
2
|
+
export declare function createListTagsTool(context: InstanceAiContext): import("@mastra/core/tools").Tool<{}, {
|
|
3
|
+
tags: {
|
|
4
|
+
id: string;
|
|
5
|
+
name: string;
|
|
6
|
+
}[];
|
|
7
|
+
}, unknown, unknown, import("@mastra/core/tools").ToolExecutionContext<unknown, unknown, unknown>, "list-tags", unknown>;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createListTagsTool = createListTagsTool;
|
|
4
|
+
const tools_1 = require("@mastra/core/tools");
|
|
5
|
+
const zod_1 = require("zod");
|
|
6
|
+
function createListTagsTool(context) {
|
|
7
|
+
return (0, tools_1.createTool)({
|
|
8
|
+
id: 'list-tags',
|
|
9
|
+
description: 'List all available tags. Use this to check existing tags before creating new ones.',
|
|
10
|
+
inputSchema: zod_1.z.object({}),
|
|
11
|
+
outputSchema: zod_1.z.object({
|
|
12
|
+
tags: zod_1.z.array(zod_1.z.object({
|
|
13
|
+
id: zod_1.z.string(),
|
|
14
|
+
name: zod_1.z.string(),
|
|
15
|
+
})),
|
|
16
|
+
}),
|
|
17
|
+
execute: async () => {
|
|
18
|
+
const tags = await context.workspaceService.listTags();
|
|
19
|
+
return { tags };
|
|
20
|
+
},
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=list-tags.tool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"list-tags.tool.js","sourceRoot":"","sources":["../../../src/tools/workspace/list-tags.tool.ts"],"names":[],"mappings":";;AAKA,gDAmBC;AAxBD,8CAAgD;AAChD,6BAAwB;AAIxB,SAAgB,kBAAkB,CAAC,OAA0B;IAC5D,OAAO,IAAA,kBAAU,EAAC;QACjB,EAAE,EAAE,WAAW;QACf,WAAW,EACV,oFAAoF;QACrF,WAAW,EAAE,OAAC,CAAC,MAAM,CAAC,EAAE,CAAC;QACzB,YAAY,EAAE,OAAC,CAAC,MAAM,CAAC;YACtB,IAAI,EAAE,OAAC,CAAC,KAAK,CACZ,OAAC,CAAC,MAAM,CAAC;gBACR,EAAE,EAAE,OAAC,CAAC,MAAM,EAAE;gBACd,IAAI,EAAE,OAAC,CAAC,MAAM,EAAE;aAChB,CAAC,CACF;SACD,CAAC;QACF,OAAO,EAAE,KAAK,IAAI,EAAE;YACnB,MAAM,IAAI,GAAG,MAAM,OAAO,CAAC,gBAAiB,CAAC,QAAQ,EAAE,CAAC;YACxD,OAAO,EAAE,IAAI,EAAE,CAAC;QACjB,CAAC;KACD,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import type { InstanceAiContext } from '../../types';
|
|
2
|
+
export declare function createMoveWorkflowToFolderTool(context: InstanceAiContext): import("@mastra/core/tools").Tool<{
|
|
3
|
+
workflowId: string;
|
|
4
|
+
folderId: string;
|
|
5
|
+
workflowName?: string | undefined;
|
|
6
|
+
folderName?: string | undefined;
|
|
7
|
+
}, {
|
|
8
|
+
success: boolean;
|
|
9
|
+
denied?: boolean | undefined;
|
|
10
|
+
reason?: string | undefined;
|
|
11
|
+
}, {
|
|
12
|
+
message: string;
|
|
13
|
+
requestId: string;
|
|
14
|
+
severity: "destructive" | "warning" | "info";
|
|
15
|
+
}, {
|
|
16
|
+
approved: boolean;
|
|
17
|
+
}, import("@mastra/core/tools").ToolExecutionContext<{
|
|
18
|
+
message: string;
|
|
19
|
+
requestId: string;
|
|
20
|
+
severity: "destructive" | "warning" | "info";
|
|
21
|
+
}, {
|
|
22
|
+
approved: boolean;
|
|
23
|
+
}, unknown>, "move-workflow-to-folder", unknown>;
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createMoveWorkflowToFolderTool = createMoveWorkflowToFolderTool;
|
|
4
|
+
const tools_1 = require("@mastra/core/tools");
|
|
5
|
+
const api_types_1 = require("@n8n/api-types");
|
|
6
|
+
const nanoid_1 = require("nanoid");
|
|
7
|
+
const zod_1 = require("zod");
|
|
8
|
+
function createMoveWorkflowToFolderTool(context) {
|
|
9
|
+
return (0, tools_1.createTool)({
|
|
10
|
+
id: 'move-workflow-to-folder',
|
|
11
|
+
description: 'Move a workflow into a folder. Non-destructive — the workflow is not modified.',
|
|
12
|
+
inputSchema: zod_1.z.object({
|
|
13
|
+
workflowId: zod_1.z.string().describe('ID of the workflow to move'),
|
|
14
|
+
workflowName: zod_1.z
|
|
15
|
+
.string()
|
|
16
|
+
.optional()
|
|
17
|
+
.describe('Name of the workflow (for confirmation message)'),
|
|
18
|
+
folderId: zod_1.z.string().describe('ID of the destination folder'),
|
|
19
|
+
folderName: zod_1.z
|
|
20
|
+
.string()
|
|
21
|
+
.optional()
|
|
22
|
+
.describe('Name of the destination folder (for confirmation message)'),
|
|
23
|
+
}),
|
|
24
|
+
outputSchema: zod_1.z.object({
|
|
25
|
+
success: zod_1.z.boolean(),
|
|
26
|
+
denied: zod_1.z.boolean().optional(),
|
|
27
|
+
reason: zod_1.z.string().optional(),
|
|
28
|
+
}),
|
|
29
|
+
suspendSchema: zod_1.z.object({
|
|
30
|
+
requestId: zod_1.z.string(),
|
|
31
|
+
message: zod_1.z.string(),
|
|
32
|
+
severity: api_types_1.instanceAiConfirmationSeveritySchema,
|
|
33
|
+
}),
|
|
34
|
+
resumeSchema: zod_1.z.object({
|
|
35
|
+
approved: zod_1.z.boolean(),
|
|
36
|
+
}),
|
|
37
|
+
execute: async (input, ctx) => {
|
|
38
|
+
const { resumeData, suspend } = ctx?.agent ?? {};
|
|
39
|
+
const needsApproval = context.permissions?.moveWorkflowToFolder !== 'always_allow';
|
|
40
|
+
if (needsApproval && (resumeData === undefined || resumeData === null)) {
|
|
41
|
+
await suspend?.({
|
|
42
|
+
requestId: (0, nanoid_1.nanoid)(),
|
|
43
|
+
message: `Move workflow "${input.workflowName ?? input.workflowId}" to folder "${input.folderName ?? input.folderId}"?`,
|
|
44
|
+
severity: 'info',
|
|
45
|
+
});
|
|
46
|
+
return { success: false };
|
|
47
|
+
}
|
|
48
|
+
if (resumeData !== undefined && resumeData !== null && !resumeData.approved) {
|
|
49
|
+
return { success: false, denied: true, reason: 'User denied the action' };
|
|
50
|
+
}
|
|
51
|
+
await context.workspaceService.moveWorkflowToFolder(input.workflowId, input.folderId);
|
|
52
|
+
return { success: true };
|
|
53
|
+
},
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
//# sourceMappingURL=move-workflow-to-folder.tool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"move-workflow-to-folder.tool.js","sourceRoot":"","sources":["../../../src/tools/workspace/move-workflow-to-folder.tool.ts"],"names":[],"mappings":";;AAOA,wEAuDC;AA9DD,8CAAgD;AAChD,8CAAsE;AACtE,mCAAgC;AAChC,6BAAwB;AAIxB,SAAgB,8BAA8B,CAAC,OAA0B;IACxE,OAAO,IAAA,kBAAU,EAAC;QACjB,EAAE,EAAE,yBAAyB;QAC7B,WAAW,EAAE,gFAAgF;QAC7F,WAAW,EAAE,OAAC,CAAC,MAAM,CAAC;YACrB,UAAU,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,4BAA4B,CAAC;YAC7D,YAAY,EAAE,OAAC;iBACb,MAAM,EAAE;iBACR,QAAQ,EAAE;iBACV,QAAQ,CAAC,iDAAiD,CAAC;YAC7D,QAAQ,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,8BAA8B,CAAC;YAC7D,UAAU,EAAE,OAAC;iBACX,MAAM,EAAE;iBACR,QAAQ,EAAE;iBACV,QAAQ,CAAC,2DAA2D,CAAC;SACvE,CAAC;QACF,YAAY,EAAE,OAAC,CAAC,MAAM,CAAC;YACtB,OAAO,EAAE,OAAC,CAAC,OAAO,EAAE;YACpB,MAAM,EAAE,OAAC,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE;YAC9B,MAAM,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;SAC7B,CAAC;QACF,aAAa,EAAE,OAAC,CAAC,MAAM,CAAC;YACvB,SAAS,EAAE,OAAC,CAAC,MAAM,EAAE;YACrB,OAAO,EAAE,OAAC,CAAC,MAAM,EAAE;YACnB,QAAQ,EAAE,gDAAoC;SAC9C,CAAC;QACF,YAAY,EAAE,OAAC,CAAC,MAAM,CAAC;YACtB,QAAQ,EAAE,OAAC,CAAC,OAAO,EAAE;SACrB,CAAC;QACF,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE;YAC7B,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,GAAG,GAAG,EAAE,KAAK,IAAI,EAAE,CAAC;YAEjD,MAAM,aAAa,GAAG,OAAO,CAAC,WAAW,EAAE,oBAAoB,KAAK,cAAc,CAAC;YAGnF,IAAI,aAAa,IAAI,CAAC,UAAU,KAAK,SAAS,IAAI,UAAU,KAAK,IAAI,CAAC,EAAE,CAAC;gBACxE,MAAM,OAAO,EAAE,CAAC;oBACf,SAAS,EAAE,IAAA,eAAM,GAAE;oBACnB,OAAO,EAAE,kBAAkB,KAAK,CAAC,YAAY,IAAI,KAAK,CAAC,UAAU,gBAAgB,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC,QAAQ,IAAI;oBACvH,QAAQ,EAAE,MAAe;iBACzB,CAAC,CAAC;gBAEH,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;YAC3B,CAAC;YAGD,IAAI,UAAU,KAAK,SAAS,IAAI,UAAU,KAAK,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;gBAC7E,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,wBAAwB,EAAE,CAAC;YAC3E,CAAC;YAGD,MAAM,OAAO,CAAC,gBAAiB,CAAC,oBAAqB,CAAC,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC;YACxF,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;QAC1B,CAAC;KACD,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { InstanceAiContext } from '../../types';
|
|
2
|
+
export declare function createTagWorkflowTool(context: InstanceAiContext): import("@mastra/core/tools").Tool<{
|
|
3
|
+
workflowId: string;
|
|
4
|
+
tags: string[];
|
|
5
|
+
workflowName?: string | undefined;
|
|
6
|
+
}, {
|
|
7
|
+
appliedTags: string[];
|
|
8
|
+
denied?: boolean | undefined;
|
|
9
|
+
reason?: string | undefined;
|
|
10
|
+
}, {
|
|
11
|
+
message: string;
|
|
12
|
+
requestId: string;
|
|
13
|
+
severity: "destructive" | "warning" | "info";
|
|
14
|
+
}, {
|
|
15
|
+
approved: boolean;
|
|
16
|
+
}, import("@mastra/core/tools").ToolExecutionContext<{
|
|
17
|
+
message: string;
|
|
18
|
+
requestId: string;
|
|
19
|
+
severity: "destructive" | "warning" | "info";
|
|
20
|
+
}, {
|
|
21
|
+
approved: boolean;
|
|
22
|
+
}, unknown>, "tag-workflow", unknown>;
|