@jingyi0605/codingns 0.7.3 → 0.8.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/README.md +6 -0
- package/bin/codingns.mjs +747 -28
- package/bin/office-mcp-server.mjs +620 -0
- package/dist/public/assets/{AdaptiveButlerPage-CgBX49t-.js → AdaptiveButlerPage-BsgVNRAa.js} +1 -1
- package/dist/public/assets/{App-tXOqoHNl.js → App-tPcbyRdS.js} +3 -3
- package/dist/public/assets/{BootstrapPage-DoRMz87R.js → BootstrapPage--MDOigQi.js} +1 -1
- package/dist/public/assets/{ConversationPage-DXR6Hp4O.js → ConversationPage-BBss5ED8.js} +6 -6
- package/dist/public/assets/{DesktopDetachPreviewPage-Cyk-ZYCk.js → DesktopDetachPreviewPage-CB8DoqwU.js} +1 -1
- package/dist/public/assets/{DesktopWindowPage-DNVNK3hs.js → DesktopWindowPage-GtIx5m8K.js} +1 -1
- package/dist/public/assets/FileContextPanel-BcM7AIT4.js +1 -0
- package/dist/public/assets/{GitSidebar-Cr3Z9OUI.js → GitSidebar-CMtkaxuI.js} +2 -2
- package/dist/public/assets/{MobileCreateSessionSheet-DMW0V6GJ.js → MobileCreateSessionSheet-CrFY41_8.js} +1 -1
- package/dist/public/assets/{MobileTopHeaderFrame-CkdnZ_MU.js → MobileTopHeaderFrame-DGVOzXyg.js} +1 -1
- package/dist/public/assets/{MobileWorkspaceSwitcherHeader-KIbqBYJN.js → MobileWorkspaceSwitcherHeader-DLkACTnQ.js} +1 -1
- package/dist/public/assets/{RelayConnectEntryPage-DIRBH3hw.js → RelayConnectEntryPage-0MPPjxtQ.js} +1 -1
- package/dist/public/assets/{ServerSettingsModal-C-9RxdWP.js → ServerSettingsModal-vgOhwus4.js} +1 -1
- package/dist/public/assets/{SessionIndexPage-bRlIydRA.js → SessionIndexPage-KK626Ra9.js} +1 -1
- package/dist/public/assets/{SettingsPage-CMEt4ua9.js → SettingsPage-B3edBJIo.js} +2 -2
- package/dist/public/assets/{TerminalManagerPanel-2bi9wVhT.js → TerminalManagerPanel-BxlhZp8c.js} +1 -1
- package/dist/public/assets/{TerminalPage-DayZz2Tf.js → TerminalPage-B6Rdhylx.js} +1 -1
- package/dist/public/assets/{TerminalRuntimeFallbackModal-DgwYcp-Y.js → TerminalRuntimeFallbackModal-BVLfrpSa.js} +1 -1
- package/dist/public/assets/{ToolFilesPage-YvnP_FXW.js → ToolFilesPage-N_gwwUjD.js} +1 -1
- package/dist/public/assets/{ToolGitPage-GMcQKtV9.js → ToolGitPage-DOcuuWM1.js} +1 -1
- package/dist/public/assets/{ToolProcessesPage-DFIQ7BCd.js → ToolProcessesPage-D-FfJ7Re.js} +1 -1
- package/dist/public/assets/{ToolsHomePage-CSilFzXR.js → ToolsHomePage-CHfPxd20.js} +1 -1
- package/dist/public/assets/{WorkbenchLandingPage-1VtToSz9.js → WorkbenchLandingPage-CTTnfovY.js} +1 -1
- package/dist/public/assets/WorkbenchLayout-CbpJg0g1.js +244 -0
- package/dist/public/assets/{WorkbenchModal-BWXYSXmC.js → WorkbenchModal-Bt_1fYmM.js} +1 -1
- package/dist/public/assets/WorkbenchShellRoute-B4XB8SwG.css +1 -0
- package/dist/public/assets/WorkbenchShellRoute-DyaMnPfS.js +1 -0
- package/dist/public/assets/{WorkspaceDebugDetailPage-Ux8_Q7la.js → WorkspaceDebugDetailPage-s7yuDIxR.js} +1 -1
- package/dist/public/assets/{WorkspaceDetailPage-B402p99m.js → WorkspaceDetailPage-Cf-gVpqK.js} +1 -1
- package/dist/public/assets/{WorkspaceHomePage-D2pob6HI.js → WorkspaceHomePage-COf6I8sT.js} +1 -1
- package/dist/public/assets/{client-runtime-manager-C5D76ewj.js → client-runtime-manager-DGdKvYzx.js} +1 -1
- package/dist/public/assets/file-tree-icon-BeHqeru9.js +590 -0
- package/dist/public/assets/index-CcaQt50x.css +1 -0
- package/dist/public/assets/index-CuzMc7q2.js +42 -0
- package/dist/public/assets/{login-direct-candidate-resolver-wXSaB0i7.js → login-direct-candidate-resolver-DEP_xCmR.js} +1 -1
- package/dist/public/assets/{model-switch-api-CPtou49j.js → model-switch-api-c6kcbBGm.js} +1 -1
- package/dist/public/assets/{preferences-service-CdaK7zA8.js → preferences-service-CV6Ih0BG.js} +1 -1
- package/dist/public/assets/{realtime-client-BjQazYsK.js → realtime-client-CRCx5xBt.js} +1 -1
- package/dist/public/assets/{relay-entry-BwE5nw0l.js → relay-entry-C751A-Sm.js} +1 -1
- package/dist/public/assets/{terminal-runtime-meta-C-Lbyx2i.js → terminal-runtime-meta-CRAVR-8G.js} +1 -1
- package/dist/public/assets/{useRegisteredDebugTemplates-BM7-c-gx.js → useRegisteredDebugTemplates-D6YtNS0r.js} +1 -1
- package/dist/public/index.html +2 -2
- package/dist/server/config/env.d.ts +3 -0
- package/dist/server/config/env.js +67 -1
- package/dist/server/config/env.js.map +1 -1
- package/dist/server/config/opencode-base-url-resolver.d.ts +3 -2
- package/dist/server/config/opencode-base-url-resolver.js +64 -24
- package/dist/server/config/opencode-base-url-resolver.js.map +1 -1
- package/dist/server/middlewares/auth-guard.js +4 -0
- package/dist/server/middlewares/auth-guard.js.map +1 -1
- package/dist/server/modules/assistant-capability/assistant-capability-controller.d.ts +168 -1
- package/dist/server/modules/assistant-capability/assistant-capability-controller.js +205 -4
- package/dist/server/modules/assistant-capability/assistant-capability-controller.js.map +1 -1
- package/dist/server/modules/assistant-capability/assistant-capability-service.d.ts +296 -2
- package/dist/server/modules/assistant-capability/assistant-capability-service.js +872 -3
- package/dist/server/modules/assistant-capability/assistant-capability-service.js.map +1 -1
- package/dist/server/modules/auth/auth-service.d.ts +21 -1
- package/dist/server/modules/auth/auth-service.js +64 -0
- package/dist/server/modules/auth/auth-service.js.map +1 -1
- package/dist/server/modules/browser-runtime/browser-profile-service.d.ts +26 -0
- package/dist/server/modules/browser-runtime/browser-profile-service.js +85 -0
- package/dist/server/modules/browser-runtime/browser-profile-service.js.map +1 -0
- package/dist/server/modules/browser-runtime/browser-runtime-controller.d.ts +69 -0
- package/dist/server/modules/browser-runtime/browser-runtime-controller.js +83 -0
- package/dist/server/modules/browser-runtime/browser-runtime-controller.js.map +1 -0
- package/dist/server/modules/browser-runtime/browser-runtime-service.d.ts +56 -0
- package/dist/server/modules/browser-runtime/browser-runtime-service.js +215 -0
- package/dist/server/modules/browser-runtime/browser-runtime-service.js.map +1 -0
- package/dist/server/modules/browser-runtime/browser-task-execution-support.d.ts +65 -0
- package/dist/server/modules/browser-runtime/browser-task-execution-support.js +432 -0
- package/dist/server/modules/browser-runtime/browser-task-execution-support.js.map +1 -0
- package/dist/server/modules/browser-runtime/browser-task-executor-registry.d.ts +7 -0
- package/dist/server/modules/browser-runtime/browser-task-executor-registry.js +21 -0
- package/dist/server/modules/browser-runtime/browser-task-executor-registry.js.map +1 -0
- package/dist/server/modules/browser-runtime/browser-task-executor.d.ts +55 -0
- package/dist/server/modules/browser-runtime/browser-task-executor.js +2 -0
- package/dist/server/modules/browser-runtime/browser-task-executor.js.map +1 -0
- package/dist/server/modules/browser-runtime/browser-task-payload.d.ts +31 -0
- package/dist/server/modules/browser-runtime/browser-task-payload.js +55 -0
- package/dist/server/modules/browser-runtime/browser-task-payload.js.map +1 -0
- package/dist/server/modules/browser-runtime/opencli-bridge-browser-executor.d.ts +19 -0
- package/dist/server/modules/browser-runtime/opencli-bridge-browser-executor.js +219 -0
- package/dist/server/modules/browser-runtime/opencli-bridge-browser-executor.js.map +1 -0
- package/dist/server/modules/browser-runtime/opencli-browser-bridge-service.d.ts +15 -0
- package/dist/server/modules/browser-runtime/opencli-browser-bridge-service.js +33 -0
- package/dist/server/modules/browser-runtime/opencli-browser-bridge-service.js.map +1 -0
- package/dist/server/modules/browser-runtime/playwright-browser-executor.d.ts +16 -0
- package/dist/server/modules/browser-runtime/playwright-browser-executor.js +272 -0
- package/dist/server/modules/browser-runtime/playwright-browser-executor.js.map +1 -0
- package/dist/server/modules/butler/butler-auth-service.js +4 -0
- package/dist/server/modules/butler/butler-auth-service.js.map +1 -1
- package/dist/server/modules/butler/butler-inbox-instruction-adapter.js +1 -0
- package/dist/server/modules/butler/butler-inbox-instruction-adapter.js.map +1 -1
- package/dist/server/modules/butler/butler-session-summary-service.d.ts +1 -0
- package/dist/server/modules/butler/butler-session-summary-service.js +5 -3
- package/dist/server/modules/butler/butler-session-summary-service.js.map +1 -1
- package/dist/server/modules/butler/butler-workspace-context.js +23 -0
- package/dist/server/modules/butler/butler-workspace-context.js.map +1 -1
- package/dist/server/modules/channels/wechat-claw-client.d.ts +51 -0
- package/dist/server/modules/channels/wechat-claw-client.js +245 -0
- package/dist/server/modules/channels/wechat-claw-client.js.map +1 -0
- package/dist/server/modules/debug-target/debug-target-service.d.ts +2 -0
- package/dist/server/modules/debug-target/debug-target-service.js +14 -0
- package/dist/server/modules/debug-target/debug-target-service.js.map +1 -1
- package/dist/server/modules/document-runtime/document-docx-fallback-renderer.py +139 -0
- package/dist/server/modules/document-runtime/document-export-executor.d.ts +50 -0
- package/dist/server/modules/document-runtime/document-export-executor.js +827 -0
- package/dist/server/modules/document-runtime/document-export-executor.js.map +1 -0
- package/dist/server/modules/document-runtime/document-runtime-controller.d.ts +127 -0
- package/dist/server/modules/document-runtime/document-runtime-controller.js +131 -0
- package/dist/server/modules/document-runtime/document-runtime-controller.js.map +1 -0
- package/dist/server/modules/document-runtime/document-runtime-service.d.ts +125 -0
- package/dist/server/modules/document-runtime/document-runtime-service.js +706 -0
- package/dist/server/modules/document-runtime/document-runtime-service.js.map +1 -0
- package/dist/server/modules/office/office-controller.d.ts +77 -0
- package/dist/server/modules/office/office-controller.js +174 -0
- package/dist/server/modules/office/office-controller.js.map +1 -0
- package/dist/server/modules/office/office-preview-link-service.d.ts +27 -0
- package/dist/server/modules/office/office-preview-link-service.js +121 -0
- package/dist/server/modules/office/office-preview-link-service.js.map +1 -0
- package/dist/server/modules/office/office-service.d.ts +67 -0
- package/dist/server/modules/office/office-service.js +359 -0
- package/dist/server/modules/office/office-service.js.map +1 -0
- package/dist/server/modules/opencli/opencli-bridge-skill-service.js +38 -14
- package/dist/server/modules/opencli/opencli-bridge-skill-service.js.map +1 -1
- package/dist/server/modules/opencli/opencli-install-discovery.d.ts +4 -0
- package/dist/server/modules/opencli/opencli-install-discovery.js +94 -0
- package/dist/server/modules/opencli/opencli-install-discovery.js.map +1 -1
- package/dist/server/modules/opencli/opencli-runtime-builder.js +29 -0
- package/dist/server/modules/opencli/opencli-runtime-builder.js.map +1 -1
- package/dist/server/modules/opencli/opencli-runtime-guard.d.ts +2 -0
- package/dist/server/modules/opencli/opencli-runtime-guard.js +5 -0
- package/dist/server/modules/opencli/opencli-runtime-guard.js.map +1 -0
- package/dist/server/modules/ops-runtime/ops-runtime-controller.d.ts +70 -0
- package/dist/server/modules/ops-runtime/ops-runtime-controller.js +83 -0
- package/dist/server/modules/ops-runtime/ops-runtime-controller.js.map +1 -0
- package/dist/server/modules/ops-runtime/ops-runtime-service.d.ts +80 -0
- package/dist/server/modules/ops-runtime/ops-runtime-service.js +327 -0
- package/dist/server/modules/ops-runtime/ops-runtime-service.js.map +1 -0
- package/dist/server/modules/ops-runtime/ssh-ops-executor.d.ts +41 -0
- package/dist/server/modules/ops-runtime/ssh-ops-executor.js +478 -0
- package/dist/server/modules/ops-runtime/ssh-ops-executor.js.map +1 -0
- package/dist/server/modules/presentation/presentation-controller.d.ts +22 -0
- package/dist/server/modules/presentation/presentation-controller.js +59 -0
- package/dist/server/modules/presentation/presentation-controller.js.map +1 -0
- package/dist/server/modules/presentation/presentation-export-task-service.d.ts +24 -0
- package/dist/server/modules/presentation/presentation-export-task-service.js +137 -0
- package/dist/server/modules/presentation/presentation-export-task-service.js.map +1 -0
- package/dist/server/modules/presentation/presentation-export-types.d.ts +12 -0
- package/dist/server/modules/presentation/presentation-export-types.js +2 -0
- package/dist/server/modules/presentation/presentation-export-types.js.map +1 -0
- package/dist/server/modules/presentation/presentation-pdf-export-service.d.ts +20 -0
- package/dist/server/modules/presentation/presentation-pdf-export-service.js +29 -0
- package/dist/server/modules/presentation/presentation-pdf-export-service.js.map +1 -0
- package/dist/server/modules/presentation/presentation-pptx-export-service.d.ts +20 -0
- package/dist/server/modules/presentation/presentation-pptx-export-service.js +64 -0
- package/dist/server/modules/presentation/presentation-pptx-export-service.js.map +1 -0
- package/dist/server/modules/presentation/presentation-renderer.d.ts +21 -0
- package/dist/server/modules/presentation/presentation-renderer.js +208 -0
- package/dist/server/modules/presentation/presentation-renderer.js.map +1 -0
- package/dist/server/modules/relay-tunnel/relay-tunnel-gateway-service.js +3 -3
- package/dist/server/modules/relay-tunnel/relay-tunnel-gateway-service.js.map +1 -1
- package/dist/server/modules/relay-tunnel/relay-tunnel-service.js +6 -1
- package/dist/server/modules/relay-tunnel/relay-tunnel-service.js.map +1 -1
- package/dist/server/modules/sessions/codex-app-server-helper-process.js +2 -1
- package/dist/server/modules/sessions/codex-app-server-helper-process.js.map +1 -1
- package/dist/server/modules/sessions/session-controller.d.ts +1 -0
- package/dist/server/modules/sessions/session-controller.js +59 -4
- package/dist/server/modules/sessions/session-controller.js.map +1 -1
- package/dist/server/modules/sessions/session-history-service.js +17 -5
- package/dist/server/modules/sessions/session-history-service.js.map +1 -1
- package/dist/server/modules/sessions/session-live-runtime-service.d.ts +5 -1
- package/dist/server/modules/sessions/session-live-runtime-service.js +86 -8
- package/dist/server/modules/sessions/session-live-runtime-service.js.map +1 -1
- package/dist/server/modules/sessions/session-provider-config-service.d.ts +25 -1
- package/dist/server/modules/sessions/session-provider-config-service.js +54 -5
- package/dist/server/modules/sessions/session-provider-config-service.js.map +1 -1
- package/dist/server/modules/sessions/workspace-office-mcp-config.d.ts +14 -0
- package/dist/server/modules/sessions/workspace-office-mcp-config.js +54 -0
- package/dist/server/modules/sessions/workspace-office-mcp-config.js.map +1 -0
- package/dist/server/modules/sessions/workspace-session-auth-service.d.ts +27 -0
- package/dist/server/modules/sessions/workspace-session-auth-service.js +109 -0
- package/dist/server/modules/sessions/workspace-session-auth-service.js.map +1 -0
- package/dist/server/modules/sessions/workspace-session-runtime-context-service.d.ts +50 -0
- package/dist/server/modules/sessions/workspace-session-runtime-context-service.js +332 -0
- package/dist/server/modules/sessions/workspace-session-runtime-context-service.js.map +1 -0
- package/dist/server/modules/skills/assistant-runtime-skill-catalog.js +5 -0
- package/dist/server/modules/skills/assistant-runtime-skill-catalog.js.map +1 -1
- package/dist/server/modules/skills/builtin-skills/codingns-workspace-session/SKILL.md +67 -0
- package/dist/server/modules/skills/builtin-skills/codingns-workspace-session/agents/openai.yaml +4 -0
- package/dist/server/modules/skills/builtin-skills/codingns-workspace-session/references/cli-workflow.md +133 -0
- package/dist/server/modules/skills/skill-controller.d.ts +7 -0
- package/dist/server/modules/skills/skill-controller.js +7 -0
- package/dist/server/modules/skills/skill-controller.js.map +1 -1
- package/dist/server/modules/skills/skill-manager-service.d.ts +61 -0
- package/dist/server/modules/skills/skill-manager-service.js +218 -0
- package/dist/server/modules/skills/skill-manager-service.js.map +1 -1
- package/dist/server/modules/skills/skill-name-policy.js +2 -1
- package/dist/server/modules/skills/skill-name-policy.js.map +1 -1
- package/dist/server/modules/tasks/task-helper-client.d.ts +1 -0
- package/dist/server/modules/tasks/task-helper-client.js +45 -9
- package/dist/server/modules/tasks/task-helper-client.js.map +1 -1
- package/dist/server/modules/tasks/task-types.d.ts +5 -0
- package/dist/server/modules/tasks/task-types.js +6 -1
- package/dist/server/modules/tasks/task-types.js.map +1 -1
- package/dist/server/modules/terminal/runtime/conpty-session-agent-process.js +2 -1
- package/dist/server/modules/terminal/runtime/conpty-session-agent-process.js.map +1 -1
- package/dist/server/modules/terminal/runtime/node-pty-loader.d.ts +5 -0
- package/dist/server/modules/terminal/runtime/node-pty-loader.js +68 -0
- package/dist/server/modules/terminal/runtime/node-pty-loader.js.map +1 -0
- package/dist/server/modules/terminal/runtime/pty-broker-agent-process.js +2 -1
- package/dist/server/modules/terminal/runtime/pty-broker-agent-process.js.map +1 -1
- package/dist/server/modules/terminal/runtime/pty-host-attachment-manager.js +6 -9
- package/dist/server/modules/terminal/runtime/pty-host-attachment-manager.js.map +1 -1
- package/dist/server/modules/terminal/runtime/pty-runtime-manager.js +6 -9
- package/dist/server/modules/terminal/runtime/pty-runtime-manager.js.map +1 -1
- package/dist/server/routes/assistant.d.ts +2 -1
- package/dist/server/routes/assistant.js +20 -1
- package/dist/server/routes/assistant.js.map +1 -1
- package/dist/server/routes/browser-runtime.d.ts +3 -0
- package/dist/server/routes/browser-runtime.js +14 -0
- package/dist/server/routes/browser-runtime.js.map +1 -0
- package/dist/server/routes/document-runtime.d.ts +3 -0
- package/dist/server/routes/document-runtime.js +18 -0
- package/dist/server/routes/document-runtime.js.map +1 -0
- package/dist/server/routes/office.d.ts +3 -0
- package/dist/server/routes/office.js +16 -0
- package/dist/server/routes/office.js.map +1 -0
- package/dist/server/routes/ops-runtime.d.ts +3 -0
- package/dist/server/routes/ops-runtime.js +13 -0
- package/dist/server/routes/ops-runtime.js.map +1 -0
- package/dist/server/routes/presentation.d.ts +3 -0
- package/dist/server/routes/presentation.js +5 -0
- package/dist/server/routes/presentation.js.map +1 -0
- package/dist/server/routes/skills.js +1 -0
- package/dist/server/routes/skills.js.map +1 -1
- package/dist/server/server/create-server.d.ts +36 -0
- package/dist/server/server/create-server.js +215 -4
- package/dist/server/server/create-server.js.map +1 -1
- package/dist/server/server/release-manifest-sync.d.ts +1 -0
- package/dist/server/server/release-manifest-sync.js +2 -2
- package/dist/server/server/release-manifest-sync.js.map +1 -1
- package/dist/server/server/start-host.js +1 -1
- package/dist/server/server/start-host.js.map +1 -1
- package/dist/server/storage/repositories/auth-token-repository.js +22 -6
- package/dist/server/storage/repositories/auth-token-repository.js.map +1 -1
- package/dist/server/storage/repositories/browser-profile-repository.d.ts +18 -0
- package/dist/server/storage/repositories/browser-profile-repository.js +134 -0
- package/dist/server/storage/repositories/browser-profile-repository.js.map +1 -0
- package/dist/server/storage/repositories/document-comment-repository.d.ts +10 -0
- package/dist/server/storage/repositories/document-comment-repository.js +118 -0
- package/dist/server/storage/repositories/document-comment-repository.js.map +1 -0
- package/dist/server/storage/repositories/document-repository.d.ts +16 -0
- package/dist/server/storage/repositories/document-repository.js +109 -0
- package/dist/server/storage/repositories/document-repository.js.map +1 -0
- package/dist/server/storage/repositories/document-revision-repository.d.ts +10 -0
- package/dist/server/storage/repositories/document-revision-repository.js +79 -0
- package/dist/server/storage/repositories/document-revision-repository.js.map +1 -0
- package/dist/server/storage/repositories/document-template-repository.d.ts +13 -0
- package/dist/server/storage/repositories/document-template-repository.js +244 -0
- package/dist/server/storage/repositories/document-template-repository.js.map +1 -0
- package/dist/server/storage/repositories/office-approval-repository.d.ts +11 -0
- package/dist/server/storage/repositories/office-approval-repository.js +109 -0
- package/dist/server/storage/repositories/office-approval-repository.js.map +1 -0
- package/dist/server/storage/repositories/office-artifact-repository.d.ts +10 -0
- package/dist/server/storage/repositories/office-artifact-repository.js +89 -0
- package/dist/server/storage/repositories/office-artifact-repository.js.map +1 -0
- package/dist/server/storage/repositories/office-audit-event-repository.d.ts +8 -0
- package/dist/server/storage/repositories/office-audit-event-repository.js +54 -0
- package/dist/server/storage/repositories/office-audit-event-repository.js.map +1 -0
- package/dist/server/storage/repositories/office-connector-repository.d.ts +10 -0
- package/dist/server/storage/repositories/office-connector-repository.js +97 -0
- package/dist/server/storage/repositories/office-connector-repository.js.map +1 -0
- package/dist/server/storage/repositories/office-receipt-repository.d.ts +8 -0
- package/dist/server/storage/repositories/office-receipt-repository.js +48 -0
- package/dist/server/storage/repositories/office-receipt-repository.js.map +1 -0
- package/dist/server/storage/repositories/office-rollback-record-repository.d.ts +8 -0
- package/dist/server/storage/repositories/office-rollback-record-repository.js +60 -0
- package/dist/server/storage/repositories/office-rollback-record-repository.js.map +1 -0
- package/dist/server/storage/repositories/office-task-repository.d.ts +19 -0
- package/dist/server/storage/repositories/office-task-repository.js +199 -0
- package/dist/server/storage/repositories/office-task-repository.js.map +1 -0
- package/dist/server/storage/repositories/office-task-step-repository.d.ts +10 -0
- package/dist/server/storage/repositories/office-task-step-repository.js +110 -0
- package/dist/server/storage/repositories/office-task-step-repository.js.map +1 -0
- package/dist/server/storage/repositories/ops-target-repository.d.ts +16 -0
- package/dist/server/storage/repositories/ops-target-repository.js +119 -0
- package/dist/server/storage/repositories/ops-target-repository.js.map +1 -0
- package/dist/server/storage/repositories/session-binding-repository.d.ts +4 -0
- package/dist/server/storage/repositories/session-binding-repository.js +70 -69
- package/dist/server/storage/repositories/session-binding-repository.js.map +1 -1
- package/dist/server/storage/repositories/session-changed-file-repository.d.ts +6 -0
- package/dist/server/storage/repositories/session-changed-file-repository.js +44 -43
- package/dist/server/storage/repositories/session-changed-file-repository.js.map +1 -1
- package/dist/server/storage/repositories/session-fork-repository.d.ts +2 -0
- package/dist/server/storage/repositories/session-fork-repository.js +42 -41
- package/dist/server/storage/repositories/session-fork-repository.js.map +1 -1
- package/dist/server/storage/repositories/session-index-repository.d.ts +5 -0
- package/dist/server/storage/repositories/session-index-repository.js +153 -152
- package/dist/server/storage/repositories/session-index-repository.js.map +1 -1
- package/dist/server/storage/repositories/session-message-attachment-repository.d.ts +7 -0
- package/dist/server/storage/repositories/session-message-attachment-repository.js +91 -90
- package/dist/server/storage/repositories/session-message-attachment-repository.js.map +1 -1
- package/dist/server/storage/repositories/session-message-origin-repository.d.ts +2 -0
- package/dist/server/storage/repositories/session-message-origin-repository.js +25 -24
- package/dist/server/storage/repositories/session-message-origin-repository.js.map +1 -1
- package/dist/server/storage/repositories/session-state-repository.d.ts +2 -0
- package/dist/server/storage/repositories/session-state-repository.js +35 -34
- package/dist/server/storage/repositories/session-state-repository.js.map +1 -1
- package/dist/server/storage/repositories/session-status-snapshot-repository.d.ts +2 -0
- package/dist/server/storage/repositories/session-status-snapshot-repository.js +25 -24
- package/dist/server/storage/repositories/session-status-snapshot-repository.js.map +1 -1
- package/dist/server/storage/sqlite/client.js +123 -1
- package/dist/server/storage/sqlite/client.js.map +1 -1
- package/dist/server/storage/sqlite/schema.sql +300 -1
- package/dist/server/types/domain.d.ts +205 -1
- package/package.json +14 -7
- package/scripts/postinstall.mjs +170 -36
- package/dist/public/assets/FileContextPanel-xGTYDclT.js +0 -1
- package/dist/public/assets/WorkbenchLayout-DScHaza9.js +0 -244
- package/dist/public/assets/WorkbenchShellRoute-DN6LdrqC.js +0 -1
- package/dist/public/assets/WorkbenchShellRoute-DhQo_0vu.css +0 -1
- package/dist/public/assets/file-tree-icon-lfU9Ag77.js +0 -3
- package/dist/public/assets/index-CFYXCsyx.css +0 -1
- package/dist/public/assets/index-NGxWr8Ix.js +0 -42
- package/node_modules/@codingns/session-sync-core/dist/claude-message-utils.d.ts +0 -42
- package/node_modules/@codingns/session-sync-core/dist/claude-message-utils.js +0 -346
- package/node_modules/@codingns/session-sync-core/dist/claude-message-utils.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/codex-resume-history.d.ts +0 -1
- package/node_modules/@codingns/session-sync-core/dist/codex-resume-history.js +0 -80
- package/node_modules/@codingns/session-sync-core/dist/codex-resume-history.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/index.d.ts +0 -18
- package/node_modules/@codingns/session-sync-core/dist/index.js +0 -19
- package/node_modules/@codingns/session-sync-core/dist/index.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/kimi-message-normalizer.d.ts +0 -18
- package/node_modules/@codingns/session-sync-core/dist/kimi-message-normalizer.js +0 -659
- package/node_modules/@codingns/session-sync-core/dist/kimi-message-normalizer.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/kimi-shared.d.ts +0 -11
- package/node_modules/@codingns/session-sync-core/dist/kimi-shared.js +0 -72
- package/node_modules/@codingns/session-sync-core/dist/kimi-shared.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/patch-builder.d.ts +0 -67
- package/node_modules/@codingns/session-sync-core/dist/patch-builder.js +0 -752
- package/node_modules/@codingns/session-sync-core/dist/patch-builder.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/claude-code.d.ts +0 -48
- package/node_modules/@codingns/session-sync-core/dist/providers/claude-code.js +0 -1184
- package/node_modules/@codingns/session-sync-core/dist/providers/claude-code.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/claude-session-store.d.ts +0 -11
- package/node_modules/@codingns/session-sync-core/dist/providers/claude-session-store.js +0 -105
- package/node_modules/@codingns/session-sync-core/dist/providers/claude-session-store.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/codex.d.ts +0 -84
- package/node_modules/@codingns/session-sync-core/dist/providers/codex.js +0 -2436
- package/node_modules/@codingns/session-sync-core/dist/providers/codex.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/gemini.d.ts +0 -47
- package/node_modules/@codingns/session-sync-core/dist/providers/gemini.js +0 -1480
- package/node_modules/@codingns/session-sync-core/dist/providers/gemini.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/kimi.d.ts +0 -33
- package/node_modules/@codingns/session-sync-core/dist/providers/kimi.js +0 -684
- package/node_modules/@codingns/session-sync-core/dist/providers/kimi.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/legna-code.d.ts +0 -9
- package/node_modules/@codingns/session-sync-core/dist/providers/legna-code.js +0 -17
- package/node_modules/@codingns/session-sync-core/dist/providers/legna-code.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/opencode-permissions.d.ts +0 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/opencode-permissions.js +0 -8
- package/node_modules/@codingns/session-sync-core/dist/providers/opencode-permissions.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/opencode-shared.d.ts +0 -48
- package/node_modules/@codingns/session-sync-core/dist/providers/opencode-shared.js +0 -373
- package/node_modules/@codingns/session-sync-core/dist/providers/opencode-shared.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/opencode.d.ts +0 -61
- package/node_modules/@codingns/session-sync-core/dist/providers/opencode.js +0 -1191
- package/node_modules/@codingns/session-sync-core/dist/providers/opencode.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/utils.d.ts +0 -27
- package/node_modules/@codingns/session-sync-core/dist/providers/utils.js +0 -415
- package/node_modules/@codingns/session-sync-core/dist/providers/utils.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/registry.d.ts +0 -7
- package/node_modules/@codingns/session-sync-core/dist/registry.js +0 -22
- package/node_modules/@codingns/session-sync-core/dist/registry.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/runtime/active-run-registry.d.ts +0 -24
- package/node_modules/@codingns/session-sync-core/dist/runtime/active-run-registry.js +0 -329
- package/node_modules/@codingns/session-sync-core/dist/runtime/active-run-registry.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/runtime/claude-runtime.d.ts +0 -30
- package/node_modules/@codingns/session-sync-core/dist/runtime/claude-runtime.js +0 -939
- package/node_modules/@codingns/session-sync-core/dist/runtime/claude-runtime.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/runtime/codex-permissions.d.ts +0 -1
- package/node_modules/@codingns/session-sync-core/dist/runtime/codex-permissions.js +0 -16
- package/node_modules/@codingns/session-sync-core/dist/runtime/codex-permissions.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.d.ts +0 -70
- package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.js +0 -2571
- package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/runtime/gemini-runtime.d.ts +0 -21
- package/node_modules/@codingns/session-sync-core/dist/runtime/gemini-runtime.js +0 -561
- package/node_modules/@codingns/session-sync-core/dist/runtime/gemini-runtime.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/runtime/kimi-runtime.d.ts +0 -38
- package/node_modules/@codingns/session-sync-core/dist/runtime/kimi-runtime.js +0 -911
- package/node_modules/@codingns/session-sync-core/dist/runtime/kimi-runtime.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/runtime/legna-runtime.d.ts +0 -15
- package/node_modules/@codingns/session-sync-core/dist/runtime/legna-runtime.js +0 -16
- package/node_modules/@codingns/session-sync-core/dist/runtime/legna-runtime.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/runtime/opencode-runtime.d.ts +0 -37
- package/node_modules/@codingns/session-sync-core/dist/runtime/opencode-runtime.js +0 -963
- package/node_modules/@codingns/session-sync-core/dist/runtime/opencode-runtime.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/runtime/provider-runtime-service.d.ts +0 -21
- package/node_modules/@codingns/session-sync-core/dist/runtime/provider-runtime-service.js +0 -168
- package/node_modules/@codingns/session-sync-core/dist/runtime/provider-runtime-service.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/runtime/types.d.ts +0 -152
- package/node_modules/@codingns/session-sync-core/dist/runtime/types.js +0 -2
- package/node_modules/@codingns/session-sync-core/dist/runtime/types.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/services.d.ts +0 -28
- package/node_modules/@codingns/session-sync-core/dist/services.js +0 -148
- package/node_modules/@codingns/session-sync-core/dist/services.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/sqlite/node-sqlite.d.ts +0 -6
- package/node_modules/@codingns/session-sync-core/dist/sqlite/node-sqlite.js +0 -9
- package/node_modules/@codingns/session-sync-core/dist/sqlite/node-sqlite.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/dist/types.d.ts +0 -198
- package/node_modules/@codingns/session-sync-core/dist/types.js +0 -2
- package/node_modules/@codingns/session-sync-core/dist/types.js.map +0 -1
- package/node_modules/@codingns/session-sync-core/package.json +0 -33
|
@@ -3,6 +3,90 @@ import { AppError } from "../../shared/errors/app-error.js";
|
|
|
3
3
|
import { nowIso } from "../../shared/utils/time.js";
|
|
4
4
|
import { recordButlerProxyMessageOrigin } from "../sessions/session-message-origin-utils.js";
|
|
5
5
|
import { createProviderDisabledError } from "../provider/provider-disabled.js";
|
|
6
|
+
const WORKSPACE_SCOPED_DEFAULT_CAPABILITIES = new Set([
|
|
7
|
+
"capabilities.list",
|
|
8
|
+
"projects.get",
|
|
9
|
+
"sessions.get",
|
|
10
|
+
"sessions.messages.list",
|
|
11
|
+
"sessions.runtime.get",
|
|
12
|
+
"terminals.create",
|
|
13
|
+
"terminals.list",
|
|
14
|
+
"terminals.history.read",
|
|
15
|
+
"office.document.create",
|
|
16
|
+
"office.document.update",
|
|
17
|
+
"office.document.export",
|
|
18
|
+
"office.document.task.get",
|
|
19
|
+
"office.browser.profile.list",
|
|
20
|
+
"office.browser.profile.create",
|
|
21
|
+
"office.browser.profile.get",
|
|
22
|
+
"office.browser.task.create",
|
|
23
|
+
"office.browser.task.get",
|
|
24
|
+
"office.ops.target.list",
|
|
25
|
+
"office.ops.target.create",
|
|
26
|
+
"office.ops.target.get",
|
|
27
|
+
"office.ops.ssh-task.create",
|
|
28
|
+
"office.ops.browser-task.create",
|
|
29
|
+
"office.ops.task.get",
|
|
30
|
+
"worktrees.tree",
|
|
31
|
+
"worktrees.create",
|
|
32
|
+
"worktrees.merge-preview",
|
|
33
|
+
"worktrees.cleanup"
|
|
34
|
+
]);
|
|
35
|
+
const WORKSPACE_SCOPED_CONFIRMATION_CAPABILITIES = new Set([
|
|
36
|
+
"terminals.input.send",
|
|
37
|
+
"terminals.close",
|
|
38
|
+
"office.ops.task.execute",
|
|
39
|
+
"debug-targets.analyze",
|
|
40
|
+
"debug-targets.framework-analysis.refresh",
|
|
41
|
+
"debug-targets.launch-plan.create",
|
|
42
|
+
"debug-targets.run",
|
|
43
|
+
"worktrees.merge-into-parent"
|
|
44
|
+
]);
|
|
45
|
+
const PROJECT_SCOPED_CAPABILITIES = new Set([
|
|
46
|
+
"projects.get",
|
|
47
|
+
"projects.sessions.list",
|
|
48
|
+
"projects.sessions.start",
|
|
49
|
+
"worktrees.tree",
|
|
50
|
+
"worktrees.create",
|
|
51
|
+
"worktrees.merge-preview",
|
|
52
|
+
"worktrees.merge-into-parent",
|
|
53
|
+
"worktrees.cleanup"
|
|
54
|
+
]);
|
|
55
|
+
const WORKSPACE_SCOPED_CAPABILITIES = new Set([
|
|
56
|
+
"capabilities.list",
|
|
57
|
+
"sessions.get",
|
|
58
|
+
"sessions.messages.list",
|
|
59
|
+
"sessions.runtime.get",
|
|
60
|
+
"terminals.create",
|
|
61
|
+
"terminals.list",
|
|
62
|
+
"terminals.history.read",
|
|
63
|
+
"terminals.input.send",
|
|
64
|
+
"terminals.close",
|
|
65
|
+
"office.document.create",
|
|
66
|
+
"office.document.update",
|
|
67
|
+
"office.document.export",
|
|
68
|
+
"office.document.task.get",
|
|
69
|
+
"office.browser.profile.list",
|
|
70
|
+
"office.browser.profile.create",
|
|
71
|
+
"office.browser.profile.get",
|
|
72
|
+
"office.browser.task.create",
|
|
73
|
+
"office.browser.task.get",
|
|
74
|
+
"office.ops.target.list",
|
|
75
|
+
"office.ops.target.create",
|
|
76
|
+
"office.ops.target.get",
|
|
77
|
+
"office.ops.ssh-task.create",
|
|
78
|
+
"office.ops.browser-task.create",
|
|
79
|
+
"office.ops.task.get",
|
|
80
|
+
"office.ops.task.execute",
|
|
81
|
+
"debug-targets.analyze",
|
|
82
|
+
"debug-targets.framework-analysis.get",
|
|
83
|
+
"debug-targets.framework-analysis.refresh",
|
|
84
|
+
"debug-targets.launch-plan.create",
|
|
85
|
+
"debug-targets.run",
|
|
86
|
+
"debug-targets.runtime-latest.get",
|
|
87
|
+
"debug-targets.runtimes.list",
|
|
88
|
+
"debug-runtimes.get"
|
|
89
|
+
]);
|
|
6
90
|
const ASSISTANT_CAPABILITIES = [
|
|
7
91
|
{
|
|
8
92
|
name: "capabilities.list",
|
|
@@ -226,6 +310,108 @@ const ASSISTANT_CAPABILITIES = [
|
|
|
226
310
|
enabled: true,
|
|
227
311
|
summary: "关闭指定受控终端"
|
|
228
312
|
},
|
|
313
|
+
{
|
|
314
|
+
name: "office.document.create",
|
|
315
|
+
mode: "proxy_execute",
|
|
316
|
+
enabled: true,
|
|
317
|
+
summary: "创建办公文档并返回文档摘要"
|
|
318
|
+
},
|
|
319
|
+
{
|
|
320
|
+
name: "office.document.update",
|
|
321
|
+
mode: "proxy_execute",
|
|
322
|
+
enabled: true,
|
|
323
|
+
summary: "更新办公文档并返回最新修订摘要"
|
|
324
|
+
},
|
|
325
|
+
{
|
|
326
|
+
name: "office.document.export",
|
|
327
|
+
mode: "proxy_execute",
|
|
328
|
+
enabled: true,
|
|
329
|
+
summary: "创建或执行文档导出任务,并返回任务状态与回执"
|
|
330
|
+
},
|
|
331
|
+
{
|
|
332
|
+
name: "office.document.task.get",
|
|
333
|
+
mode: "read",
|
|
334
|
+
enabled: true,
|
|
335
|
+
summary: "读取办公文档导出任务状态、产物与回执"
|
|
336
|
+
},
|
|
337
|
+
{
|
|
338
|
+
name: "office.browser.profile.list",
|
|
339
|
+
mode: "read",
|
|
340
|
+
enabled: true,
|
|
341
|
+
summary: "列出办公浏览器 Profile"
|
|
342
|
+
},
|
|
343
|
+
{
|
|
344
|
+
name: "office.browser.profile.create",
|
|
345
|
+
mode: "proxy_execute",
|
|
346
|
+
enabled: true,
|
|
347
|
+
summary: "创建独立或接管模式的办公浏览器 Profile"
|
|
348
|
+
},
|
|
349
|
+
{
|
|
350
|
+
name: "office.browser.profile.get",
|
|
351
|
+
mode: "read",
|
|
352
|
+
enabled: true,
|
|
353
|
+
summary: "读取办公浏览器 Profile 详情"
|
|
354
|
+
},
|
|
355
|
+
{
|
|
356
|
+
name: "office.browser.task.create",
|
|
357
|
+
mode: "proxy_execute",
|
|
358
|
+
enabled: true,
|
|
359
|
+
summary: "创建并可选执行办公浏览器任务"
|
|
360
|
+
},
|
|
361
|
+
{
|
|
362
|
+
name: "office.browser.task.get",
|
|
363
|
+
mode: "read",
|
|
364
|
+
enabled: true,
|
|
365
|
+
summary: "读取办公浏览器任务状态、产物与回执"
|
|
366
|
+
},
|
|
367
|
+
{
|
|
368
|
+
name: "office.ops.target.list",
|
|
369
|
+
mode: "read",
|
|
370
|
+
enabled: true,
|
|
371
|
+
summary: "列出办公运维目标"
|
|
372
|
+
},
|
|
373
|
+
{
|
|
374
|
+
name: "office.ops.target.create",
|
|
375
|
+
mode: "proxy_execute",
|
|
376
|
+
enabled: true,
|
|
377
|
+
summary: "创建 SSH 或网页控制台运维目标"
|
|
378
|
+
},
|
|
379
|
+
{
|
|
380
|
+
name: "office.ops.target.get",
|
|
381
|
+
mode: "read",
|
|
382
|
+
enabled: true,
|
|
383
|
+
summary: "读取办公运维目标详情"
|
|
384
|
+
},
|
|
385
|
+
{
|
|
386
|
+
name: "office.ops.ssh-task.create",
|
|
387
|
+
mode: "proxy_execute",
|
|
388
|
+
enabled: true,
|
|
389
|
+
summary: "创建 SSH 运维任务"
|
|
390
|
+
},
|
|
391
|
+
{
|
|
392
|
+
name: "office.ops.task.execute",
|
|
393
|
+
mode: "proxy_execute",
|
|
394
|
+
enabled: true,
|
|
395
|
+
summary: "执行已创建并准备好的 SSH 运维任务"
|
|
396
|
+
},
|
|
397
|
+
{
|
|
398
|
+
name: "office.task.approval.reply",
|
|
399
|
+
mode: "proxy_execute",
|
|
400
|
+
enabled: true,
|
|
401
|
+
summary: "处理办公任务审批,批准后任务可以继续执行"
|
|
402
|
+
},
|
|
403
|
+
{
|
|
404
|
+
name: "office.ops.browser-task.create",
|
|
405
|
+
mode: "proxy_execute",
|
|
406
|
+
enabled: true,
|
|
407
|
+
summary: "创建浏览器运维任务"
|
|
408
|
+
},
|
|
409
|
+
{
|
|
410
|
+
name: "office.ops.task.get",
|
|
411
|
+
mode: "read",
|
|
412
|
+
enabled: true,
|
|
413
|
+
summary: "读取办公运维任务状态、产物与回执"
|
|
414
|
+
},
|
|
229
415
|
{
|
|
230
416
|
name: "debug-targets.compatibility-matrix.get",
|
|
231
417
|
mode: "read",
|
|
@@ -377,6 +563,7 @@ export class AssistantCapabilityService {
|
|
|
377
563
|
terminalService;
|
|
378
564
|
debugTargetService;
|
|
379
565
|
workspaceService;
|
|
566
|
+
workspaceWorktreeRepository;
|
|
380
567
|
worktreeManager;
|
|
381
568
|
worktreeSyncService;
|
|
382
569
|
worktreeMergeService;
|
|
@@ -384,7 +571,13 @@ export class AssistantCapabilityService {
|
|
|
384
571
|
sessionMessageOriginRepository;
|
|
385
572
|
butlerFollowUpService;
|
|
386
573
|
providerControlRepository;
|
|
387
|
-
|
|
574
|
+
documentRuntimeService;
|
|
575
|
+
officeServiceForDocumentTask;
|
|
576
|
+
officePreviewLinkService;
|
|
577
|
+
browserRuntimeService;
|
|
578
|
+
opsRuntimeService;
|
|
579
|
+
capabilityDefinitions = augmentAssistantCapabilities(ASSISTANT_CAPABILITIES);
|
|
580
|
+
constructor(butlerProjectService, butlerSessionService, butlerControlSessionService, assistantAutomationService, assistantSandboxService, butlerControlTimerService, sessionHistoryService, sessionLiveRuntimeService, terminalService, debugTargetService, workspaceService, workspaceWorktreeRepository, worktreeManager, worktreeSyncService, worktreeMergeService, worktreeCleanupService, sessionMessageOriginRepository = null, butlerFollowUpService = null, providerControlRepository = null, documentRuntimeService = null, officeServiceForDocumentTask = null, officePreviewLinkService = null, browserRuntimeService = null, opsRuntimeService = null) {
|
|
388
581
|
this.butlerProjectService = butlerProjectService;
|
|
389
582
|
this.butlerSessionService = butlerSessionService;
|
|
390
583
|
this.butlerControlSessionService = butlerControlSessionService;
|
|
@@ -396,6 +589,7 @@ export class AssistantCapabilityService {
|
|
|
396
589
|
this.terminalService = terminalService;
|
|
397
590
|
this.debugTargetService = debugTargetService;
|
|
398
591
|
this.workspaceService = workspaceService;
|
|
592
|
+
this.workspaceWorktreeRepository = workspaceWorktreeRepository;
|
|
399
593
|
this.worktreeManager = worktreeManager;
|
|
400
594
|
this.worktreeSyncService = worktreeSyncService;
|
|
401
595
|
this.worktreeMergeService = worktreeMergeService;
|
|
@@ -403,14 +597,19 @@ export class AssistantCapabilityService {
|
|
|
403
597
|
this.sessionMessageOriginRepository = sessionMessageOriginRepository;
|
|
404
598
|
this.butlerFollowUpService = butlerFollowUpService;
|
|
405
599
|
this.providerControlRepository = providerControlRepository;
|
|
600
|
+
this.documentRuntimeService = documentRuntimeService;
|
|
601
|
+
this.officeServiceForDocumentTask = officeServiceForDocumentTask;
|
|
602
|
+
this.officePreviewLinkService = officePreviewLinkService;
|
|
603
|
+
this.browserRuntimeService = browserRuntimeService;
|
|
604
|
+
this.opsRuntimeService = opsRuntimeService;
|
|
406
605
|
}
|
|
407
|
-
listCapabilities() {
|
|
606
|
+
listCapabilities(context) {
|
|
408
607
|
return this.createReceipt("capabilities.list", {
|
|
409
608
|
kind: "none",
|
|
410
609
|
id: null
|
|
411
610
|
}, {
|
|
412
611
|
version: "2026-04-16",
|
|
413
|
-
items:
|
|
612
|
+
items: this.listVisibleCapabilities(context)
|
|
414
613
|
});
|
|
415
614
|
}
|
|
416
615
|
listProjects(input) {
|
|
@@ -450,6 +649,291 @@ export class AssistantCapabilityService {
|
|
|
450
649
|
items
|
|
451
650
|
});
|
|
452
651
|
}
|
|
652
|
+
createOfficeDocument(input) {
|
|
653
|
+
const detail = this.requireDocumentRuntimeService().createDocument({
|
|
654
|
+
userId: input.userId,
|
|
655
|
+
workspaceId: normalizeAssistantText(input.workspaceId) ?? undefined,
|
|
656
|
+
title: input.title,
|
|
657
|
+
templateId: normalizeAssistantText(input.templateId) ?? undefined,
|
|
658
|
+
templateKey: normalizeAssistantText(input.templateKey) ?? undefined,
|
|
659
|
+
content: input.content,
|
|
660
|
+
outline: input.outline,
|
|
661
|
+
summary: input.summary ?? undefined
|
|
662
|
+
});
|
|
663
|
+
return this.createReceipt("office.document.create", {
|
|
664
|
+
kind: "workspace",
|
|
665
|
+
id: detail.document.workspaceId
|
|
666
|
+
}, {
|
|
667
|
+
document: summarizeOfficeDocumentDetail(detail)
|
|
668
|
+
});
|
|
669
|
+
}
|
|
670
|
+
updateOfficeDocument(input) {
|
|
671
|
+
const detail = this.requireDocumentRuntimeService().updateDocument({
|
|
672
|
+
documentId: input.documentId,
|
|
673
|
+
userId: input.userId,
|
|
674
|
+
title: input.title ?? undefined,
|
|
675
|
+
templateId: normalizeAssistantText(input.templateId) ?? undefined,
|
|
676
|
+
content: input.content,
|
|
677
|
+
outline: input.outline,
|
|
678
|
+
summary: input.summary ?? undefined,
|
|
679
|
+
status: input.status
|
|
680
|
+
});
|
|
681
|
+
return this.createReceipt("office.document.update", {
|
|
682
|
+
kind: "workspace",
|
|
683
|
+
id: detail.document.workspaceId
|
|
684
|
+
}, {
|
|
685
|
+
document: summarizeOfficeDocumentDetail(detail)
|
|
686
|
+
});
|
|
687
|
+
}
|
|
688
|
+
async exportOfficeDocument(input) {
|
|
689
|
+
const createResult = this.requireDocumentRuntimeService().createExportTask({
|
|
690
|
+
documentId: input.documentId,
|
|
691
|
+
userId: input.userId,
|
|
692
|
+
workspaceId: normalizeAssistantText(input.workspaceId) ?? undefined,
|
|
693
|
+
format: input.format ?? "docx",
|
|
694
|
+
riskLevel: input.riskLevel
|
|
695
|
+
});
|
|
696
|
+
const execution = input.execute === false
|
|
697
|
+
? null
|
|
698
|
+
: await this.requireDocumentRuntimeService().executeExportTask(createResult.task.id, input.userId);
|
|
699
|
+
const detail = this.requireOfficeTaskService().getTaskDetail(createResult.task.id, input.userId);
|
|
700
|
+
return this.createReceipt("office.document.export", {
|
|
701
|
+
kind: "workspace",
|
|
702
|
+
id: detail.task.workspaceId
|
|
703
|
+
}, {
|
|
704
|
+
task: summarizeOfficeTaskDetail(detail, {
|
|
705
|
+
officePreviewLinkService: this.officePreviewLinkService,
|
|
706
|
+
userId: input.userId
|
|
707
|
+
}),
|
|
708
|
+
execution
|
|
709
|
+
});
|
|
710
|
+
}
|
|
711
|
+
getOfficeDocumentTask(taskId, userId) {
|
|
712
|
+
const detail = this.requireOfficeTaskService().getTaskDetail(taskId, userId);
|
|
713
|
+
return this.createReceipt("office.document.task.get", {
|
|
714
|
+
kind: "workspace",
|
|
715
|
+
id: detail.task.workspaceId
|
|
716
|
+
}, {
|
|
717
|
+
task: summarizeOfficeTaskDetail(detail, {
|
|
718
|
+
officePreviewLinkService: this.officePreviewLinkService,
|
|
719
|
+
userId
|
|
720
|
+
})
|
|
721
|
+
});
|
|
722
|
+
}
|
|
723
|
+
listOfficeBrowserProfiles(userId, workspaceId) {
|
|
724
|
+
const items = this.requireBrowserRuntimeService().listProfiles(userId, normalizeAssistantText(workspaceId) ?? undefined);
|
|
725
|
+
return this.createReceipt("office.browser.profile.list", {
|
|
726
|
+
kind: "workspace",
|
|
727
|
+
id: normalizeAssistantText(workspaceId)
|
|
728
|
+
}, {
|
|
729
|
+
items
|
|
730
|
+
});
|
|
731
|
+
}
|
|
732
|
+
getOfficeBrowserProfile(profileId, userId) {
|
|
733
|
+
const profile = this.requireBrowserRuntimeService().getProfile(profileId, userId);
|
|
734
|
+
return this.createReceipt("office.browser.profile.get", {
|
|
735
|
+
kind: "workspace",
|
|
736
|
+
id: profile.workspaceId
|
|
737
|
+
}, {
|
|
738
|
+
profile
|
|
739
|
+
});
|
|
740
|
+
}
|
|
741
|
+
createOfficeBrowserProfile(input) {
|
|
742
|
+
const browserRuntimeService = this.requireBrowserRuntimeService();
|
|
743
|
+
const profile = input.mode === "cdp_attached"
|
|
744
|
+
? browserRuntimeService.attachCdpProfile({
|
|
745
|
+
userId: input.userId,
|
|
746
|
+
workspaceId: normalizeAssistantText(input.workspaceId) ?? undefined,
|
|
747
|
+
engine: input.engine ?? "chrome",
|
|
748
|
+
mode: "cdp_attached",
|
|
749
|
+
displayName: input.displayName ?? undefined,
|
|
750
|
+
ownershipScope: input.ownershipScope ?? undefined,
|
|
751
|
+
cdpEndpoint: input.cdpEndpoint ?? undefined
|
|
752
|
+
})
|
|
753
|
+
: browserRuntimeService.createProfile({
|
|
754
|
+
userId: input.userId,
|
|
755
|
+
workspaceId: normalizeAssistantText(input.workspaceId) ?? undefined,
|
|
756
|
+
engine: input.engine ?? "chrome",
|
|
757
|
+
mode: "persistent",
|
|
758
|
+
displayName: input.displayName ?? undefined,
|
|
759
|
+
ownershipScope: input.ownershipScope ?? undefined,
|
|
760
|
+
cdpEndpoint: input.cdpEndpoint ?? undefined
|
|
761
|
+
});
|
|
762
|
+
return this.createReceipt("office.browser.profile.create", {
|
|
763
|
+
kind: "workspace",
|
|
764
|
+
id: profile.workspaceId
|
|
765
|
+
}, {
|
|
766
|
+
profile
|
|
767
|
+
});
|
|
768
|
+
}
|
|
769
|
+
async createOfficeBrowserTask(input) {
|
|
770
|
+
const createResult = this.requireBrowserRuntimeService().createBrowserTask({
|
|
771
|
+
userId: input.userId,
|
|
772
|
+
workspaceId: normalizeAssistantText(input.workspaceId) ?? undefined,
|
|
773
|
+
title: input.title,
|
|
774
|
+
profileId: normalizeAssistantText(input.profileId) ?? undefined,
|
|
775
|
+
riskLevel: input.riskLevel,
|
|
776
|
+
executionBackend: input.executionBackend,
|
|
777
|
+
input: input.input
|
|
778
|
+
});
|
|
779
|
+
const execution = input.execute === false
|
|
780
|
+
? null
|
|
781
|
+
: await this.requireBrowserRuntimeService().executeBrowserTask(createResult.task.id, input.userId);
|
|
782
|
+
const detail = this.requireOfficeTaskService().getTaskDetail(createResult.task.id, input.userId);
|
|
783
|
+
return this.createReceipt("office.browser.task.create", {
|
|
784
|
+
kind: "workspace",
|
|
785
|
+
id: detail.task.workspaceId
|
|
786
|
+
}, {
|
|
787
|
+
task: summarizeOfficeTaskDetail(detail, {
|
|
788
|
+
officePreviewLinkService: this.officePreviewLinkService,
|
|
789
|
+
userId: input.userId
|
|
790
|
+
}),
|
|
791
|
+
execution
|
|
792
|
+
});
|
|
793
|
+
}
|
|
794
|
+
getOfficeBrowserTask(taskId, userId) {
|
|
795
|
+
const detail = this.requireOfficeTaskService().getTaskDetail(taskId, userId);
|
|
796
|
+
return this.createReceipt("office.browser.task.get", {
|
|
797
|
+
kind: "workspace",
|
|
798
|
+
id: detail.task.workspaceId
|
|
799
|
+
}, {
|
|
800
|
+
task: summarizeOfficeTaskDetail(detail, {
|
|
801
|
+
officePreviewLinkService: this.officePreviewLinkService,
|
|
802
|
+
userId
|
|
803
|
+
})
|
|
804
|
+
});
|
|
805
|
+
}
|
|
806
|
+
listOfficeOpsTargets(userId, workspaceId, kind, status) {
|
|
807
|
+
const items = this.requireOpsRuntimeService().listTargets({
|
|
808
|
+
userId,
|
|
809
|
+
workspaceId: normalizeAssistantText(workspaceId) ?? undefined,
|
|
810
|
+
kind: kind ?? undefined,
|
|
811
|
+
status: status ?? undefined
|
|
812
|
+
});
|
|
813
|
+
return this.createReceipt("office.ops.target.list", {
|
|
814
|
+
kind: "workspace",
|
|
815
|
+
id: normalizeAssistantText(workspaceId)
|
|
816
|
+
}, {
|
|
817
|
+
items
|
|
818
|
+
});
|
|
819
|
+
}
|
|
820
|
+
getOfficeOpsTarget(targetId, userId) {
|
|
821
|
+
const target = this.requireOpsRuntimeService().getTarget(targetId, userId);
|
|
822
|
+
return this.createReceipt("office.ops.target.get", {
|
|
823
|
+
kind: "workspace",
|
|
824
|
+
id: target.workspaceId
|
|
825
|
+
}, {
|
|
826
|
+
target
|
|
827
|
+
});
|
|
828
|
+
}
|
|
829
|
+
createOfficeOpsTarget(input) {
|
|
830
|
+
const target = this.requireOpsRuntimeService().createTarget({
|
|
831
|
+
userId: input.userId,
|
|
832
|
+
workspaceId: normalizeAssistantText(input.workspaceId) ?? undefined,
|
|
833
|
+
kind: input.kind,
|
|
834
|
+
displayName: input.displayName,
|
|
835
|
+
environment: input.environment ?? undefined,
|
|
836
|
+
config: input.config,
|
|
837
|
+
credentialRef: input.credentialRef ?? undefined
|
|
838
|
+
});
|
|
839
|
+
return this.createReceipt("office.ops.target.create", {
|
|
840
|
+
kind: "workspace",
|
|
841
|
+
id: target.workspaceId
|
|
842
|
+
}, {
|
|
843
|
+
target
|
|
844
|
+
});
|
|
845
|
+
}
|
|
846
|
+
async createOfficeOpsSshTask(input) {
|
|
847
|
+
const createResult = this.requireOpsRuntimeService().createSshTask({
|
|
848
|
+
userId: input.userId,
|
|
849
|
+
title: input.title,
|
|
850
|
+
targetId: input.targetId,
|
|
851
|
+
riskLevel: input.riskLevel,
|
|
852
|
+
input: input.input
|
|
853
|
+
});
|
|
854
|
+
const execution = input.execute === false
|
|
855
|
+
? null
|
|
856
|
+
: createResult.task.status === "ready"
|
|
857
|
+
? await this.requireOpsRuntimeService().executeSshTask(createResult.task.id, input.userId)
|
|
858
|
+
: null;
|
|
859
|
+
const detail = this.requireOfficeTaskService().getTaskDetail(createResult.task.id, input.userId);
|
|
860
|
+
return this.createReceipt("office.ops.ssh-task.create", {
|
|
861
|
+
kind: "workspace",
|
|
862
|
+
id: detail.task.workspaceId
|
|
863
|
+
}, {
|
|
864
|
+
task: summarizeOfficeTaskDetail(detail, {
|
|
865
|
+
officePreviewLinkService: this.officePreviewLinkService,
|
|
866
|
+
userId: input.userId
|
|
867
|
+
}),
|
|
868
|
+
execution
|
|
869
|
+
});
|
|
870
|
+
}
|
|
871
|
+
async executeOfficeOpsTask(input) {
|
|
872
|
+
const execution = await this.requireOpsRuntimeService().executeSshTask(input.taskId, input.userId);
|
|
873
|
+
const detail = this.requireOfficeTaskService().getTaskDetail(input.taskId, input.userId);
|
|
874
|
+
return this.createReceipt("office.ops.task.execute", {
|
|
875
|
+
kind: "workspace",
|
|
876
|
+
id: detail.task.workspaceId
|
|
877
|
+
}, {
|
|
878
|
+
execution,
|
|
879
|
+
task: summarizeOfficeTaskDetail(detail, {
|
|
880
|
+
officePreviewLinkService: this.officePreviewLinkService,
|
|
881
|
+
userId: input.userId
|
|
882
|
+
})
|
|
883
|
+
});
|
|
884
|
+
}
|
|
885
|
+
replyOfficeTaskApproval(input) {
|
|
886
|
+
const approval = this.requireOfficeApprovalService().replyApproval({
|
|
887
|
+
approvalId: input.approvalId,
|
|
888
|
+
userId: input.userId,
|
|
889
|
+
status: input.status,
|
|
890
|
+
decisionNote: input.decisionNote ?? undefined
|
|
891
|
+
});
|
|
892
|
+
const detail = this.requireOfficeTaskService().getTaskDetail(approval.taskId, input.userId);
|
|
893
|
+
return this.createReceipt("office.task.approval.reply", {
|
|
894
|
+
kind: "workspace",
|
|
895
|
+
id: detail.task.workspaceId
|
|
896
|
+
}, {
|
|
897
|
+
approval,
|
|
898
|
+
task: summarizeOfficeTaskDetail(detail, {
|
|
899
|
+
officePreviewLinkService: this.officePreviewLinkService,
|
|
900
|
+
userId: input.userId
|
|
901
|
+
})
|
|
902
|
+
});
|
|
903
|
+
}
|
|
904
|
+
createOfficeOpsBrowserTask(input) {
|
|
905
|
+
const createResult = this.requireOpsRuntimeService().createBrowserTask({
|
|
906
|
+
userId: input.userId,
|
|
907
|
+
title: input.title,
|
|
908
|
+
targetId: input.targetId,
|
|
909
|
+
profileId: normalizeAssistantText(input.profileId) ?? undefined,
|
|
910
|
+
executionBackend: input.executionBackend,
|
|
911
|
+
riskLevel: input.riskLevel,
|
|
912
|
+
input: input.input
|
|
913
|
+
});
|
|
914
|
+
const detail = this.requireOfficeTaskService().getTaskDetail(createResult.task.id, input.userId);
|
|
915
|
+
return this.createReceipt("office.ops.browser-task.create", {
|
|
916
|
+
kind: "workspace",
|
|
917
|
+
id: detail.task.workspaceId
|
|
918
|
+
}, {
|
|
919
|
+
task: summarizeOfficeTaskDetail(detail, {
|
|
920
|
+
officePreviewLinkService: this.officePreviewLinkService,
|
|
921
|
+
userId: input.userId
|
|
922
|
+
})
|
|
923
|
+
});
|
|
924
|
+
}
|
|
925
|
+
getOfficeOpsTask(taskId, userId) {
|
|
926
|
+
const detail = this.requireOfficeTaskService().getTaskDetail(taskId, userId);
|
|
927
|
+
return this.createReceipt("office.ops.task.get", {
|
|
928
|
+
kind: "workspace",
|
|
929
|
+
id: detail.task.workspaceId
|
|
930
|
+
}, {
|
|
931
|
+
task: summarizeOfficeTaskDetail(detail, {
|
|
932
|
+
officePreviewLinkService: this.officePreviewLinkService,
|
|
933
|
+
userId
|
|
934
|
+
})
|
|
935
|
+
});
|
|
936
|
+
}
|
|
453
937
|
async startProjectSession(input) {
|
|
454
938
|
const config = this.resolveSessionLaunchConfig(input);
|
|
455
939
|
const session = await this.butlerSessionService.startSession(input.projectId, {
|
|
@@ -526,6 +1010,7 @@ export class AssistantCapabilityService {
|
|
|
526
1010
|
});
|
|
527
1011
|
}
|
|
528
1012
|
async listSessionMessages(input) {
|
|
1013
|
+
this.sessionHistoryService.getSession(input.sessionId, input.userId);
|
|
529
1014
|
const page = await this.sessionHistoryService.readSessionHistory(input.sessionId, input.cursor, input.limit, input.direction, input.userId);
|
|
530
1015
|
return this.createReceipt("sessions.messages.list", {
|
|
531
1016
|
kind: "session",
|
|
@@ -535,6 +1020,7 @@ export class AssistantCapabilityService {
|
|
|
535
1020
|
});
|
|
536
1021
|
}
|
|
537
1022
|
async getSessionRuntime(sessionId, userId) {
|
|
1023
|
+
this.sessionHistoryService.getSession(sessionId, userId);
|
|
538
1024
|
const runtime = await this.sessionLiveRuntimeService.getSessionRuntime(sessionId, userId);
|
|
539
1025
|
return this.createReceipt("sessions.runtime.get", {
|
|
540
1026
|
kind: "session",
|
|
@@ -931,6 +1417,40 @@ export class AssistantCapabilityService {
|
|
|
931
1417
|
timer
|
|
932
1418
|
});
|
|
933
1419
|
}
|
|
1420
|
+
async createTerminal(input) {
|
|
1421
|
+
const workspaceId = input.projectId?.trim()
|
|
1422
|
+
? this.butlerProjectService.getById(input.projectId).workspaceId
|
|
1423
|
+
: input.workspaceId?.trim() || "";
|
|
1424
|
+
if (!workspaceId) {
|
|
1425
|
+
throw new AppError({
|
|
1426
|
+
statusCode: 400,
|
|
1427
|
+
errorCode: "INVALID_INPUT",
|
|
1428
|
+
detail: "创建终端必须提供 workspaceId 或 projectId",
|
|
1429
|
+
field: "workspaceId"
|
|
1430
|
+
});
|
|
1431
|
+
}
|
|
1432
|
+
const terminal = await this.terminalService.createTerminal({
|
|
1433
|
+
workspaceId,
|
|
1434
|
+
name: normalizeAssistantText(input.name) ?? undefined,
|
|
1435
|
+
cwd: normalizeAssistantText(input.cwd) ?? undefined,
|
|
1436
|
+
shell: normalizeAssistantText(input.shell) ?? undefined,
|
|
1437
|
+
createdByUserId: input.userId
|
|
1438
|
+
});
|
|
1439
|
+
return this.createReceipt("terminals.create", {
|
|
1440
|
+
kind: input.projectId?.trim() ? "project" : "workspace",
|
|
1441
|
+
id: input.projectId?.trim() || workspaceId
|
|
1442
|
+
}, {
|
|
1443
|
+
workspaceId,
|
|
1444
|
+
terminal: {
|
|
1445
|
+
id: terminal.id,
|
|
1446
|
+
workspaceId: terminal.workspaceId,
|
|
1447
|
+
name: terminal.name,
|
|
1448
|
+
cwd: terminal.cwd,
|
|
1449
|
+
shell: terminal.shell,
|
|
1450
|
+
status: terminal.status
|
|
1451
|
+
}
|
|
1452
|
+
});
|
|
1453
|
+
}
|
|
934
1454
|
async listTerminals(input) {
|
|
935
1455
|
const workspaceId = input.projectId?.trim()
|
|
936
1456
|
? this.butlerProjectService.getById(input.projectId).workspaceId
|
|
@@ -1209,6 +1729,186 @@ export class AssistantCapabilityService {
|
|
|
1209
1729
|
payload
|
|
1210
1730
|
};
|
|
1211
1731
|
}
|
|
1732
|
+
getCapabilityDefinition(capability) {
|
|
1733
|
+
return this.capabilityDefinitions.find((item) => item.name === capability) ?? null;
|
|
1734
|
+
}
|
|
1735
|
+
listVisibleCapabilities(context) {
|
|
1736
|
+
const profile = context?.capabilityProfile ?? resolveAssistantCapabilityProfile(context?.callerKind);
|
|
1737
|
+
return this.capabilityDefinitions
|
|
1738
|
+
.filter((item) => item.enabled)
|
|
1739
|
+
.filter((item) => profile ? item.allowedProfiles.includes(profile) : true)
|
|
1740
|
+
.map((item) => toVisibleCapabilityDescriptor(item));
|
|
1741
|
+
}
|
|
1742
|
+
assertExecutionAllowed(capability, context, target) {
|
|
1743
|
+
const definition = this.getCapabilityDefinition(capability);
|
|
1744
|
+
if (!definition) {
|
|
1745
|
+
return;
|
|
1746
|
+
}
|
|
1747
|
+
const profile = context.capabilityProfile ?? resolveAssistantCapabilityProfile(context.callerKind);
|
|
1748
|
+
if (profile && !definition.allowedProfiles.includes(profile)) {
|
|
1749
|
+
throw new AppError({
|
|
1750
|
+
statusCode: 403,
|
|
1751
|
+
errorCode: "ASSISTANT_CAPABILITY_NOT_ALLOWED",
|
|
1752
|
+
detail: `当前调用者无权使用能力 ${capability}`
|
|
1753
|
+
});
|
|
1754
|
+
}
|
|
1755
|
+
if (profile === "workspace-scoped" && definition.requiresConfirmation) {
|
|
1756
|
+
this.assertConfirmationSatisfied(capability, context);
|
|
1757
|
+
}
|
|
1758
|
+
if (profile !== "workspace-scoped") {
|
|
1759
|
+
return;
|
|
1760
|
+
}
|
|
1761
|
+
if (definition.scopeKind === "workspace") {
|
|
1762
|
+
const userId = this.requireExecutionUserId(context, capability);
|
|
1763
|
+
const targetWorkspaceId = target?.workspaceId
|
|
1764
|
+
?? (target?.projectId ? this.butlerProjectService.getById(target.projectId).workspaceId : null)
|
|
1765
|
+
?? (target?.sessionId ? this.sessionHistoryService.getSession(target.sessionId, userId).workspaceId : null)
|
|
1766
|
+
?? (target?.terminalId ? this.terminalService.getTerminalOrThrow(target.terminalId).workspaceId : null);
|
|
1767
|
+
const documentWorkspaceId = target?.documentId
|
|
1768
|
+
? this.requireDocumentRuntimeService().getDocumentDetail(target.documentId, userId).document.workspaceId
|
|
1769
|
+
: null;
|
|
1770
|
+
const officeTaskWorkspaceId = target?.officeTaskId
|
|
1771
|
+
? this.requireOfficeTaskService().getTaskDetail(target.officeTaskId, userId).task.workspaceId
|
|
1772
|
+
: null;
|
|
1773
|
+
const browserProfileWorkspaceId = target?.browserProfileId
|
|
1774
|
+
? this.requireBrowserRuntimeService().getProfile(target.browserProfileId, userId).workspaceId
|
|
1775
|
+
: null;
|
|
1776
|
+
const debugTargetWorkspaceId = target?.debugTargetId
|
|
1777
|
+
? this.debugTargetService.getTargetWorkspaceId(target.debugTargetId)
|
|
1778
|
+
: null;
|
|
1779
|
+
const debugRuntimeWorkspaceId = target?.debugRuntimeId
|
|
1780
|
+
? this.debugTargetService.getRuntimeWorkspaceId(target.debugRuntimeId)
|
|
1781
|
+
: null;
|
|
1782
|
+
this.assertConsistentWorkspaceTargets(capability, [
|
|
1783
|
+
targetWorkspaceId,
|
|
1784
|
+
documentWorkspaceId,
|
|
1785
|
+
officeTaskWorkspaceId,
|
|
1786
|
+
browserProfileWorkspaceId,
|
|
1787
|
+
debugTargetWorkspaceId,
|
|
1788
|
+
debugRuntimeWorkspaceId
|
|
1789
|
+
]);
|
|
1790
|
+
const resolvedWorkspaceId = target?.worktreeWorkspaceId
|
|
1791
|
+
? this.resolveRootWorkspaceId(target.worktreeWorkspaceId)
|
|
1792
|
+
: debugRuntimeWorkspaceId
|
|
1793
|
+
?? debugTargetWorkspaceId
|
|
1794
|
+
?? browserProfileWorkspaceId
|
|
1795
|
+
?? officeTaskWorkspaceId
|
|
1796
|
+
?? documentWorkspaceId
|
|
1797
|
+
?? targetWorkspaceId;
|
|
1798
|
+
this.assertWorkspaceScopedTarget(context.workspaceId, resolvedWorkspaceId, capability);
|
|
1799
|
+
return;
|
|
1800
|
+
}
|
|
1801
|
+
if (definition.scopeKind === "project") {
|
|
1802
|
+
if (capability.startsWith("worktrees.")) {
|
|
1803
|
+
this.assertWorktreeExecutionAllowed(capability, context, target?.worktreeWorkspaceId ?? target?.workspaceId);
|
|
1804
|
+
return;
|
|
1805
|
+
}
|
|
1806
|
+
const projectId = target?.projectId
|
|
1807
|
+
?? (target?.worktreeWorkspaceId
|
|
1808
|
+
? (() => {
|
|
1809
|
+
const rootWorkspaceId = this.resolveRootWorkspaceId(target.worktreeWorkspaceId);
|
|
1810
|
+
return rootWorkspaceId ? this.resolveWorkspaceProject(rootWorkspaceId).id : null;
|
|
1811
|
+
})()
|
|
1812
|
+
: null)
|
|
1813
|
+
?? context.projectId;
|
|
1814
|
+
if (!projectId) {
|
|
1815
|
+
throw new AppError({
|
|
1816
|
+
statusCode: 403,
|
|
1817
|
+
errorCode: "ASSISTANT_PROJECT_SCOPE_REQUIRED",
|
|
1818
|
+
detail: `能力 ${capability} 必须绑定当前项目作用域`
|
|
1819
|
+
});
|
|
1820
|
+
}
|
|
1821
|
+
const project = this.butlerProjectService.getById(projectId);
|
|
1822
|
+
this.assertWorkspaceScopedTarget(context.workspaceId, project.workspaceId, capability);
|
|
1823
|
+
if (context.projectId && context.projectId !== projectId) {
|
|
1824
|
+
throw new AppError({
|
|
1825
|
+
statusCode: 403,
|
|
1826
|
+
errorCode: "ASSISTANT_PROJECT_SCOPE_MISMATCH",
|
|
1827
|
+
detail: `能力 ${capability} 不能跨项目执行`
|
|
1828
|
+
});
|
|
1829
|
+
}
|
|
1830
|
+
}
|
|
1831
|
+
}
|
|
1832
|
+
assertWorkspaceScopedTarget(scopedWorkspaceId, targetWorkspaceId, capability) {
|
|
1833
|
+
if (!scopedWorkspaceId || !targetWorkspaceId || scopedWorkspaceId !== targetWorkspaceId) {
|
|
1834
|
+
throw new AppError({
|
|
1835
|
+
statusCode: 403,
|
|
1836
|
+
errorCode: "ASSISTANT_WORKSPACE_SCOPE_MISMATCH",
|
|
1837
|
+
detail: `能力 ${capability} 不能跨工作区执行`
|
|
1838
|
+
});
|
|
1839
|
+
}
|
|
1840
|
+
}
|
|
1841
|
+
assertConfirmationSatisfied(capability, context) {
|
|
1842
|
+
if (normalizeAssistantText(context.confirmationToken) === "confirmed") {
|
|
1843
|
+
return;
|
|
1844
|
+
}
|
|
1845
|
+
throw new AppError({
|
|
1846
|
+
statusCode: 409,
|
|
1847
|
+
errorCode: "ASSISTANT_CONFIRMATION_REQUIRED",
|
|
1848
|
+
detail: `能力 ${capability} 需要用户显式确认后才能执行`,
|
|
1849
|
+
data: {
|
|
1850
|
+
capability,
|
|
1851
|
+
confirmationRequired: true
|
|
1852
|
+
}
|
|
1853
|
+
});
|
|
1854
|
+
}
|
|
1855
|
+
assertConsistentWorkspaceTargets(capability, workspaceIds) {
|
|
1856
|
+
const normalized = workspaceIds.filter((item) => Boolean(item));
|
|
1857
|
+
if (normalized.length <= 1) {
|
|
1858
|
+
return;
|
|
1859
|
+
}
|
|
1860
|
+
const first = normalized[0];
|
|
1861
|
+
if (normalized.some((item) => item !== first)) {
|
|
1862
|
+
throw new AppError({
|
|
1863
|
+
statusCode: 403,
|
|
1864
|
+
errorCode: "ASSISTANT_WORKSPACE_SCOPE_MISMATCH",
|
|
1865
|
+
detail: `能力 ${capability} 的目标资源不属于同一工作区`
|
|
1866
|
+
});
|
|
1867
|
+
}
|
|
1868
|
+
}
|
|
1869
|
+
assertWorktreeExecutionAllowed(capability, context, targetWorkspaceId) {
|
|
1870
|
+
if (!targetWorkspaceId) {
|
|
1871
|
+
throw new AppError({
|
|
1872
|
+
statusCode: 403,
|
|
1873
|
+
errorCode: "ASSISTANT_PROJECT_SCOPE_REQUIRED",
|
|
1874
|
+
detail: `能力 ${capability} 必须绑定当前项目作用域`
|
|
1875
|
+
});
|
|
1876
|
+
}
|
|
1877
|
+
const scopedRootWorkspaceId = this.resolveRootWorkspaceId(context.workspaceId);
|
|
1878
|
+
const targetRootWorkspaceId = this.resolveRootWorkspaceId(targetWorkspaceId);
|
|
1879
|
+
this.assertWorkspaceScopedTarget(scopedRootWorkspaceId, targetRootWorkspaceId, capability);
|
|
1880
|
+
}
|
|
1881
|
+
resolveRootWorkspaceId(workspaceId) {
|
|
1882
|
+
const normalizedWorkspaceId = normalizeAssistantText(workspaceId);
|
|
1883
|
+
if (!normalizedWorkspaceId) {
|
|
1884
|
+
return null;
|
|
1885
|
+
}
|
|
1886
|
+
return this.workspaceWorktreeRepository.findByWorkspaceId(normalizedWorkspaceId)?.rootWorkspaceId
|
|
1887
|
+
?? normalizedWorkspaceId;
|
|
1888
|
+
}
|
|
1889
|
+
requireExecutionUserId(context, capability) {
|
|
1890
|
+
const userId = normalizeAssistantText(context.userId);
|
|
1891
|
+
if (!userId) {
|
|
1892
|
+
throw new AppError({
|
|
1893
|
+
statusCode: 403,
|
|
1894
|
+
errorCode: "ASSISTANT_EXECUTION_CONTEXT_INVALID",
|
|
1895
|
+
detail: `能力 ${capability} 缺少用户上下文`
|
|
1896
|
+
});
|
|
1897
|
+
}
|
|
1898
|
+
return userId;
|
|
1899
|
+
}
|
|
1900
|
+
resolveWorkspaceProject(workspaceId) {
|
|
1901
|
+
const candidates = this.butlerProjectService.list({ workspaceId });
|
|
1902
|
+
const project = candidates.find((item) => item.lifecycleStatus === "active") ?? candidates[0] ?? null;
|
|
1903
|
+
if (!project) {
|
|
1904
|
+
throw new AppError({
|
|
1905
|
+
statusCode: 404,
|
|
1906
|
+
errorCode: "BUTLER_PROJECT_NOT_FOUND",
|
|
1907
|
+
detail: "当前工作区没有可用项目,不能执行项目级能力"
|
|
1908
|
+
});
|
|
1909
|
+
}
|
|
1910
|
+
return project;
|
|
1911
|
+
}
|
|
1212
1912
|
requireFollowUpService() {
|
|
1213
1913
|
if (this.butlerFollowUpService) {
|
|
1214
1914
|
return this.butlerFollowUpService;
|
|
@@ -1219,6 +1919,56 @@ export class AssistantCapabilityService {
|
|
|
1219
1919
|
detail: "当前实例没有启用会话跟进能力"
|
|
1220
1920
|
});
|
|
1221
1921
|
}
|
|
1922
|
+
requireDocumentRuntimeService() {
|
|
1923
|
+
if (this.documentRuntimeService) {
|
|
1924
|
+
return this.documentRuntimeService;
|
|
1925
|
+
}
|
|
1926
|
+
throw new AppError({
|
|
1927
|
+
statusCode: 503,
|
|
1928
|
+
errorCode: "ASSISTANT_OFFICE_DOCUMENT_CAPABILITY_UNAVAILABLE",
|
|
1929
|
+
detail: "当前实例没有启用办公文档能力"
|
|
1930
|
+
});
|
|
1931
|
+
}
|
|
1932
|
+
requireBrowserRuntimeService() {
|
|
1933
|
+
if (this.browserRuntimeService) {
|
|
1934
|
+
return this.browserRuntimeService;
|
|
1935
|
+
}
|
|
1936
|
+
throw new AppError({
|
|
1937
|
+
statusCode: 503,
|
|
1938
|
+
errorCode: "ASSISTANT_OFFICE_BROWSER_CAPABILITY_UNAVAILABLE",
|
|
1939
|
+
detail: "当前实例没有启用办公浏览器能力"
|
|
1940
|
+
});
|
|
1941
|
+
}
|
|
1942
|
+
requireOpsRuntimeService() {
|
|
1943
|
+
if (this.opsRuntimeService) {
|
|
1944
|
+
return this.opsRuntimeService;
|
|
1945
|
+
}
|
|
1946
|
+
throw new AppError({
|
|
1947
|
+
statusCode: 503,
|
|
1948
|
+
errorCode: "ASSISTANT_OFFICE_OPS_CAPABILITY_UNAVAILABLE",
|
|
1949
|
+
detail: "当前实例没有启用办公运维能力"
|
|
1950
|
+
});
|
|
1951
|
+
}
|
|
1952
|
+
requireOfficeTaskService() {
|
|
1953
|
+
if (this.officeServiceForDocumentTask) {
|
|
1954
|
+
return this.officeServiceForDocumentTask;
|
|
1955
|
+
}
|
|
1956
|
+
throw new AppError({
|
|
1957
|
+
statusCode: 503,
|
|
1958
|
+
errorCode: "ASSISTANT_OFFICE_DOCUMENT_CAPABILITY_UNAVAILABLE",
|
|
1959
|
+
detail: "当前实例没有启用办公文档能力"
|
|
1960
|
+
});
|
|
1961
|
+
}
|
|
1962
|
+
requireOfficeApprovalService() {
|
|
1963
|
+
if (this.officeServiceForDocumentTask) {
|
|
1964
|
+
return this.officeServiceForDocumentTask;
|
|
1965
|
+
}
|
|
1966
|
+
throw new AppError({
|
|
1967
|
+
statusCode: 503,
|
|
1968
|
+
errorCode: "ASSISTANT_OFFICE_APPROVAL_CAPABILITY_UNAVAILABLE",
|
|
1969
|
+
detail: "当前实例没有启用办公审批能力"
|
|
1970
|
+
});
|
|
1971
|
+
}
|
|
1222
1972
|
resolveSessionLaunchConfig(input) {
|
|
1223
1973
|
const controlSession = this.butlerControlSessionService.getCurrentSession(input.userId);
|
|
1224
1974
|
const providerId = input.providerId?.trim()
|
|
@@ -1301,6 +2051,85 @@ function summarizeAssistantText(content) {
|
|
|
1301
2051
|
}
|
|
1302
2052
|
return normalized.length > 48 ? `${normalized.slice(0, 45)}...` : normalized;
|
|
1303
2053
|
}
|
|
2054
|
+
function summarizeOfficeDocumentDetail(detail) {
|
|
2055
|
+
return {
|
|
2056
|
+
id: detail.document.id,
|
|
2057
|
+
workspaceId: detail.document.workspaceId,
|
|
2058
|
+
title: detail.document.title,
|
|
2059
|
+
status: detail.document.status,
|
|
2060
|
+
template: {
|
|
2061
|
+
id: detail.template.id,
|
|
2062
|
+
key: detail.template.templateKey,
|
|
2063
|
+
version: detail.template.templateVersion,
|
|
2064
|
+
displayName: detail.template.displayName
|
|
2065
|
+
},
|
|
2066
|
+
currentRevision: detail.currentRevision
|
|
2067
|
+
? {
|
|
2068
|
+
id: detail.currentRevision.id,
|
|
2069
|
+
revisionSeq: detail.currentRevision.revisionSeq,
|
|
2070
|
+
summary: detail.currentRevision.summary,
|
|
2071
|
+
createdAt: detail.currentRevision.createdAt
|
|
2072
|
+
}
|
|
2073
|
+
: null,
|
|
2074
|
+
revisionCount: detail.revisions.length,
|
|
2075
|
+
openCommentCount: detail.comments.filter((item) => item.status === "open").length,
|
|
2076
|
+
updatedAt: detail.document.updatedAt
|
|
2077
|
+
};
|
|
2078
|
+
}
|
|
2079
|
+
function summarizeOfficeTaskDetail(detail, options) {
|
|
2080
|
+
return {
|
|
2081
|
+
id: detail.task.id,
|
|
2082
|
+
taskType: detail.task.taskType,
|
|
2083
|
+
title: detail.task.title,
|
|
2084
|
+
status: detail.task.status,
|
|
2085
|
+
riskLevel: detail.task.riskLevel,
|
|
2086
|
+
workspaceId: detail.task.workspaceId,
|
|
2087
|
+
targetRefKind: detail.task.targetRefKind,
|
|
2088
|
+
targetRefId: detail.task.targetRefId,
|
|
2089
|
+
createdAt: detail.task.createdAt,
|
|
2090
|
+
startedAt: detail.task.startedAt,
|
|
2091
|
+
finishedAt: detail.task.finishedAt,
|
|
2092
|
+
steps: detail.steps.map((step) => ({
|
|
2093
|
+
id: step.id,
|
|
2094
|
+
stepSeq: step.stepSeq,
|
|
2095
|
+
stepType: step.stepType,
|
|
2096
|
+
title: step.title,
|
|
2097
|
+
status: step.status,
|
|
2098
|
+
errorMessage: step.errorMessage,
|
|
2099
|
+
startedAt: step.startedAt,
|
|
2100
|
+
finishedAt: step.finishedAt
|
|
2101
|
+
})),
|
|
2102
|
+
artifacts: detail.artifacts.map((artifact) => ({
|
|
2103
|
+
id: artifact.id,
|
|
2104
|
+
kind: artifact.kind,
|
|
2105
|
+
name: artifact.name,
|
|
2106
|
+
contentType: artifact.contentType,
|
|
2107
|
+
previewPath: buildAssistantOfficeArtifactPreviewPath(artifact.id, options),
|
|
2108
|
+
previewUrl: null,
|
|
2109
|
+
metadataJson: artifact.metadataJson,
|
|
2110
|
+
createdAt: artifact.createdAt
|
|
2111
|
+
})),
|
|
2112
|
+
receipts: detail.receipts.map((receipt) => ({
|
|
2113
|
+
id: receipt.id,
|
|
2114
|
+
receiptType: receipt.receiptType,
|
|
2115
|
+
summary: receipt.summary,
|
|
2116
|
+
payloadJson: receipt.payloadJson,
|
|
2117
|
+
createdAt: receipt.createdAt
|
|
2118
|
+
}))
|
|
2119
|
+
};
|
|
2120
|
+
}
|
|
2121
|
+
function buildAssistantOfficeArtifactPreviewPath(artifactId, options) {
|
|
2122
|
+
const normalizedUserId = options?.userId?.trim();
|
|
2123
|
+
if (!options?.officePreviewLinkService || !normalizedUserId) {
|
|
2124
|
+
return null;
|
|
2125
|
+
}
|
|
2126
|
+
try {
|
|
2127
|
+
return options.officePreviewLinkService.createArtifactLink(artifactId, normalizedUserId).previewPath;
|
|
2128
|
+
}
|
|
2129
|
+
catch {
|
|
2130
|
+
return null;
|
|
2131
|
+
}
|
|
2132
|
+
}
|
|
1304
2133
|
function buildAssistantAutomationTriggerInput(triggerType, input) {
|
|
1305
2134
|
switch (triggerType) {
|
|
1306
2135
|
case "once":
|
|
@@ -1376,4 +2205,44 @@ function requireAssistantConditionKind(value) {
|
|
|
1376
2205
|
function assertNeverAssistantAutomationTriggerType(value) {
|
|
1377
2206
|
throw new Error(`Unexpected assistant automation triggerType: ${String(value)}`);
|
|
1378
2207
|
}
|
|
2208
|
+
function augmentAssistantCapabilities(items) {
|
|
2209
|
+
return items.map((item) => {
|
|
2210
|
+
const allowedProfiles = (WORKSPACE_SCOPED_DEFAULT_CAPABILITIES.has(item.name)
|
|
2211
|
+
? ["butler-full", "butler-ui", "workspace-scoped"]
|
|
2212
|
+
: ["butler-full", "butler-ui"]);
|
|
2213
|
+
const scopeKind = (PROJECT_SCOPED_CAPABILITIES.has(item.name)
|
|
2214
|
+
? "project"
|
|
2215
|
+
: WORKSPACE_SCOPED_CAPABILITIES.has(item.name)
|
|
2216
|
+
? "workspace"
|
|
2217
|
+
: "none");
|
|
2218
|
+
const requiresConfirmation = item.requiresConfirmation ?? WORKSPACE_SCOPED_CONFIRMATION_CAPABILITIES.has(item.name);
|
|
2219
|
+
return {
|
|
2220
|
+
...item,
|
|
2221
|
+
allowedProfiles,
|
|
2222
|
+
scopeKind,
|
|
2223
|
+
requiresConfirmation
|
|
2224
|
+
};
|
|
2225
|
+
});
|
|
2226
|
+
}
|
|
2227
|
+
function toVisibleCapabilityDescriptor(item) {
|
|
2228
|
+
return {
|
|
2229
|
+
name: item.name,
|
|
2230
|
+
mode: item.mode,
|
|
2231
|
+
enabled: item.enabled,
|
|
2232
|
+
summary: item.summary,
|
|
2233
|
+
requiresConfirmation: item.requiresConfirmation
|
|
2234
|
+
};
|
|
2235
|
+
}
|
|
2236
|
+
function resolveAssistantCapabilityProfile(callerKind) {
|
|
2237
|
+
if (callerKind === "assistant_runtime") {
|
|
2238
|
+
return "butler-full";
|
|
2239
|
+
}
|
|
2240
|
+
if (callerKind === "workspace_session") {
|
|
2241
|
+
return "workspace-scoped";
|
|
2242
|
+
}
|
|
2243
|
+
if (callerKind === "interactive_user") {
|
|
2244
|
+
return "butler-ui";
|
|
2245
|
+
}
|
|
2246
|
+
return null;
|
|
2247
|
+
}
|
|
1379
2248
|
//# sourceMappingURL=assistant-capability-service.js.map
|