@cicctencent/agent-server 0.1.1
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/README.md +235 -0
- package/dist/cjs/agent/agent-server.d.ts +6 -0
- package/dist/cjs/agent/agent-server.d.ts.map +1 -0
- package/dist/cjs/agent/agent-server.js +412 -0
- package/dist/cjs/agent/agent-server.js.map +1 -0
- package/dist/cjs/connectors/index.d.ts +13 -0
- package/dist/cjs/connectors/index.d.ts.map +1 -0
- package/dist/cjs/connectors/index.js +37 -0
- package/dist/cjs/connectors/index.js.map +1 -0
- package/dist/cjs/index.d.ts +56 -0
- package/dist/cjs/index.d.ts.map +1 -0
- package/dist/cjs/index.js +169 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/kb/doc-parser.d.ts +24 -0
- package/dist/cjs/kb/doc-parser.d.ts.map +1 -0
- package/dist/cjs/kb/doc-parser.js +137 -0
- package/dist/cjs/kb/doc-parser.js.map +1 -0
- package/dist/cjs/kb/embedding-vector-index.d.ts +30 -0
- package/dist/cjs/kb/embedding-vector-index.d.ts.map +1 -0
- package/dist/cjs/kb/embedding-vector-index.js +75 -0
- package/dist/cjs/kb/embedding-vector-index.js.map +1 -0
- package/dist/cjs/kb/file-knowledge-base.d.ts +25 -0
- package/dist/cjs/kb/file-knowledge-base.d.ts.map +1 -0
- package/dist/cjs/kb/file-knowledge-base.js +200 -0
- package/dist/cjs/kb/file-knowledge-base.js.map +1 -0
- package/dist/cjs/mcp/api-bridge-client.d.ts +36 -0
- package/dist/cjs/mcp/api-bridge-client.d.ts.map +1 -0
- package/dist/cjs/mcp/api-bridge-client.js +143 -0
- package/dist/cjs/mcp/api-bridge-client.js.map +1 -0
- package/dist/cjs/mcp/api-bridge-types.d.ts +91 -0
- package/dist/cjs/mcp/api-bridge-types.d.ts.map +1 -0
- package/dist/cjs/mcp/api-bridge-types.js +8 -0
- package/dist/cjs/mcp/api-bridge-types.js.map +1 -0
- package/dist/cjs/mcp/body-template.d.ts +16 -0
- package/dist/cjs/mcp/body-template.d.ts.map +1 -0
- package/dist/cjs/mcp/body-template.js +62 -0
- package/dist/cjs/mcp/body-template.js.map +1 -0
- package/dist/cjs/mcp/openapi-importer.d.ts +24 -0
- package/dist/cjs/mcp/openapi-importer.d.ts.map +1 -0
- package/dist/cjs/mcp/openapi-importer.js +183 -0
- package/dist/cjs/mcp/openapi-importer.js.map +1 -0
- package/dist/cjs/mcp/template-builder.d.ts +53 -0
- package/dist/cjs/mcp/template-builder.d.ts.map +1 -0
- package/dist/cjs/mcp/template-builder.js +177 -0
- package/dist/cjs/mcp/template-builder.js.map +1 -0
- package/dist/cjs/model/automation.d.ts +34 -0
- package/dist/cjs/model/automation.d.ts.map +1 -0
- package/dist/cjs/model/automation.js +6 -0
- package/dist/cjs/model/automation.js.map +1 -0
- package/dist/cjs/package.json +3 -0
- package/dist/cjs/prompt/prompt-builder.d.ts +14 -0
- package/dist/cjs/prompt/prompt-builder.d.ts.map +1 -0
- package/dist/cjs/prompt/prompt-builder.js +113 -0
- package/dist/cjs/prompt/prompt-builder.js.map +1 -0
- package/dist/cjs/sandbox/local-sandbox.d.ts +70 -0
- package/dist/cjs/sandbox/local-sandbox.d.ts.map +1 -0
- package/dist/cjs/sandbox/local-sandbox.js +442 -0
- package/dist/cjs/sandbox/local-sandbox.js.map +1 -0
- package/dist/cjs/sandbox/process-code-sandbox.d.ts +25 -0
- package/dist/cjs/sandbox/process-code-sandbox.d.ts.map +1 -0
- package/dist/cjs/sandbox/process-code-sandbox.js +113 -0
- package/dist/cjs/sandbox/process-code-sandbox.js.map +1 -0
- package/dist/cjs/sandbox/sandbox-manager.d.ts +47 -0
- package/dist/cjs/sandbox/sandbox-manager.d.ts.map +1 -0
- package/dist/cjs/sandbox/sandbox-manager.js +126 -0
- package/dist/cjs/sandbox/sandbox-manager.js.map +1 -0
- package/dist/cjs/service/agent-profile.service.d.ts +27 -0
- package/dist/cjs/service/agent-profile.service.d.ts.map +1 -0
- package/dist/cjs/service/agent-profile.service.js +143 -0
- package/dist/cjs/service/agent-profile.service.js.map +1 -0
- package/dist/cjs/service/artifact.service.d.ts +33 -0
- package/dist/cjs/service/artifact.service.d.ts.map +1 -0
- package/dist/cjs/service/artifact.service.js +214 -0
- package/dist/cjs/service/artifact.service.js.map +1 -0
- package/dist/cjs/service/audit.service.d.ts +30 -0
- package/dist/cjs/service/audit.service.d.ts.map +1 -0
- package/dist/cjs/service/audit.service.js +169 -0
- package/dist/cjs/service/audit.service.js.map +1 -0
- package/dist/cjs/service/chat.service.d.ts +90 -0
- package/dist/cjs/service/chat.service.d.ts.map +1 -0
- package/dist/cjs/service/chat.service.js +433 -0
- package/dist/cjs/service/chat.service.js.map +1 -0
- package/dist/cjs/service/engine-pool.d.ts +6 -0
- package/dist/cjs/service/engine-pool.d.ts.map +1 -0
- package/dist/cjs/service/engine-pool.js +24 -0
- package/dist/cjs/service/engine-pool.js.map +1 -0
- package/dist/cjs/service/memory.service.d.ts +45 -0
- package/dist/cjs/service/memory.service.d.ts.map +1 -0
- package/dist/cjs/service/memory.service.js +193 -0
- package/dist/cjs/service/memory.service.js.map +1 -0
- package/dist/cjs/service/observability.service.d.ts +3 -0
- package/dist/cjs/service/observability.service.d.ts.map +1 -0
- package/dist/cjs/service/observability.service.js +10 -0
- package/dist/cjs/service/observability.service.js.map +1 -0
- package/dist/cjs/service/permission.service.d.ts +5 -0
- package/dist/cjs/service/permission.service.d.ts.map +1 -0
- package/dist/cjs/service/permission.service.js +40 -0
- package/dist/cjs/service/permission.service.js.map +1 -0
- package/dist/cjs/service/run-registry.d.ts +7 -0
- package/dist/cjs/service/run-registry.d.ts.map +1 -0
- package/dist/cjs/service/run-registry.js +44 -0
- package/dist/cjs/service/run-registry.js.map +1 -0
- package/dist/cjs/service/safety-audit.middleware.d.ts +3 -0
- package/dist/cjs/service/safety-audit.middleware.d.ts.map +1 -0
- package/dist/cjs/service/safety-audit.middleware.js +115 -0
- package/dist/cjs/service/safety-audit.middleware.js.map +1 -0
- package/dist/cjs/service/security-policy.service.d.ts +18 -0
- package/dist/cjs/service/security-policy.service.d.ts.map +1 -0
- package/dist/cjs/service/security-policy.service.js +46 -0
- package/dist/cjs/service/security-policy.service.js.map +1 -0
- package/dist/cjs/service/settings.service.d.ts +18 -0
- package/dist/cjs/service/settings.service.d.ts.map +1 -0
- package/dist/cjs/service/settings.service.js +222 -0
- package/dist/cjs/service/settings.service.js.map +1 -0
- package/dist/cjs/service/tool-risk.service.d.ts +3 -0
- package/dist/cjs/service/tool-risk.service.d.ts.map +1 -0
- package/dist/cjs/service/tool-risk.service.js +23 -0
- package/dist/cjs/service/tool-risk.service.js.map +1 -0
- package/dist/cjs/service/workspace.service.d.ts +33 -0
- package/dist/cjs/service/workspace.service.d.ts.map +1 -0
- package/dist/cjs/service/workspace.service.js +107 -0
- package/dist/cjs/service/workspace.service.js.map +1 -0
- package/dist/cjs/sse/sse-handler.d.ts +15 -0
- package/dist/cjs/sse/sse-handler.d.ts.map +1 -0
- package/dist/cjs/sse/sse-handler.js +56 -0
- package/dist/cjs/sse/sse-handler.js.map +1 -0
- package/dist/cjs/store/app-stores.d.ts +42 -0
- package/dist/cjs/store/app-stores.d.ts.map +1 -0
- package/dist/cjs/store/app-stores.js +226 -0
- package/dist/cjs/store/app-stores.js.map +1 -0
- package/dist/cjs/store/index.d.ts +3 -0
- package/dist/cjs/store/index.d.ts.map +1 -0
- package/dist/cjs/store/index.js +10 -0
- package/dist/cjs/store/index.js.map +1 -0
- package/dist/cjs/store/mcp-server-store.d.ts +35 -0
- package/dist/cjs/store/mcp-server-store.d.ts.map +1 -0
- package/dist/cjs/store/mcp-server-store.js +288 -0
- package/dist/cjs/store/mcp-server-store.js.map +1 -0
- package/dist/cjs/tool/builtin.d.ts +18 -0
- package/dist/cjs/tool/builtin.d.ts.map +1 -0
- package/dist/cjs/tool/builtin.js +43 -0
- package/dist/cjs/tool/builtin.js.map +1 -0
- package/dist/cjs/tool/local-executors.d.ts +22 -0
- package/dist/cjs/tool/local-executors.d.ts.map +1 -0
- package/dist/cjs/tool/local-executors.js +126 -0
- package/dist/cjs/tool/local-executors.js.map +1 -0
- package/dist/cjs/tool/tools/automation.d.ts +3 -0
- package/dist/cjs/tool/tools/automation.d.ts.map +1 -0
- package/dist/cjs/tool/tools/automation.js +190 -0
- package/dist/cjs/tool/tools/automation.js.map +1 -0
- package/dist/cjs/tool/tools/communication.d.ts +3 -0
- package/dist/cjs/tool/tools/communication.d.ts.map +1 -0
- package/dist/cjs/tool/tools/communication.js +302 -0
- package/dist/cjs/tool/tools/communication.js.map +1 -0
- package/dist/cjs/tool/tools/discovery.d.ts +3 -0
- package/dist/cjs/tool/tools/discovery.d.ts.map +1 -0
- package/dist/cjs/tool/tools/discovery.js +248 -0
- package/dist/cjs/tool/tools/discovery.js.map +1 -0
- package/dist/cjs/tool/tools/filesystem.d.ts +3 -0
- package/dist/cjs/tool/tools/filesystem.d.ts.map +1 -0
- package/dist/cjs/tool/tools/filesystem.js +403 -0
- package/dist/cjs/tool/tools/filesystem.js.map +1 -0
- package/dist/cjs/tool/tools/git.d.ts +3 -0
- package/dist/cjs/tool/tools/git.d.ts.map +1 -0
- package/dist/cjs/tool/tools/git.js +224 -0
- package/dist/cjs/tool/tools/git.js.map +1 -0
- package/dist/cjs/tool/tools/memory.d.ts +3 -0
- package/dist/cjs/tool/tools/memory.d.ts.map +1 -0
- package/dist/cjs/tool/tools/memory.js +126 -0
- package/dist/cjs/tool/tools/memory.js.map +1 -0
- package/dist/cjs/tool/tools/sandbox.d.ts +3 -0
- package/dist/cjs/tool/tools/sandbox.d.ts.map +1 -0
- package/dist/cjs/tool/tools/sandbox.js +413 -0
- package/dist/cjs/tool/tools/sandbox.js.map +1 -0
- package/dist/cjs/tool/tools/web-utils.d.ts +16 -0
- package/dist/cjs/tool/tools/web-utils.d.ts.map +1 -0
- package/dist/cjs/tool/tools/web-utils.js +131 -0
- package/dist/cjs/tool/tools/web-utils.js.map +1 -0
- package/dist/cjs/tool/tools/web.d.ts +3 -0
- package/dist/cjs/tool/tools/web.d.ts.map +1 -0
- package/dist/cjs/tool/tools/web.js +358 -0
- package/dist/cjs/tool/tools/web.js.map +1 -0
- package/dist/cjs/types.d.ts +523 -0
- package/dist/cjs/types.d.ts.map +1 -0
- package/dist/cjs/types.js +6 -0
- package/dist/cjs/types.js.map +1 -0
- package/dist/cjs/utils/data-dir.d.ts +8 -0
- package/dist/cjs/utils/data-dir.d.ts.map +1 -0
- package/dist/cjs/utils/data-dir.js +92 -0
- package/dist/cjs/utils/data-dir.js.map +1 -0
- package/dist/esm/agent/agent-server.d.ts +6 -0
- package/dist/esm/agent/agent-server.d.ts.map +1 -0
- package/dist/esm/agent/agent-server.js +409 -0
- package/dist/esm/agent/agent-server.js.map +1 -0
- package/dist/esm/connectors/index.d.ts +13 -0
- package/dist/esm/connectors/index.d.ts.map +1 -0
- package/dist/esm/connectors/index.js +30 -0
- package/dist/esm/connectors/index.js.map +1 -0
- package/dist/esm/index.d.ts +56 -0
- package/dist/esm/index.d.ts.map +1 -0
- package/dist/esm/index.js +57 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/kb/doc-parser.d.ts +24 -0
- package/dist/esm/kb/doc-parser.d.ts.map +1 -0
- package/dist/esm/kb/doc-parser.js +100 -0
- package/dist/esm/kb/doc-parser.js.map +1 -0
- package/dist/esm/kb/embedding-vector-index.d.ts +30 -0
- package/dist/esm/kb/embedding-vector-index.d.ts.map +1 -0
- package/dist/esm/kb/embedding-vector-index.js +71 -0
- package/dist/esm/kb/embedding-vector-index.js.map +1 -0
- package/dist/esm/kb/file-knowledge-base.d.ts +25 -0
- package/dist/esm/kb/file-knowledge-base.d.ts.map +1 -0
- package/dist/esm/kb/file-knowledge-base.js +163 -0
- package/dist/esm/kb/file-knowledge-base.js.map +1 -0
- package/dist/esm/mcp/api-bridge-client.d.ts +36 -0
- package/dist/esm/mcp/api-bridge-client.d.ts.map +1 -0
- package/dist/esm/mcp/api-bridge-client.js +139 -0
- package/dist/esm/mcp/api-bridge-client.js.map +1 -0
- package/dist/esm/mcp/api-bridge-types.d.ts +91 -0
- package/dist/esm/mcp/api-bridge-types.d.ts.map +1 -0
- package/dist/esm/mcp/api-bridge-types.js +7 -0
- package/dist/esm/mcp/api-bridge-types.js.map +1 -0
- package/dist/esm/mcp/body-template.d.ts +16 -0
- package/dist/esm/mcp/body-template.d.ts.map +1 -0
- package/dist/esm/mcp/body-template.js +59 -0
- package/dist/esm/mcp/body-template.js.map +1 -0
- package/dist/esm/mcp/openapi-importer.d.ts +24 -0
- package/dist/esm/mcp/openapi-importer.d.ts.map +1 -0
- package/dist/esm/mcp/openapi-importer.js +177 -0
- package/dist/esm/mcp/openapi-importer.js.map +1 -0
- package/dist/esm/mcp/template-builder.d.ts +53 -0
- package/dist/esm/mcp/template-builder.d.ts.map +1 -0
- package/dist/esm/mcp/template-builder.js +173 -0
- package/dist/esm/mcp/template-builder.js.map +1 -0
- package/dist/esm/model/automation.d.ts +34 -0
- package/dist/esm/model/automation.d.ts.map +1 -0
- package/dist/esm/model/automation.js +5 -0
- package/dist/esm/model/automation.js.map +1 -0
- package/dist/esm/package.json +3 -0
- package/dist/esm/prompt/prompt-builder.d.ts +14 -0
- package/dist/esm/prompt/prompt-builder.d.ts.map +1 -0
- package/dist/esm/prompt/prompt-builder.js +109 -0
- package/dist/esm/prompt/prompt-builder.js.map +1 -0
- package/dist/esm/sandbox/local-sandbox.d.ts +70 -0
- package/dist/esm/sandbox/local-sandbox.d.ts.map +1 -0
- package/dist/esm/sandbox/local-sandbox.js +403 -0
- package/dist/esm/sandbox/local-sandbox.js.map +1 -0
- package/dist/esm/sandbox/process-code-sandbox.d.ts +25 -0
- package/dist/esm/sandbox/process-code-sandbox.d.ts.map +1 -0
- package/dist/esm/sandbox/process-code-sandbox.js +76 -0
- package/dist/esm/sandbox/process-code-sandbox.js.map +1 -0
- package/dist/esm/sandbox/sandbox-manager.d.ts +47 -0
- package/dist/esm/sandbox/sandbox-manager.d.ts.map +1 -0
- package/dist/esm/sandbox/sandbox-manager.js +88 -0
- package/dist/esm/sandbox/sandbox-manager.js.map +1 -0
- package/dist/esm/service/agent-profile.service.d.ts +27 -0
- package/dist/esm/service/agent-profile.service.d.ts.map +1 -0
- package/dist/esm/service/agent-profile.service.js +130 -0
- package/dist/esm/service/agent-profile.service.js.map +1 -0
- package/dist/esm/service/artifact.service.d.ts +33 -0
- package/dist/esm/service/artifact.service.d.ts.map +1 -0
- package/dist/esm/service/artifact.service.js +175 -0
- package/dist/esm/service/artifact.service.js.map +1 -0
- package/dist/esm/service/audit.service.d.ts +30 -0
- package/dist/esm/service/audit.service.d.ts.map +1 -0
- package/dist/esm/service/audit.service.js +131 -0
- package/dist/esm/service/audit.service.js.map +1 -0
- package/dist/esm/service/chat.service.d.ts +90 -0
- package/dist/esm/service/chat.service.d.ts.map +1 -0
- package/dist/esm/service/chat.service.js +388 -0
- package/dist/esm/service/chat.service.js.map +1 -0
- package/dist/esm/service/engine-pool.d.ts +6 -0
- package/dist/esm/service/engine-pool.d.ts.map +1 -0
- package/dist/esm/service/engine-pool.js +18 -0
- package/dist/esm/service/engine-pool.js.map +1 -0
- package/dist/esm/service/memory.service.d.ts +45 -0
- package/dist/esm/service/memory.service.d.ts.map +1 -0
- package/dist/esm/service/memory.service.js +154 -0
- package/dist/esm/service/memory.service.js.map +1 -0
- package/dist/esm/service/observability.service.d.ts +3 -0
- package/dist/esm/service/observability.service.d.ts.map +1 -0
- package/dist/esm/service/observability.service.js +5 -0
- package/dist/esm/service/observability.service.js.map +1 -0
- package/dist/esm/service/permission.service.d.ts +5 -0
- package/dist/esm/service/permission.service.d.ts.map +1 -0
- package/dist/esm/service/permission.service.js +33 -0
- package/dist/esm/service/permission.service.js.map +1 -0
- package/dist/esm/service/run-registry.d.ts +7 -0
- package/dist/esm/service/run-registry.d.ts.map +1 -0
- package/dist/esm/service/run-registry.js +37 -0
- package/dist/esm/service/run-registry.js.map +1 -0
- package/dist/esm/service/safety-audit.middleware.d.ts +3 -0
- package/dist/esm/service/safety-audit.middleware.d.ts.map +1 -0
- package/dist/esm/service/safety-audit.middleware.js +112 -0
- package/dist/esm/service/safety-audit.middleware.js.map +1 -0
- package/dist/esm/service/security-policy.service.d.ts +18 -0
- package/dist/esm/service/security-policy.service.d.ts.map +1 -0
- package/dist/esm/service/security-policy.service.js +42 -0
- package/dist/esm/service/security-policy.service.js.map +1 -0
- package/dist/esm/service/settings.service.d.ts +18 -0
- package/dist/esm/service/settings.service.d.ts.map +1 -0
- package/dist/esm/service/settings.service.js +181 -0
- package/dist/esm/service/settings.service.js.map +1 -0
- package/dist/esm/service/tool-risk.service.d.ts +3 -0
- package/dist/esm/service/tool-risk.service.d.ts.map +1 -0
- package/dist/esm/service/tool-risk.service.js +17 -0
- package/dist/esm/service/tool-risk.service.js.map +1 -0
- package/dist/esm/service/workspace.service.d.ts +33 -0
- package/dist/esm/service/workspace.service.d.ts.map +1 -0
- package/dist/esm/service/workspace.service.js +97 -0
- package/dist/esm/service/workspace.service.js.map +1 -0
- package/dist/esm/sse/sse-handler.d.ts +15 -0
- package/dist/esm/sse/sse-handler.d.ts.map +1 -0
- package/dist/esm/sse/sse-handler.js +49 -0
- package/dist/esm/sse/sse-handler.js.map +1 -0
- package/dist/esm/store/app-stores.d.ts +42 -0
- package/dist/esm/store/app-stores.d.ts.map +1 -0
- package/dist/esm/store/app-stores.js +181 -0
- package/dist/esm/store/app-stores.js.map +1 -0
- package/dist/esm/store/index.d.ts +3 -0
- package/dist/esm/store/index.d.ts.map +1 -0
- package/dist/esm/store/index.js +5 -0
- package/dist/esm/store/index.js.map +1 -0
- package/dist/esm/store/mcp-server-store.d.ts +35 -0
- package/dist/esm/store/mcp-server-store.d.ts.map +1 -0
- package/dist/esm/store/mcp-server-store.js +251 -0
- package/dist/esm/store/mcp-server-store.js.map +1 -0
- package/dist/esm/tool/builtin.d.ts +18 -0
- package/dist/esm/tool/builtin.d.ts.map +1 -0
- package/dist/esm/tool/builtin.js +40 -0
- package/dist/esm/tool/builtin.js.map +1 -0
- package/dist/esm/tool/local-executors.d.ts +22 -0
- package/dist/esm/tool/local-executors.d.ts.map +1 -0
- package/dist/esm/tool/local-executors.js +88 -0
- package/dist/esm/tool/local-executors.js.map +1 -0
- package/dist/esm/tool/tools/automation.d.ts +3 -0
- package/dist/esm/tool/tools/automation.d.ts.map +1 -0
- package/dist/esm/tool/tools/automation.js +154 -0
- package/dist/esm/tool/tools/automation.js.map +1 -0
- package/dist/esm/tool/tools/communication.d.ts +3 -0
- package/dist/esm/tool/tools/communication.d.ts.map +1 -0
- package/dist/esm/tool/tools/communication.js +266 -0
- package/dist/esm/tool/tools/communication.js.map +1 -0
- package/dist/esm/tool/tools/discovery.d.ts +3 -0
- package/dist/esm/tool/tools/discovery.d.ts.map +1 -0
- package/dist/esm/tool/tools/discovery.js +245 -0
- package/dist/esm/tool/tools/discovery.js.map +1 -0
- package/dist/esm/tool/tools/filesystem.d.ts +3 -0
- package/dist/esm/tool/tools/filesystem.d.ts.map +1 -0
- package/dist/esm/tool/tools/filesystem.js +367 -0
- package/dist/esm/tool/tools/filesystem.js.map +1 -0
- package/dist/esm/tool/tools/git.d.ts +3 -0
- package/dist/esm/tool/tools/git.d.ts.map +1 -0
- package/dist/esm/tool/tools/git.js +188 -0
- package/dist/esm/tool/tools/git.js.map +1 -0
- package/dist/esm/tool/tools/memory.d.ts +3 -0
- package/dist/esm/tool/tools/memory.d.ts.map +1 -0
- package/dist/esm/tool/tools/memory.js +123 -0
- package/dist/esm/tool/tools/memory.js.map +1 -0
- package/dist/esm/tool/tools/sandbox.d.ts +3 -0
- package/dist/esm/tool/tools/sandbox.d.ts.map +1 -0
- package/dist/esm/tool/tools/sandbox.js +377 -0
- package/dist/esm/tool/tools/sandbox.js.map +1 -0
- package/dist/esm/tool/tools/web-utils.d.ts +16 -0
- package/dist/esm/tool/tools/web-utils.d.ts.map +1 -0
- package/dist/esm/tool/tools/web-utils.js +88 -0
- package/dist/esm/tool/tools/web-utils.js.map +1 -0
- package/dist/esm/tool/tools/web.d.ts +3 -0
- package/dist/esm/tool/tools/web.d.ts.map +1 -0
- package/dist/esm/tool/tools/web.js +319 -0
- package/dist/esm/tool/tools/web.js.map +1 -0
- package/dist/esm/types.d.ts +523 -0
- package/dist/esm/types.d.ts.map +1 -0
- package/dist/esm/types.js +5 -0
- package/dist/esm/types.js.map +1 -0
- package/dist/esm/utils/data-dir.d.ts +8 -0
- package/dist/esm/utils/data-dir.d.ts.map +1 -0
- package/dist/esm/utils/data-dir.js +48 -0
- package/dist/esm/utils/data-dir.js.map +1 -0
- package/package.json +56 -0
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @file LocalSandboxManager — 沙箱生命周期管理
|
|
3
|
+
* @description 管理沙箱的创建、获取、销毁,沙箱目录统一在 {cwd}/data/sandboxes/ 下
|
|
4
|
+
*/
|
|
5
|
+
import * as path from 'path';
|
|
6
|
+
import { LocalSandbox } from "./local-sandbox.js";
|
|
7
|
+
import { getProjectDataPath } from "../utils/data-dir.js";
|
|
8
|
+
/**
|
|
9
|
+
* 本地沙箱管理器
|
|
10
|
+
* - 创建沙箱时自动在 baseDir/{id} 下创建隔离目录
|
|
11
|
+
* - 支持获取已创建的沙箱实例
|
|
12
|
+
* - 销毁时清理沙箱目录
|
|
13
|
+
*/
|
|
14
|
+
export class LocalSandboxManager {
|
|
15
|
+
sandboxes = new Map();
|
|
16
|
+
baseDir;
|
|
17
|
+
constructor(baseDir) {
|
|
18
|
+
this.baseDir = baseDir || getProjectDataPath('sandboxes');
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* 创建沙箱(复用已有实例)
|
|
22
|
+
* 同一 thread 的多次对话复用同一个沙箱,避免销毁导致 artifacts 丢失。
|
|
23
|
+
* 如需强制清理,请先调用 destroy()。
|
|
24
|
+
*/
|
|
25
|
+
async create(id, config) {
|
|
26
|
+
// 复用已有沙箱:保留 _artifacts/ 等目录,避免历史产物丢失
|
|
27
|
+
const existing = this.sandboxes.get(id);
|
|
28
|
+
if (existing) {
|
|
29
|
+
return existing;
|
|
30
|
+
}
|
|
31
|
+
const rootDir = config?.rootDir || path.join(this.baseDir, id);
|
|
32
|
+
const fullConfig = {
|
|
33
|
+
rootDir,
|
|
34
|
+
...config,
|
|
35
|
+
};
|
|
36
|
+
const sandbox = new LocalSandbox(id, fullConfig);
|
|
37
|
+
await sandbox.init();
|
|
38
|
+
this.sandboxes.set(id, sandbox);
|
|
39
|
+
return sandbox;
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* 获取已创建的沙箱
|
|
43
|
+
*/
|
|
44
|
+
get(id) {
|
|
45
|
+
return this.sandboxes.get(id);
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* 销毁指定沙箱(清理目录 + 移除引用)
|
|
49
|
+
*/
|
|
50
|
+
async destroy(id) {
|
|
51
|
+
const sandbox = this.sandboxes.get(id);
|
|
52
|
+
if (sandbox) {
|
|
53
|
+
await sandbox.destroy();
|
|
54
|
+
this.sandboxes.delete(id);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* 销毁所有沙箱
|
|
59
|
+
*/
|
|
60
|
+
async destroyAll() {
|
|
61
|
+
const destroyPromises = [...this.sandboxes.keys()].map(id => this.destroy(id));
|
|
62
|
+
await Promise.allSettled(destroyPromises);
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* 获取当前活跃沙箱数量
|
|
66
|
+
*/
|
|
67
|
+
get size() {
|
|
68
|
+
return this.sandboxes.size;
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* 获取所有活跃沙箱 ID
|
|
72
|
+
*/
|
|
73
|
+
listIds() {
|
|
74
|
+
return [...this.sandboxes.keys()];
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
// ---- 单例导出 ----
|
|
78
|
+
let defaultManager = null;
|
|
79
|
+
/**
|
|
80
|
+
* 获取默认沙箱管理器单例
|
|
81
|
+
*/
|
|
82
|
+
export function getSandboxManager() {
|
|
83
|
+
if (!defaultManager) {
|
|
84
|
+
defaultManager = new LocalSandboxManager();
|
|
85
|
+
}
|
|
86
|
+
return defaultManager;
|
|
87
|
+
}
|
|
88
|
+
//# sourceMappingURL=sandbox-manager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sandbox-manager.js","sourceRoot":"","sources":["../../../src/sandbox/sandbox-manager.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAE7B,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAE1D;;;;;GAKG;AACH,MAAM,OAAO,mBAAmB;IACtB,SAAS,GAAG,IAAI,GAAG,EAAwB,CAAC;IACnC,OAAO,CAAS;IAEjC,YAAY,OAAgB;QAC1B,IAAI,CAAC,OAAO,GAAG,OAAO,IAAI,kBAAkB,CAAC,WAAW,CAAC,CAAC;IAC5D,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,MAAM,CAAC,EAAU,EAAE,MAA+B;QACtD,qCAAqC;QACrC,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACxC,IAAI,QAAQ,EAAE,CAAC;YACb,OAAO,QAAQ,CAAC;QAClB,CAAC;QAED,MAAM,OAAO,GAAG,MAAM,EAAE,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QAC/D,MAAM,UAAU,GAAkB;YAChC,OAAO;YACP,GAAG,MAAM;SACV,CAAC;QAEF,MAAM,OAAO,GAAG,IAAI,YAAY,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC;QACjD,MAAM,OAAO,CAAC,IAAI,EAAE,CAAC;QAErB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;QAChC,OAAO,OAAO,CAAC;IACjB,CAAC;IAED;;OAEG;IACH,GAAG,CAAC,EAAU;QACZ,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAChC,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,OAAO,CAAC,EAAU;QACtB,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACvC,IAAI,OAAO,EAAE,CAAC;YACZ,MAAM,OAAO,CAAC,OAAO,EAAE,CAAC;YACxB,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QAC5B,CAAC;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,UAAU;QACd,MAAM,eAAe,GAAG,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC;QAC/E,MAAM,OAAO,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC;IAC5C,CAAC;IAED;;OAEG;IACH,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;IAC7B,CAAC;IAED;;OAEG;IACH,OAAO;QACL,OAAO,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC,CAAC;IACpC,CAAC;CACF;AAED,iBAAiB;AAEjB,IAAI,cAAc,GAA+B,IAAI,CAAC;AAEtD;;GAEG;AACH,MAAM,UAAU,iBAAiB;IAC/B,IAAI,CAAC,cAAc,EAAE,CAAC;QACpB,cAAc,GAAG,IAAI,mBAAmB,EAAE,CAAC;IAC7C,CAAC;IACD,OAAO,cAAc,CAAC;AACxB,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import type { AgentProfileEntity, AgentProfileProvider } from '../types.js';
|
|
2
|
+
declare function nextId(namespace: string): number;
|
|
3
|
+
declare function setIdCounter(namespace: string, val: number): void;
|
|
4
|
+
declare function getIdCounter(namespace: string): number;
|
|
5
|
+
/**
|
|
6
|
+
* 默认 AgentProfileProvider 实现 — JSON 文件存储
|
|
7
|
+
*/
|
|
8
|
+
export declare class DefaultAgentProfileProvider implements AgentProfileProvider {
|
|
9
|
+
private store;
|
|
10
|
+
constructor(dataDir?: string);
|
|
11
|
+
private ensureDefaultProfile;
|
|
12
|
+
listProfiles(): AgentProfileEntity[];
|
|
13
|
+
getProfile(id: number): AgentProfileEntity | undefined;
|
|
14
|
+
getDefaultProfile(): AgentProfileEntity | undefined;
|
|
15
|
+
createProfile(data: Partial<AgentProfileEntity>): AgentProfileEntity;
|
|
16
|
+
updateProfile(id: number, data: Partial<AgentProfileEntity>): AgentProfileEntity | undefined;
|
|
17
|
+
deleteProfile(id: number): boolean;
|
|
18
|
+
}
|
|
19
|
+
export declare function getAgentProfileProvider(dataDir?: string): DefaultAgentProfileProvider;
|
|
20
|
+
export declare function listProfiles(): AgentProfileEntity[];
|
|
21
|
+
export declare function getProfile(id: number): AgentProfileEntity | undefined;
|
|
22
|
+
export declare function getDefaultProfile(): AgentProfileEntity | undefined;
|
|
23
|
+
export declare function createProfile(data: Partial<AgentProfileEntity>): AgentProfileEntity;
|
|
24
|
+
export declare function updateProfile(id: number, data: Partial<AgentProfileEntity>): AgentProfileEntity | undefined;
|
|
25
|
+
export declare function deleteProfile(id: number): boolean;
|
|
26
|
+
export { nextId, setIdCounter, getIdCounter };
|
|
27
|
+
//# sourceMappingURL=agent-profile.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-profile.service.d.ts","sourceRoot":"","sources":["../../../src/service/agent-profile.service.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,kBAAkB,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAC;AAQ5E,iBAAS,MAAM,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,CAGzC;AAED,iBAAS,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,IAAI,CAE1D;AAED,iBAAS,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,CAE/C;AAED;;GAEG;AACH,qBAAa,2BAA4B,YAAW,oBAAoB;IACtE,OAAO,CAAC,KAAK,CAAoC;gBAErC,OAAO,CAAC,EAAE,MAAM;IAK5B,OAAO,CAAC,oBAAoB;IAuB5B,YAAY,IAAI,kBAAkB,EAAE;IAIpC,UAAU,CAAC,EAAE,EAAE,MAAM,GAAG,kBAAkB,GAAG,SAAS;IAItD,iBAAiB,IAAI,kBAAkB,GAAG,SAAS;IAKnD,aAAa,CAAC,IAAI,EAAE,OAAO,CAAC,kBAAkB,CAAC,GAAG,kBAAkB;IAgCpE,aAAa,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,CAAC,kBAAkB,CAAC,GAAG,kBAAkB,GAAG,SAAS;IAI5F,aAAa,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO;CAKnC;AAMD,wBAAgB,uBAAuB,CAAC,OAAO,CAAC,EAAE,MAAM,GAAG,2BAA2B,CAGrF;AAGD,wBAAgB,YAAY,IAAI,kBAAkB,EAAE,CAEnD;AACD,wBAAgB,UAAU,CAAC,EAAE,EAAE,MAAM,GAAG,kBAAkB,GAAG,SAAS,CAErE;AACD,wBAAgB,iBAAiB,IAAI,kBAAkB,GAAG,SAAS,CAElE;AACD,wBAAgB,aAAa,CAAC,IAAI,EAAE,OAAO,CAAC,kBAAkB,CAAC,GAAG,kBAAkB,CAEnF;AACD,wBAAgB,aAAa,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,CAAC,kBAAkB,CAAC,GAAG,kBAAkB,GAAG,SAAS,CAE3G;AACD,wBAAgB,aAAa,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAEjD;AAED,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,YAAY,EAAE,CAAC"}
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
// ============================================================
|
|
2
|
+
// AgentProfileService — 多 Agent 配置管理(默认 JSON 文件实现)
|
|
3
|
+
// ============================================================
|
|
4
|
+
import { JsonListStore } from "../store/index.js";
|
|
5
|
+
import { formatLocalDateTime } from '@cicctencent/agent-core';
|
|
6
|
+
const DEFAULT_BASE_PROMPT = 'You are a helpful AI assistant with access to tools. Use tools when needed to accomplish tasks. Always explain your actions clearly. Respond in the same language as the user.';
|
|
7
|
+
// 自增 ID 辅助
|
|
8
|
+
let _idCounters = {};
|
|
9
|
+
function nextId(namespace) {
|
|
10
|
+
if (!_idCounters[namespace])
|
|
11
|
+
_idCounters[namespace] = Date.now();
|
|
12
|
+
return ++_idCounters[namespace];
|
|
13
|
+
}
|
|
14
|
+
function setIdCounter(namespace, val) {
|
|
15
|
+
_idCounters[namespace] = val;
|
|
16
|
+
}
|
|
17
|
+
function getIdCounter(namespace) {
|
|
18
|
+
return _idCounters[namespace] || 0;
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* 默认 AgentProfileProvider 实现 — JSON 文件存储
|
|
22
|
+
*/
|
|
23
|
+
export class DefaultAgentProfileProvider {
|
|
24
|
+
store;
|
|
25
|
+
constructor(dataDir) {
|
|
26
|
+
this.store = new JsonListStore('agent-profiles.json', { projectLocal: true, ttl: 5 * 60 * 1000 });
|
|
27
|
+
this.ensureDefaultProfile();
|
|
28
|
+
}
|
|
29
|
+
ensureDefaultProfile() {
|
|
30
|
+
if (this.store.list().length > 0)
|
|
31
|
+
return;
|
|
32
|
+
this.store.add({
|
|
33
|
+
id: nextId('agent-profile'),
|
|
34
|
+
name: '默认 Agent',
|
|
35
|
+
description: '内置默认 Agent,支持工具调用和任务委派',
|
|
36
|
+
icon: '🤖',
|
|
37
|
+
color: '#6B5CE7',
|
|
38
|
+
basePrompt: DEFAULT_BASE_PROMPT,
|
|
39
|
+
maxIterations: 15,
|
|
40
|
+
maxMessages: 50,
|
|
41
|
+
toolTimeout: 30000,
|
|
42
|
+
disabledTools: [],
|
|
43
|
+
mcpServers: [],
|
|
44
|
+
connectorIds: [],
|
|
45
|
+
agentType: 'default',
|
|
46
|
+
isDefault: true,
|
|
47
|
+
createdAt: formatLocalDateTime(),
|
|
48
|
+
updatedAt: formatLocalDateTime(),
|
|
49
|
+
});
|
|
50
|
+
console.log('[AgentProfileService] 已创建默认 Agent');
|
|
51
|
+
}
|
|
52
|
+
listProfiles() {
|
|
53
|
+
return this.store.list();
|
|
54
|
+
}
|
|
55
|
+
getProfile(id) {
|
|
56
|
+
return this.store.findById(id);
|
|
57
|
+
}
|
|
58
|
+
getDefaultProfile() {
|
|
59
|
+
const list = this.store.list();
|
|
60
|
+
return list.find(p => p.isDefault) || list[0];
|
|
61
|
+
}
|
|
62
|
+
createProfile(data) {
|
|
63
|
+
const now = formatLocalDateTime();
|
|
64
|
+
const agentType = data.agentType === 'remote' ? 'remote' : 'specialist';
|
|
65
|
+
const profile = {
|
|
66
|
+
id: nextId('agent-profile'),
|
|
67
|
+
name: data.name || 'New Agent',
|
|
68
|
+
description: data.description,
|
|
69
|
+
icon: data.icon,
|
|
70
|
+
color: data.color,
|
|
71
|
+
basePrompt: data.basePrompt || DEFAULT_BASE_PROMPT,
|
|
72
|
+
model: data.model,
|
|
73
|
+
modelConfigId: data.modelConfigId,
|
|
74
|
+
maxIterations: data.maxIterations || 15,
|
|
75
|
+
maxMessages: data.maxMessages || 50,
|
|
76
|
+
toolTimeout: data.toolTimeout || 30000,
|
|
77
|
+
disabledTools: data.disabledTools || [],
|
|
78
|
+
mcpServers: data.mcpServers || [],
|
|
79
|
+
selectedSkills: data.selectedSkills,
|
|
80
|
+
alwaysInjectSkills: data.alwaysInjectSkills,
|
|
81
|
+
connectorIds: data.connectorIds || [],
|
|
82
|
+
agentType,
|
|
83
|
+
domain: data.domain,
|
|
84
|
+
remoteUrl: data.remoteUrl,
|
|
85
|
+
remoteAuth: data.remoteAuth,
|
|
86
|
+
a2aProtocol: data.a2aProtocol,
|
|
87
|
+
restA2AConfig: data.restA2AConfig,
|
|
88
|
+
createdAt: now,
|
|
89
|
+
updatedAt: now,
|
|
90
|
+
};
|
|
91
|
+
return this.store.add(profile);
|
|
92
|
+
}
|
|
93
|
+
updateProfile(id, data) {
|
|
94
|
+
return this.store.update(id, { ...data, updatedAt: formatLocalDateTime() });
|
|
95
|
+
}
|
|
96
|
+
deleteProfile(id) {
|
|
97
|
+
const profile = this.store.findById(id);
|
|
98
|
+
if (profile?.isDefault)
|
|
99
|
+
return false;
|
|
100
|
+
return this.store.remove(id);
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
// ---- 全局单例 ----
|
|
104
|
+
let globalProvider = null;
|
|
105
|
+
export function getAgentProfileProvider(dataDir) {
|
|
106
|
+
if (!globalProvider)
|
|
107
|
+
globalProvider = new DefaultAgentProfileProvider(dataDir);
|
|
108
|
+
return globalProvider;
|
|
109
|
+
}
|
|
110
|
+
// 向后兼容的导出
|
|
111
|
+
export function listProfiles() {
|
|
112
|
+
return getAgentProfileProvider().listProfiles();
|
|
113
|
+
}
|
|
114
|
+
export function getProfile(id) {
|
|
115
|
+
return getAgentProfileProvider().getProfile(id);
|
|
116
|
+
}
|
|
117
|
+
export function getDefaultProfile() {
|
|
118
|
+
return getAgentProfileProvider().getDefaultProfile();
|
|
119
|
+
}
|
|
120
|
+
export function createProfile(data) {
|
|
121
|
+
return getAgentProfileProvider().createProfile(data);
|
|
122
|
+
}
|
|
123
|
+
export function updateProfile(id, data) {
|
|
124
|
+
return getAgentProfileProvider().updateProfile(id, data);
|
|
125
|
+
}
|
|
126
|
+
export function deleteProfile(id) {
|
|
127
|
+
return getAgentProfileProvider().deleteProfile(id);
|
|
128
|
+
}
|
|
129
|
+
export { nextId, setIdCounter, getIdCounter };
|
|
130
|
+
//# sourceMappingURL=agent-profile.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-profile.service.js","sourceRoot":"","sources":["../../../src/service/agent-profile.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @file Artifact 存储服务
|
|
3
|
+
* @description 将 Agent 生成的文件 Artifact(图表、数据文件等)持久化到沙箱目录内,
|
|
4
|
+
* 遵循沙箱隔离原则:所有 I/O 操作限制在沙箱 rootDir 中。
|
|
5
|
+
* 提供 HTTP URL 供前端下载/预览。
|
|
6
|
+
*/
|
|
7
|
+
/** 根据文件扩展名推断 MIME 类型 */
|
|
8
|
+
export declare function getMimeType(filename: string): string;
|
|
9
|
+
/** 判断 MIME 类型是否为可内联预览的图片 */
|
|
10
|
+
export declare function isImageMime(mime: string): boolean;
|
|
11
|
+
/**
|
|
12
|
+
* 保存 Artifact 文件到沙箱目录内
|
|
13
|
+
*
|
|
14
|
+
* @param sandboxRoot 沙箱根目录(如 data/sandboxes/{sessionId})
|
|
15
|
+
* @param sessionId 会话 ID(用于生成唯一 artifactId)
|
|
16
|
+
* @param filename 原始文件名
|
|
17
|
+
* @param content 文件内容(字符串或 Buffer)
|
|
18
|
+
* @returns 保存结果:artifactId、文件大小、URL
|
|
19
|
+
*/
|
|
20
|
+
export declare function saveArtifact(sandboxRoot: string, sessionId: string, filename: string, content: string | Buffer): {
|
|
21
|
+
artifactId: string;
|
|
22
|
+
filename: string;
|
|
23
|
+
mimeType: string;
|
|
24
|
+
size: number;
|
|
25
|
+
url: string;
|
|
26
|
+
dedup?: boolean;
|
|
27
|
+
};
|
|
28
|
+
/**
|
|
29
|
+
* 根据 sessionId + artifactId + filename 解析沙箱内文件路径
|
|
30
|
+
* 返回 null 如果文件不存在
|
|
31
|
+
*/
|
|
32
|
+
export declare function resolveArtifactPath(sessionId: string, artifactId: string, filename: string): string | null;
|
|
33
|
+
//# sourceMappingURL=artifact.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"artifact.service.d.ts","sourceRoot":"","sources":["../../../src/service/artifact.service.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AA2BH,wBAAwB;AACxB,wBAAgB,WAAW,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAiCpD;AAED,4BAA4B;AAC5B,wBAAgB,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAEjD;AAED;;;;;;;;GAQG;AACH,wBAAgB,YAAY,CAC1B,WAAW,EAAE,MAAM,EACnB,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE,MAAM,GAAG,MAAM,GACvB;IACD,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB,CAmDA;AAED;;;GAGG;AACH,wBAAgB,mBAAmB,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CA0B1G"}
|
|
@@ -0,0 +1,175 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @file Artifact 存储服务
|
|
3
|
+
* @description 将 Agent 生成的文件 Artifact(图表、数据文件等)持久化到沙箱目录内,
|
|
4
|
+
* 遵循沙箱隔离原则:所有 I/O 操作限制在沙箱 rootDir 中。
|
|
5
|
+
* 提供 HTTP URL 供前端下载/预览。
|
|
6
|
+
*/
|
|
7
|
+
import * as fs from 'fs';
|
|
8
|
+
import * as path from 'path';
|
|
9
|
+
import * as crypto from 'crypto';
|
|
10
|
+
import { getSandboxManager } from "../sandbox/sandbox-manager.js";
|
|
11
|
+
import { getProjectDataPath } from "../utils/data-dir.js";
|
|
12
|
+
/** 最大文件大小:5MB */
|
|
13
|
+
const MAX_FILE_SIZE = 5 * 1024 * 1024;
|
|
14
|
+
/** 沙箱内 Artifact 子目录名 */
|
|
15
|
+
const ARTIFACTS_SUBDIR = '_artifacts';
|
|
16
|
+
/** 获取沙箱内的 _artifacts/ 目录,不存在则创建 */
|
|
17
|
+
function getSandboxArtifactsDir(sandboxRoot) {
|
|
18
|
+
const dir = path.join(sandboxRoot, ARTIFACTS_SUBDIR);
|
|
19
|
+
if (!fs.existsSync(dir)) {
|
|
20
|
+
fs.mkdirSync(dir, { recursive: true });
|
|
21
|
+
}
|
|
22
|
+
return dir;
|
|
23
|
+
}
|
|
24
|
+
function getArtifactStoredPath(sandboxRoot, artifactId, filename) {
|
|
25
|
+
return path.join(getSandboxArtifactsDir(sandboxRoot), artifactId, filename);
|
|
26
|
+
}
|
|
27
|
+
/** 根据文件扩展名推断 MIME 类型 */
|
|
28
|
+
export function getMimeType(filename) {
|
|
29
|
+
const ext = path.extname(filename).toLowerCase();
|
|
30
|
+
const mimeMap = {
|
|
31
|
+
// 图片
|
|
32
|
+
'.png': 'image/png',
|
|
33
|
+
'.jpg': 'image/jpeg',
|
|
34
|
+
'.jpeg': 'image/jpeg',
|
|
35
|
+
'.gif': 'image/gif',
|
|
36
|
+
'.svg': 'image/svg+xml',
|
|
37
|
+
'.webp': 'image/webp',
|
|
38
|
+
'.bmp': 'image/bmp',
|
|
39
|
+
// 数据
|
|
40
|
+
'.json': 'application/json',
|
|
41
|
+
'.csv': 'text/csv',
|
|
42
|
+
'.tsv': 'text/tab-separated-values',
|
|
43
|
+
'.xml': 'application/xml',
|
|
44
|
+
// 文档
|
|
45
|
+
'.pdf': 'application/pdf',
|
|
46
|
+
'.html': 'text/html',
|
|
47
|
+
'.md': 'text/markdown',
|
|
48
|
+
'.txt': 'text/plain',
|
|
49
|
+
// 压缩包
|
|
50
|
+
'.zip': 'application/zip',
|
|
51
|
+
'.gz': 'application/gzip',
|
|
52
|
+
// 表格
|
|
53
|
+
'.xlsx': 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
|
|
54
|
+
'.xls': 'application/vnd.ms-excel',
|
|
55
|
+
'.pptx': 'application/vnd.openxmlformats-officedocument.presentationml.presentation',
|
|
56
|
+
'.ppt': 'application/vnd.ms-powerpoint',
|
|
57
|
+
'.docx': 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
|
|
58
|
+
'.doc': 'application/msword',
|
|
59
|
+
};
|
|
60
|
+
return mimeMap[ext] || 'application/octet-stream';
|
|
61
|
+
}
|
|
62
|
+
/** 判断 MIME 类型是否为可内联预览的图片 */
|
|
63
|
+
export function isImageMime(mime) {
|
|
64
|
+
return mime.startsWith('image/');
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* 保存 Artifact 文件到沙箱目录内
|
|
68
|
+
*
|
|
69
|
+
* @param sandboxRoot 沙箱根目录(如 data/sandboxes/{sessionId})
|
|
70
|
+
* @param sessionId 会话 ID(用于生成唯一 artifactId)
|
|
71
|
+
* @param filename 原始文件名
|
|
72
|
+
* @param content 文件内容(字符串或 Buffer)
|
|
73
|
+
* @returns 保存结果:artifactId、文件大小、URL
|
|
74
|
+
*/
|
|
75
|
+
export function saveArtifact(sandboxRoot, sessionId, filename, content) {
|
|
76
|
+
const buffer = typeof content === 'string' ? Buffer.from(content, 'utf-8') : content;
|
|
77
|
+
if (buffer.length > MAX_FILE_SIZE) {
|
|
78
|
+
throw new Error(`Artifact too large: ${buffer.length} bytes (max ${MAX_FILE_SIZE})`);
|
|
79
|
+
}
|
|
80
|
+
// 安全化文件名(去除路径分隔符和特殊字符)
|
|
81
|
+
const safeName = path.basename(filename).replace(/[^a-zA-Z0-9._\-\u4e00-\u9fff]/g, '_');
|
|
82
|
+
// 去重:检查是否已有同名同大小的 artifact,避免重复保存
|
|
83
|
+
const artifactsDir = getSandboxArtifactsDir(sandboxRoot);
|
|
84
|
+
try {
|
|
85
|
+
const entries = fs.readdirSync(artifactsDir, { withFileTypes: true });
|
|
86
|
+
for (const entry of entries) {
|
|
87
|
+
if (!entry.isDirectory() || entry.name === '.tmp')
|
|
88
|
+
continue;
|
|
89
|
+
const existingPath = path.join(artifactsDir, entry.name, safeName);
|
|
90
|
+
if (fs.existsSync(existingPath)) {
|
|
91
|
+
const stat = fs.statSync(existingPath);
|
|
92
|
+
if (stat.size === buffer.length) {
|
|
93
|
+
// Same file already saved — return existing artifact info (skip emit)
|
|
94
|
+
const mimeType = getMimeType(filename);
|
|
95
|
+
const url = `/api/work/artifacts/${encodeURIComponent(sessionId)}/${entry.name}/${encodeURIComponent(safeName)}`;
|
|
96
|
+
return {
|
|
97
|
+
artifactId: entry.name,
|
|
98
|
+
filename: safeName,
|
|
99
|
+
mimeType,
|
|
100
|
+
size: buffer.length,
|
|
101
|
+
url,
|
|
102
|
+
dedup: true,
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
catch { /* ignore dedup scan errors */ }
|
|
109
|
+
// 生成 artifactId
|
|
110
|
+
const timestamp = Date.now();
|
|
111
|
+
const hash = crypto.createHash('md5').update(sessionId + filename + timestamp).digest('hex').slice(0, 8);
|
|
112
|
+
const artifactId = `art_${timestamp}_${hash}`;
|
|
113
|
+
// 写入沙箱内 _artifacts/{artifactId}/ 目录
|
|
114
|
+
const filePath = getArtifactStoredPath(sandboxRoot, artifactId, safeName);
|
|
115
|
+
fs.mkdirSync(path.dirname(filePath), { recursive: true });
|
|
116
|
+
fs.writeFileSync(filePath, buffer);
|
|
117
|
+
const mimeType = getMimeType(filename);
|
|
118
|
+
// URL 路径:/api/work/artifacts/:sessionId/:artifactId/:filename
|
|
119
|
+
const url = `/api/work/artifacts/${encodeURIComponent(sessionId)}/${artifactId}/${encodeURIComponent(safeName)}`;
|
|
120
|
+
return { artifactId, filename: safeName, mimeType, size: buffer.length, url };
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* 根据 sessionId + artifactId + filename 解析沙箱内文件路径
|
|
124
|
+
* 返回 null 如果文件不存在
|
|
125
|
+
*/
|
|
126
|
+
export function resolveArtifactPath(sessionId, artifactId, filename) {
|
|
127
|
+
const decodedName = decodeURIComponent(filename);
|
|
128
|
+
// 1. 优先从沙箱管理器获取对应沙箱的 rootDir
|
|
129
|
+
const sandbox = getSandboxManager().get(sessionId);
|
|
130
|
+
if (sandbox) {
|
|
131
|
+
const result = findInSandbox(sandbox.rootDir, artifactId, decodedName);
|
|
132
|
+
if (result)
|
|
133
|
+
return result;
|
|
134
|
+
}
|
|
135
|
+
// 2. 回退:delegate 子 Agent 复用父级沙箱,sessionId 未注册到 SandboxManager
|
|
136
|
+
// 扫描 data/sandboxes/ 下所有沙箱目录查找匹配的 artifactId
|
|
137
|
+
const sandboxesBase = getProjectDataPath('sandboxes');
|
|
138
|
+
if (fs.existsSync(sandboxesBase)) {
|
|
139
|
+
try {
|
|
140
|
+
const dirs = fs.readdirSync(sandboxesBase, { withFileTypes: true });
|
|
141
|
+
for (const entry of dirs) {
|
|
142
|
+
if (!entry.isDirectory())
|
|
143
|
+
continue;
|
|
144
|
+
const sandboxDir = path.join(sandboxesBase, entry.name);
|
|
145
|
+
const result = findInSandbox(sandboxDir, artifactId, decodedName);
|
|
146
|
+
if (result)
|
|
147
|
+
return result;
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
catch { /* ignore scan errors */ }
|
|
151
|
+
}
|
|
152
|
+
return null;
|
|
153
|
+
}
|
|
154
|
+
/** 在指定沙箱目录内查找 artifact 文件 */
|
|
155
|
+
function findInSandbox(sandboxRoot, artifactId, filename) {
|
|
156
|
+
const nestedPath = path.join(sandboxRoot, ARTIFACTS_SUBDIR, artifactId, filename);
|
|
157
|
+
if (fs.existsSync(nestedPath))
|
|
158
|
+
return nestedPath;
|
|
159
|
+
const dir = path.join(sandboxRoot, ARTIFACTS_SUBDIR);
|
|
160
|
+
const legacyPath = path.join(dir, `${artifactId}_${filename}`);
|
|
161
|
+
if (fs.existsSync(legacyPath))
|
|
162
|
+
return legacyPath;
|
|
163
|
+
// 兼容老格式:扫描 _artifacts/ 目录查找以 artifactId_ 开头的文件
|
|
164
|
+
try {
|
|
165
|
+
if (!fs.existsSync(dir))
|
|
166
|
+
return null;
|
|
167
|
+
const files = fs.readdirSync(dir);
|
|
168
|
+
const match = files.find(f => f.startsWith(artifactId + '_'));
|
|
169
|
+
if (match)
|
|
170
|
+
return path.join(dir, match);
|
|
171
|
+
}
|
|
172
|
+
catch { /* ignore */ }
|
|
173
|
+
return null;
|
|
174
|
+
}
|
|
175
|
+
//# sourceMappingURL=artifact.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"artifact.service.js","sourceRoot":"","sources":["../../../src/service/artifact.service.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,MAAM,IAAI,CAAC;AACzB,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAC;AACjC,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAE1D,iBAAiB;AACjB,MAAM,aAAa,GAAG,CAAC,GAAG,IAAI,GAAG,IAAI,CAAC;AAEtC,wBAAwB;AACxB,MAAM,gBAAgB,GAAG,YAAY,CAAC;AAEtC,mCAAmC;AACnC,SAAS,sBAAsB,CAAC,WAAmB;IACjD,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,gBAAgB,CAAC,CAAC;IACrD,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;QACxB,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IACzC,CAAC;IACD,OAAO,GAAG,CAAC;AACb,CAAC;AAED,SAAS,qBAAqB,CAAC,WAAmB,EAAE,UAAkB,EAAE,QAAgB;IACtF,OAAO,IAAI,CAAC,IAAI,CAAC,sBAAsB,CAAC,WAAW,CAAC,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;AAC9E,CAAC;AAED,wBAAwB;AACxB,MAAM,UAAU,WAAW,CAAC,QAAgB;IAC1C,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAC;IACjD,MAAM,OAAO,GAA2B;QACtC,KAAK;QACL,MAAM,EAAE,WAAW;QACnB,MAAM,EAAE,YAAY;QACpB,OAAO,EAAE,YAAY;QACrB,MAAM,EAAE,WAAW;QACnB,MAAM,EAAE,eAAe;QACvB,OAAO,EAAE,YAAY;QACrB,MAAM,EAAE,WAAW;QACnB,KAAK;QACL,OAAO,EAAE,kBAAkB;QAC3B,MAAM,EAAE,UAAU;QAClB,MAAM,EAAE,2BAA2B;QACnC,MAAM,EAAE,iBAAiB;QACzB,KAAK;QACL,MAAM,EAAE,iBAAiB;QACzB,OAAO,EAAE,WAAW;QACpB,KAAK,EAAE,eAAe;QACtB,MAAM,EAAE,YAAY;QACpB,MAAM;QACN,MAAM,EAAE,iBAAiB;QACzB,KAAK,EAAE,kBAAkB;QACzB,KAAK;QACL,OAAO,EAAE,mEAAmE;QAC5E,MAAM,EAAE,0BAA0B;QAClC,OAAO,EAAE,2EAA2E;QACpF,MAAM,EAAE,+BAA+B;QACvC,OAAO,EAAE,yEAAyE;QAClF,MAAM,EAAE,oBAAoB;KAC7B,CAAC;IACF,OAAO,OAAO,CAAC,GAAG,CAAC,IAAI,0BAA0B,CAAC;AACpD,CAAC;AAED,4BAA4B;AAC5B,MAAM,UAAU,WAAW,CAAC,IAAY;IACtC,OAAO,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;AACnC,CAAC;AAED;;;;;;;;GAQG;AACH,MAAM,UAAU,YAAY,CAC1B,WAAmB,EACnB,SAAiB,EACjB,QAAgB,EAChB,OAAwB;IASxB,MAAM,MAAM,GAAG,OAAO,OAAO,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;IAErF,IAAI,MAAM,CAAC,MAAM,GAAG,aAAa,EAAE,CAAC;QAClC,MAAM,IAAI,KAAK,CAAC,uBAAuB,MAAM,CAAC,MAAM,eAAe,aAAa,GAAG,CAAC,CAAC;IACvF,CAAC;IAED,uBAAuB;IACvB,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,gCAAgC,EAAE,GAAG,CAAC,CAAC;IAExF,kCAAkC;IAClC,MAAM,YAAY,GAAG,sBAAsB,CAAC,WAAW,CAAC,CAAC;IACzD,IAAI,CAAC;QACH,MAAM,OAAO,GAAG,EAAE,CAAC,WAAW,CAAC,YAAY,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC;QACtE,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE,CAAC;YAC5B,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,IAAI,KAAK,CAAC,IAAI,KAAK,MAAM;gBAAE,SAAS;YAC5D,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,KAAK,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;YACnE,IAAI,EAAE,CAAC,UAAU,CAAC,YAAY,CAAC,EAAE,CAAC;gBAChC,MAAM,IAAI,GAAG,EAAE,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;gBACvC,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,CAAC,MAAM,EAAE,CAAC;oBAChC,sEAAsE;oBACtE,MAAM,QAAQ,GAAG,WAAW,CAAC,QAAQ,CAAC,CAAC;oBACvC,MAAM,GAAG,GAAG,uBAAuB,kBAAkB,CAAC,SAAS,CAAC,IAAI,KAAK,CAAC,IAAI,IAAI,kBAAkB,CAAC,QAAQ,CAAC,EAAE,CAAC;oBACjH,OAAO;wBACL,UAAU,EAAE,KAAK,CAAC,IAAI;wBACtB,QAAQ,EAAE,QAAQ;wBAClB,QAAQ;wBACR,IAAI,EAAE,MAAM,CAAC,MAAM;wBACnB,GAAG;wBACH,KAAK,EAAE,IAAI;qBACZ,CAAC;gBACJ,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAAC,MAAM,CAAC,CAAC,8BAA8B,CAAC,CAAC;IAE1C,gBAAgB;IAChB,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IAC7B,MAAM,IAAI,GAAG,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,SAAS,GAAG,QAAQ,GAAG,SAAS,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACzG,MAAM,UAAU,GAAG,OAAO,SAAS,IAAI,IAAI,EAAE,CAAC;IAE9C,oCAAoC;IACpC,MAAM,QAAQ,GAAG,qBAAqB,CAAC,WAAW,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;IAC1E,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAC1D,EAAE,CAAC,aAAa,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;IAEnC,MAAM,QAAQ,GAAG,WAAW,CAAC,QAAQ,CAAC,CAAC;IACvC,8DAA8D;IAC9D,MAAM,GAAG,GAAG,uBAAuB,kBAAkB,CAAC,SAAS,CAAC,IAAI,UAAU,IAAI,kBAAkB,CAAC,QAAQ,CAAC,EAAE,CAAC;IAEjH,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,EAAE,CAAC;AAChF,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,mBAAmB,CAAC,SAAiB,EAAE,UAAkB,EAAE,QAAgB;IACzF,MAAM,WAAW,GAAG,kBAAkB,CAAC,QAAQ,CAAC,CAAC;IAEjD,6BAA6B;IAC7B,MAAM,OAAO,GAAG,iBAAiB,EAAE,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IACnD,IAAI,OAAO,EAAE,CAAC;QACZ,MAAM,MAAM,GAAG,aAAa,CAAC,OAAO,CAAC,OAAO,EAAE,UAAU,EAAE,WAAW,CAAC,CAAC;QACvE,IAAI,MAAM;YAAE,OAAO,MAAM,CAAC;IAC5B,CAAC;IAED,8DAA8D;IAC9D,gDAAgD;IAChD,MAAM,aAAa,GAAG,kBAAkB,CAAC,WAAW,CAAC,CAAC;IACtD,IAAI,EAAE,CAAC,UAAU,CAAC,aAAa,CAAC,EAAE,CAAC;QACjC,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,EAAE,CAAC,WAAW,CAAC,aAAa,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC;YACpE,KAAK,MAAM,KAAK,IAAI,IAAI,EAAE,CAAC;gBACzB,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE;oBAAE,SAAS;gBACnC,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;gBACxD,MAAM,MAAM,GAAG,aAAa,CAAC,UAAU,EAAE,UAAU,EAAE,WAAW,CAAC,CAAC;gBAClE,IAAI,MAAM;oBAAE,OAAO,MAAM,CAAC;YAC5B,CAAC;QACH,CAAC;QAAC,MAAM,CAAC,CAAC,wBAAwB,CAAC,CAAC;IACtC,CAAC;IAED,OAAO,IAAI,CAAC;AACd,CAAC;AAED,6BAA6B;AAC7B,SAAS,aAAa,CAAC,WAAmB,EAAE,UAAkB,EAAE,QAAgB;IAC9E,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,gBAAgB,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;IAClF,IAAI,EAAE,CAAC,UAAU,CAAC,UAAU,CAAC;QAAE,OAAO,UAAU,CAAC;IAEjD,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,gBAAgB,CAAC,CAAC;IACrD,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,UAAU,IAAI,QAAQ,EAAE,CAAC,CAAC;IAC/D,IAAI,EAAE,CAAC,UAAU,CAAC,UAAU,CAAC;QAAE,OAAO,UAAU,CAAC;IAEjD,+CAA+C;IAC/C,IAAI,CAAC;QACH,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC;YAAE,OAAO,IAAI,CAAC;QACrC,MAAM,KAAK,GAAG,EAAE,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QAClC,MAAM,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,UAAU,GAAG,GAAG,CAAC,CAAC,CAAC;QAC9D,IAAI,KAAK;YAAE,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IAC1C,CAAC;IAAC,MAAM,CAAC,CAAC,YAAY,CAAC,CAAC;IAExB,OAAO,IAAI,CAAC;AACd,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import type { ToolRiskAssessment } from '@cicctencent/agent-core';
|
|
2
|
+
export interface AuditLogEntry {
|
|
3
|
+
id: string;
|
|
4
|
+
ts: number;
|
|
5
|
+
sessionId: string;
|
|
6
|
+
traceId?: string;
|
|
7
|
+
iteration?: number;
|
|
8
|
+
phase: 'before_tool' | 'after_tool' | 'blocked';
|
|
9
|
+
tool: string;
|
|
10
|
+
args?: Record<string, unknown>;
|
|
11
|
+
result?: string;
|
|
12
|
+
isError?: boolean;
|
|
13
|
+
duration?: number;
|
|
14
|
+
risk: ToolRiskAssessment;
|
|
15
|
+
}
|
|
16
|
+
export interface AuditQuery {
|
|
17
|
+
limit?: number;
|
|
18
|
+
since?: number;
|
|
19
|
+
until?: number;
|
|
20
|
+
tool?: string;
|
|
21
|
+
level?: string;
|
|
22
|
+
sessionId?: string;
|
|
23
|
+
}
|
|
24
|
+
export declare function redactAuditEntry(entry: AuditLogEntry): AuditLogEntry;
|
|
25
|
+
export declare function appendAuditLog(entry: Omit<AuditLogEntry, 'id' | 'ts'> & {
|
|
26
|
+
id?: string;
|
|
27
|
+
ts?: number;
|
|
28
|
+
}): AuditLogEntry;
|
|
29
|
+
export declare function listAuditLogs(query?: AuditQuery): AuditLogEntry[];
|
|
30
|
+
//# sourceMappingURL=audit.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"audit.service.d.ts","sourceRoot":"","sources":["../../../src/service/audit.service.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAIlE,MAAM,WAAW,aAAa;IAC5B,EAAE,EAAE,MAAM,CAAC;IACX,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,aAAa,GAAG,YAAY,GAAG,SAAS,CAAC;IAChD,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC/B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,kBAAkB,CAAC;CAC1B;AAED,MAAM,WAAW,UAAU;IACzB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAqCD,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,aAAa,GAAG,aAAa,CAOpE;AA4BD,wBAAgB,cAAc,CAAC,KAAK,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,GAAG,IAAI,CAAC,GAAG;IAAE,EAAE,CAAC,EAAE,MAAM,CAAC;IAAC,EAAE,CAAC,EAAE,MAAM,CAAA;CAAE,GAAG,aAAa,CAcpH;AAED,wBAAgB,aAAa,CAAC,KAAK,GAAE,UAAe,GAAG,aAAa,EAAE,CAuBrE"}
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
// ============================================================
|
|
2
|
+
// AuditService — 审计日志(JSONL 文件存储)
|
|
3
|
+
// ============================================================
|
|
4
|
+
import * as fs from 'fs';
|
|
5
|
+
import * as fsp from 'fs/promises';
|
|
6
|
+
import * as path from 'path';
|
|
7
|
+
import { getProjectDataPath, ensureProjectDataDir } from "../utils/data-dir.js";
|
|
8
|
+
import { isLowRiskTool } from "./tool-risk.service.js";
|
|
9
|
+
import { getSecurityPolicy } from "./security-policy.service.js";
|
|
10
|
+
function auditDir() {
|
|
11
|
+
ensureProjectDataDir();
|
|
12
|
+
const dir = getProjectDataPath('audit');
|
|
13
|
+
if (!fs.existsSync(dir))
|
|
14
|
+
fs.mkdirSync(dir, { recursive: true });
|
|
15
|
+
return dir;
|
|
16
|
+
}
|
|
17
|
+
function auditFile(ts = Date.now()) {
|
|
18
|
+
const day = new Date(ts).toISOString().slice(0, 10);
|
|
19
|
+
return path.join(auditDir(), `${day}.jsonl`);
|
|
20
|
+
}
|
|
21
|
+
function safeJson(value) {
|
|
22
|
+
try {
|
|
23
|
+
return JSON.stringify(value);
|
|
24
|
+
}
|
|
25
|
+
catch {
|
|
26
|
+
return JSON.stringify(String(value));
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
function shouldRedactKey(key) {
|
|
30
|
+
return /(api[_-]?key|token|secret|password|passwd|authorization|cookie|credential|access[_-]?key|private[_-]?key)/i.test(key);
|
|
31
|
+
}
|
|
32
|
+
function redactValue(value, key = '') {
|
|
33
|
+
if (shouldRedactKey(key))
|
|
34
|
+
return '[REDACTED]';
|
|
35
|
+
if (typeof value === 'string') {
|
|
36
|
+
return value
|
|
37
|
+
.replace(/Bearer\s+[A-Za-z0-9._~+/=-]+/gi, 'Bearer [REDACTED]')
|
|
38
|
+
.replace(/(sk-[A-Za-z0-9_-]{8,})/g, '[REDACTED_KEY]')
|
|
39
|
+
.replace(/([A-Za-z0-9_-]{16,}\.[A-Za-z0-9_-]{16,}\.[A-Za-z0-9_-]{16,})/g, '[REDACTED_JWT]');
|
|
40
|
+
}
|
|
41
|
+
if (Array.isArray(value))
|
|
42
|
+
return value.map(item => redactValue(item));
|
|
43
|
+
if (value && typeof value === 'object') {
|
|
44
|
+
return Object.fromEntries(Object.entries(value).map(([k, v]) => [k, redactValue(v, k)]));
|
|
45
|
+
}
|
|
46
|
+
return value;
|
|
47
|
+
}
|
|
48
|
+
export function redactAuditEntry(entry) {
|
|
49
|
+
if (!getSecurityPolicy().redactAuditFields)
|
|
50
|
+
return entry;
|
|
51
|
+
return {
|
|
52
|
+
...entry,
|
|
53
|
+
args: entry.args ? redactValue(entry.args) : undefined,
|
|
54
|
+
result: typeof entry.result === 'string' ? redactValue(entry.result) : entry.result,
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
// ===== 异步批量写入审计日志 =====
|
|
58
|
+
const _writeBuffer = [];
|
|
59
|
+
let _flushTimer = null;
|
|
60
|
+
const FLUSH_INTERVAL = 500;
|
|
61
|
+
async function flushAuditBuffer() {
|
|
62
|
+
if (_writeBuffer.length === 0)
|
|
63
|
+
return;
|
|
64
|
+
const batch = _writeBuffer.splice(0);
|
|
65
|
+
const groups = new Map();
|
|
66
|
+
for (const item of batch) {
|
|
67
|
+
const lines = groups.get(item.file) || [];
|
|
68
|
+
lines.push(item.line);
|
|
69
|
+
groups.set(item.file, lines);
|
|
70
|
+
}
|
|
71
|
+
for (const [file, lines] of groups) {
|
|
72
|
+
try {
|
|
73
|
+
await fsp.appendFile(file, lines.join('\n') + '\n', 'utf-8');
|
|
74
|
+
}
|
|
75
|
+
catch (e) {
|
|
76
|
+
console.error('[audit] flush failed:', file, e);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
_flushTimer = null;
|
|
80
|
+
}
|
|
81
|
+
function scheduleFlush() {
|
|
82
|
+
if (_flushTimer)
|
|
83
|
+
return;
|
|
84
|
+
_flushTimer = setTimeout(() => { flushAuditBuffer(); }, FLUSH_INTERVAL);
|
|
85
|
+
if (_flushTimer && typeof _flushTimer === 'object' && 'unref' in _flushTimer)
|
|
86
|
+
_flushTimer.unref();
|
|
87
|
+
}
|
|
88
|
+
export function appendAuditLog(entry) {
|
|
89
|
+
if (!getSecurityPolicy().auditEnabled) {
|
|
90
|
+
return { id: entry.id || 'audit_disabled', ts: entry.ts || Date.now(), ...entry };
|
|
91
|
+
}
|
|
92
|
+
const needsRedaction = !isLowRiskTool(entry.tool);
|
|
93
|
+
const full = needsRedaction
|
|
94
|
+
? redactAuditEntry({ id: entry.id || `${Date.now()}_${Math.random().toString(36).slice(2, 10)}`, ts: entry.ts || Date.now(), ...entry })
|
|
95
|
+
: { id: entry.id || `${Date.now()}_${Math.random().toString(36).slice(2, 10)}`, ts: entry.ts || Date.now(), ...entry };
|
|
96
|
+
const file = auditFile(full.ts);
|
|
97
|
+
_writeBuffer.push({ file, line: safeJson(full) });
|
|
98
|
+
scheduleFlush();
|
|
99
|
+
return full;
|
|
100
|
+
}
|
|
101
|
+
export function listAuditLogs(query = {}) {
|
|
102
|
+
const dir = auditDir();
|
|
103
|
+
const limit = Math.max(1, Math.min(Number(query.limit) || 100, 1000));
|
|
104
|
+
const files = fs.readdirSync(dir).filter(f => f.endsWith('.jsonl')).sort().reverse();
|
|
105
|
+
const results = [];
|
|
106
|
+
for (const file of files) {
|
|
107
|
+
const raw = fs.readFileSync(path.join(dir, file), 'utf-8');
|
|
108
|
+
const lines = raw.split('\n').filter(Boolean).reverse();
|
|
109
|
+
for (const line of lines) {
|
|
110
|
+
try {
|
|
111
|
+
const item = JSON.parse(line);
|
|
112
|
+
if (query.since && item.ts < query.since)
|
|
113
|
+
continue;
|
|
114
|
+
if (query.until && item.ts > query.until)
|
|
115
|
+
continue;
|
|
116
|
+
if (query.tool && item.tool !== query.tool)
|
|
117
|
+
continue;
|
|
118
|
+
if (query.level && item.risk?.level !== query.level)
|
|
119
|
+
continue;
|
|
120
|
+
if (query.sessionId && item.sessionId !== query.sessionId)
|
|
121
|
+
continue;
|
|
122
|
+
results.push(item);
|
|
123
|
+
if (results.length >= limit)
|
|
124
|
+
return results;
|
|
125
|
+
}
|
|
126
|
+
catch { /* skip */ }
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
return results;
|
|
130
|
+
}
|
|
131
|
+
//# sourceMappingURL=audit.service.js.map
|