aws-runtime-bridge 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +56 -0
- package/dist/adapter/AdapterRegistry.d.ts +53 -0
- package/dist/adapter/AdapterRegistry.d.ts.map +1 -0
- package/dist/adapter/AdapterRegistry.js +100 -0
- package/dist/adapter/AdapterRegistry.test.d.ts +5 -0
- package/dist/adapter/AdapterRegistry.test.d.ts.map +1 -0
- package/dist/adapter/AdapterRegistry.test.js +109 -0
- package/dist/adapter/ClaudeSdkAdapter.d.ts +120 -0
- package/dist/adapter/ClaudeSdkAdapter.d.ts.map +1 -0
- package/dist/adapter/ClaudeSdkAdapter.js +1140 -0
- package/dist/adapter/ClaudeSdkAdapter.test.d.ts +2 -0
- package/dist/adapter/ClaudeSdkAdapter.test.d.ts.map +1 -0
- package/dist/adapter/ClaudeSdkAdapter.test.js +95 -0
- package/dist/adapter/CodexSdkAdapter.d.ts +48 -0
- package/dist/adapter/CodexSdkAdapter.d.ts.map +1 -0
- package/dist/adapter/CodexSdkAdapter.js +750 -0
- package/dist/adapter/CodexSdkAdapter.test.d.ts +2 -0
- package/dist/adapter/CodexSdkAdapter.test.d.ts.map +1 -0
- package/dist/adapter/CodexSdkAdapter.test.js +245 -0
- package/dist/adapter/OpencodeSdkAdapter.d.ts +45 -0
- package/dist/adapter/OpencodeSdkAdapter.d.ts.map +1 -0
- package/dist/adapter/OpencodeSdkAdapter.js +622 -0
- package/dist/adapter/OpencodeSdkAdapter.test.d.ts +2 -0
- package/dist/adapter/OpencodeSdkAdapter.test.d.ts.map +1 -0
- package/dist/adapter/OpencodeSdkAdapter.test.js +14 -0
- package/dist/adapter/SdkProviderSpi.d.ts +15 -0
- package/dist/adapter/SdkProviderSpi.d.ts.map +1 -0
- package/dist/adapter/SdkProviderSpi.js +46 -0
- package/dist/adapter/adapter.test.d.ts +5 -0
- package/dist/adapter/adapter.test.d.ts.map +1 -0
- package/dist/adapter/adapter.test.js +180 -0
- package/dist/adapter/index.d.ts +11 -0
- package/dist/adapter/index.d.ts.map +1 -0
- package/dist/adapter/index.js +10 -0
- package/dist/adapter/types.d.ts +278 -0
- package/dist/adapter/types.d.ts.map +1 -0
- package/dist/adapter/types.js +278 -0
- package/dist/adapter/types.test.d.ts +2 -0
- package/dist/adapter/types.test.d.ts.map +1 -0
- package/dist/adapter/types.test.js +59 -0
- package/dist/adapters/cc-switch/common.d.ts +52 -0
- package/dist/adapters/cc-switch/common.d.ts.map +1 -0
- package/dist/adapters/cc-switch/common.js +61 -0
- package/dist/adapters/cc-switch/index.d.ts +25 -0
- package/dist/adapters/cc-switch/index.d.ts.map +1 -0
- package/dist/adapters/cc-switch/index.js +51 -0
- package/dist/adapters/cc-switch/mcp-claude.d.ts +15 -0
- package/dist/adapters/cc-switch/mcp-claude.d.ts.map +1 -0
- package/dist/adapters/cc-switch/mcp-claude.js +88 -0
- package/dist/adapters/cc-switch/mcp-claudecode.d.ts +15 -0
- package/dist/adapters/cc-switch/mcp-claudecode.d.ts.map +1 -0
- package/dist/adapters/cc-switch/mcp-claudecode.js +77 -0
- package/dist/adapters/cc-switch/mcp-codex.d.ts +17 -0
- package/dist/adapters/cc-switch/mcp-codex.d.ts.map +1 -0
- package/dist/adapters/cc-switch/mcp-codex.js +248 -0
- package/dist/adapters/cc-switch/mcp-codex.test.d.ts +2 -0
- package/dist/adapters/cc-switch/mcp-codex.test.d.ts.map +1 -0
- package/dist/adapters/cc-switch/mcp-codex.test.js +125 -0
- package/dist/adapters/cc-switch/mcp-opencode.d.ts +23 -0
- package/dist/adapters/cc-switch/mcp-opencode.d.ts.map +1 -0
- package/dist/adapters/cc-switch/mcp-opencode.js +100 -0
- package/dist/adapters/cc-switch/mcp-placeholder.d.ts +14 -0
- package/dist/adapters/cc-switch/mcp-placeholder.d.ts.map +1 -0
- package/dist/adapters/cc-switch/mcp-placeholder.js +19 -0
- package/dist/adapters/cc-switch/skill-claude.d.ts +15 -0
- package/dist/adapters/cc-switch/skill-claude.d.ts.map +1 -0
- package/dist/adapters/cc-switch/skill-claude.js +91 -0
- package/dist/adapters/cc-switch/skill-claudecode.d.ts +15 -0
- package/dist/adapters/cc-switch/skill-claudecode.d.ts.map +1 -0
- package/dist/adapters/cc-switch/skill-claudecode.js +91 -0
- package/dist/adapters/cc-switch/skill-opencode.d.ts +15 -0
- package/dist/adapters/cc-switch/skill-opencode.d.ts.map +1 -0
- package/dist/adapters/cc-switch/skill-opencode.js +95 -0
- package/dist/adapters/cc-switch/skill-placeholder.d.ts +14 -0
- package/dist/adapters/cc-switch/skill-placeholder.d.ts.map +1 -0
- package/dist/adapters/cc-switch/skill-placeholder.js +19 -0
- package/dist/config.d.ts +76 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +109 -0
- package/dist/index.d.ts +8 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +503 -0
- package/dist/middleware/auth.d.ts +12 -0
- package/dist/middleware/auth.d.ts.map +1 -0
- package/dist/middleware/auth.js +18 -0
- package/dist/routes/ai-sources.d.ts +2 -0
- package/dist/routes/ai-sources.d.ts.map +1 -0
- package/dist/routes/ai-sources.js +136 -0
- package/dist/routes/ai-sources.test.d.ts +2 -0
- package/dist/routes/ai-sources.test.d.ts.map +1 -0
- package/dist/routes/ai-sources.test.js +148 -0
- package/dist/routes/aws-mcp.d.ts +10 -0
- package/dist/routes/aws-mcp.d.ts.map +1 -0
- package/dist/routes/aws-mcp.js +74 -0
- package/dist/routes/aws-mcp.test.d.ts +2 -0
- package/dist/routes/aws-mcp.test.d.ts.map +1 -0
- package/dist/routes/aws-mcp.test.js +42 -0
- package/dist/routes/file-browser.d.ts +7 -0
- package/dist/routes/file-browser.d.ts.map +1 -0
- package/dist/routes/file-browser.js +227 -0
- package/dist/routes/file-browser.test.d.ts +5 -0
- package/dist/routes/file-browser.test.d.ts.map +1 -0
- package/dist/routes/file-browser.test.js +88 -0
- package/dist/routes/git.d.ts +7 -0
- package/dist/routes/git.d.ts.map +1 -0
- package/dist/routes/git.js +470 -0
- package/dist/routes/git.test.d.ts +5 -0
- package/dist/routes/git.test.d.ts.map +1 -0
- package/dist/routes/git.test.js +87 -0
- package/dist/routes/instance.d.ts +3 -0
- package/dist/routes/instance.d.ts.map +1 -0
- package/dist/routes/instance.js +170 -0
- package/dist/routes/instance.test.d.ts +5 -0
- package/dist/routes/instance.test.d.ts.map +1 -0
- package/dist/routes/instance.test.js +64 -0
- package/dist/routes/mcp.d.ts +2 -0
- package/dist/routes/mcp.d.ts.map +1 -0
- package/dist/routes/mcp.js +171 -0
- package/dist/routes/mcp.test.d.ts +5 -0
- package/dist/routes/mcp.test.d.ts.map +1 -0
- package/dist/routes/mcp.test.js +84 -0
- package/dist/routes/memory.d.ts +13 -0
- package/dist/routes/memory.d.ts.map +1 -0
- package/dist/routes/memory.js +429 -0
- package/dist/routes/processes.d.ts +7 -0
- package/dist/routes/processes.d.ts.map +1 -0
- package/dist/routes/processes.js +245 -0
- package/dist/routes/properties.d.ts +7 -0
- package/dist/routes/properties.d.ts.map +1 -0
- package/dist/routes/properties.js +72 -0
- package/dist/routes/properties.test.d.ts +5 -0
- package/dist/routes/properties.test.d.ts.map +1 -0
- package/dist/routes/properties.test.js +72 -0
- package/dist/routes/sessions.d.ts +7 -0
- package/dist/routes/sessions.d.ts.map +1 -0
- package/dist/routes/sessions.js +808 -0
- package/dist/routes/sessions.test.d.ts +5 -0
- package/dist/routes/sessions.test.d.ts.map +1 -0
- package/dist/routes/sessions.test.js +70 -0
- package/dist/routes/skills.d.ts +2 -0
- package/dist/routes/skills.d.ts.map +1 -0
- package/dist/routes/skills.js +162 -0
- package/dist/routes/skills.test.d.ts +5 -0
- package/dist/routes/skills.test.d.ts.map +1 -0
- package/dist/routes/skills.test.js +42 -0
- package/dist/routes/terminal.d.ts +18 -0
- package/dist/routes/terminal.d.ts.map +1 -0
- package/dist/routes/terminal.js +663 -0
- package/dist/routes/terminal.test.d.ts +2 -0
- package/dist/routes/terminal.test.d.ts.map +1 -0
- package/dist/routes/terminal.test.js +91 -0
- package/dist/routes/yml.d.ts +7 -0
- package/dist/routes/yml.d.ts.map +1 -0
- package/dist/routes/yml.js +223 -0
- package/dist/routes/yml.test.d.ts +5 -0
- package/dist/routes/yml.test.d.ts.map +1 -0
- package/dist/routes/yml.test.js +58 -0
- package/dist/services/agent-process-manager.d.ts +241 -0
- package/dist/services/agent-process-manager.d.ts.map +1 -0
- package/dist/services/agent-process-manager.js +762 -0
- package/dist/services/auto-register.d.ts +94 -0
- package/dist/services/auto-register.d.ts.map +1 -0
- package/dist/services/auto-register.js +510 -0
- package/dist/services/aws-client-agent-mcp.d.ts +26 -0
- package/dist/services/aws-client-agent-mcp.d.ts.map +1 -0
- package/dist/services/aws-client-agent-mcp.js +142 -0
- package/dist/services/aws-client-agent-mcp.test.d.ts +2 -0
- package/dist/services/aws-client-agent-mcp.test.d.ts.map +1 -0
- package/dist/services/aws-client-agent-mcp.test.js +89 -0
- package/dist/services/aws-mcp-http.d.ts +11 -0
- package/dist/services/aws-mcp-http.d.ts.map +1 -0
- package/dist/services/aws-mcp-http.js +225 -0
- package/dist/services/aws-mcp-http.test.d.ts +2 -0
- package/dist/services/aws-mcp-http.test.d.ts.map +1 -0
- package/dist/services/aws-mcp-http.test.js +27 -0
- package/dist/services/cc-switch-sdk.d.ts +18 -0
- package/dist/services/cc-switch-sdk.d.ts.map +1 -0
- package/dist/services/cc-switch-sdk.js +117 -0
- package/dist/services/easytier-manager.d.ts +106 -0
- package/dist/services/easytier-manager.d.ts.map +1 -0
- package/dist/services/easytier-manager.js +331 -0
- package/dist/services/easytier-manager.test.d.ts +5 -0
- package/dist/services/easytier-manager.test.d.ts.map +1 -0
- package/dist/services/easytier-manager.test.js +98 -0
- package/dist/services/instance-init-service.d.ts +35 -0
- package/dist/services/instance-init-service.d.ts.map +1 -0
- package/dist/services/instance-init-service.js +190 -0
- package/dist/services/instance-service.d.ts +88 -0
- package/dist/services/instance-service.d.ts.map +1 -0
- package/dist/services/instance-service.js +236 -0
- package/dist/services/instance-state.d.ts +36 -0
- package/dist/services/instance-state.d.ts.map +1 -0
- package/dist/services/instance-state.js +79 -0
- package/dist/services/instance-state.test.d.ts +2 -0
- package/dist/services/instance-state.test.d.ts.map +1 -0
- package/dist/services/instance-state.test.js +213 -0
- package/dist/services/memory-service.d.ts +195 -0
- package/dist/services/memory-service.d.ts.map +1 -0
- package/dist/services/memory-service.js +650 -0
- package/dist/services/orphan-monitor.d.ts +94 -0
- package/dist/services/orphan-monitor.d.ts.map +1 -0
- package/dist/services/orphan-monitor.js +321 -0
- package/dist/services/process-detector.d.ts +175 -0
- package/dist/services/process-detector.d.ts.map +1 -0
- package/dist/services/process-detector.js +992 -0
- package/dist/services/process-registry.d.ts +208 -0
- package/dist/services/process-registry.d.ts.map +1 -0
- package/dist/services/process-registry.js +354 -0
- package/dist/services/session-lookup.d.ts +20 -0
- package/dist/services/session-lookup.d.ts.map +1 -0
- package/dist/services/session-lookup.js +43 -0
- package/dist/services/session-output.d.ts +56 -0
- package/dist/services/session-output.d.ts.map +1 -0
- package/dist/services/session-output.js +122 -0
- package/dist/services/session-output.test.d.ts +5 -0
- package/dist/services/session-output.test.d.ts.map +1 -0
- package/dist/services/session-output.test.js +68 -0
- package/dist/services/terminal-persistence.d.ts +51 -0
- package/dist/services/terminal-persistence.d.ts.map +1 -0
- package/dist/services/terminal-persistence.js +125 -0
- package/dist/services/terminal-persistence.test.d.ts +5 -0
- package/dist/services/terminal-persistence.test.d.ts.map +1 -0
- package/dist/services/terminal-persistence.test.js +88 -0
- package/dist/services/tool-installer.d.ts +15 -0
- package/dist/services/tool-installer.d.ts.map +1 -0
- package/dist/services/tool-installer.js +297 -0
- package/dist/services/tool-installer.test.d.ts +2 -0
- package/dist/services/tool-installer.test.d.ts.map +1 -0
- package/dist/services/tool-installer.test.js +102 -0
- package/dist/services/user-api-key-service.d.ts +28 -0
- package/dist/services/user-api-key-service.d.ts.map +1 -0
- package/dist/services/user-api-key-service.js +75 -0
- package/dist/services/workspace-files.d.ts +85 -0
- package/dist/services/workspace-files.d.ts.map +1 -0
- package/dist/services/workspace-files.js +224 -0
- package/dist/services/workspace-files.test.d.ts +2 -0
- package/dist/services/workspace-files.test.d.ts.map +1 -0
- package/dist/services/workspace-files.test.js +117 -0
- package/dist/types.d.ts +233 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +1 -0
- package/dist/utils/file-utils.d.ts +13 -0
- package/dist/utils/file-utils.d.ts.map +1 -0
- package/dist/utils/file-utils.js +140 -0
- package/dist/utils/file-utils.test.d.ts +2 -0
- package/dist/utils/file-utils.test.d.ts.map +1 -0
- package/dist/utils/file-utils.test.js +201 -0
- package/dist/utils/logger.d.ts +39 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +110 -0
- package/dist/utils/logger.test.d.ts +2 -0
- package/dist/utils/logger.test.d.ts.map +1 -0
- package/dist/utils/logger.test.js +93 -0
- package/dist/utils/mcp-utils.d.ts +73 -0
- package/dist/utils/mcp-utils.d.ts.map +1 -0
- package/dist/utils/mcp-utils.js +165 -0
- package/dist/utils/path-utils.d.ts +24 -0
- package/dist/utils/path-utils.d.ts.map +1 -0
- package/dist/utils/path-utils.js +44 -0
- package/dist/utils/validation.d.ts +23 -0
- package/dist/utils/validation.d.ts.map +1 -0
- package/dist/utils/validation.js +53 -0
- package/dist/utils/validation.test.d.ts +2 -0
- package/dist/utils/validation.test.d.ts.map +1 -0
- package/dist/utils/validation.test.js +88 -0
- package/dist/utils/yaml-utils.d.ts +73 -0
- package/dist/utils/yaml-utils.d.ts.map +1 -0
- package/dist/utils/yaml-utils.js +309 -0
- package/dist/utils/yaml-utils.test.d.ts +2 -0
- package/dist/utils/yaml-utils.test.d.ts.map +1 -0
- package/dist/utils/yaml-utils.test.js +363 -0
- package/package/aws-client-agent-mcp/README.md +288 -0
- package/package/aws-client-agent-mcp/dist/activity-reporter.d.ts +150 -0
- package/package/aws-client-agent-mcp/dist/activity-reporter.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/activity-reporter.js +353 -0
- package/package/aws-client-agent-mcp/dist/activity-reporter.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/activity-reporter.test.d.ts +2 -0
- package/package/aws-client-agent-mcp/dist/activity-reporter.test.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/activity-reporter.test.js +75 -0
- package/package/aws-client-agent-mcp/dist/activity-reporter.test.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/activity-types.d.ts +96 -0
- package/package/aws-client-agent-mcp/dist/activity-types.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/activity-types.js +141 -0
- package/package/aws-client-agent-mcp/dist/activity-types.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/agent-client.d.ts +165 -0
- package/package/aws-client-agent-mcp/dist/agent-client.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/agent-client.js +588 -0
- package/package/aws-client-agent-mcp/dist/agent-client.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/agent-client.test.d.ts +2 -0
- package/package/aws-client-agent-mcp/dist/agent-client.test.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/agent-client.test.js +534 -0
- package/package/aws-client-agent-mcp/dist/agent-client.test.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/config.d.ts +21 -0
- package/package/aws-client-agent-mcp/dist/config.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/config.js +67 -0
- package/package/aws-client-agent-mcp/dist/config.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/config.test.d.ts +2 -0
- package/package/aws-client-agent-mcp/dist/config.test.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/config.test.js +139 -0
- package/package/aws-client-agent-mcp/dist/config.test.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/constants.d.ts +15 -0
- package/package/aws-client-agent-mcp/dist/constants.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/constants.js +19 -0
- package/package/aws-client-agent-mcp/dist/constants.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/http-client.d.ts +27 -0
- package/package/aws-client-agent-mcp/dist/http-client.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/http-client.js +65 -0
- package/package/aws-client-agent-mcp/dist/http-client.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/http-client.test.d.ts +2 -0
- package/package/aws-client-agent-mcp/dist/http-client.test.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/http-client.test.js +228 -0
- package/package/aws-client-agent-mcp/dist/http-client.test.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/index.d.ts +14 -0
- package/package/aws-client-agent-mcp/dist/index.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/index.js +30 -0
- package/package/aws-client-agent-mcp/dist/index.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/logger.d.ts +7 -0
- package/package/aws-client-agent-mcp/dist/logger.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/logger.js +19 -0
- package/package/aws-client-agent-mcp/dist/logger.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/mcp-server.d.ts +77 -0
- package/package/aws-client-agent-mcp/dist/mcp-server.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/mcp-server.js +427 -0
- package/package/aws-client-agent-mcp/dist/mcp-server.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/mcp-server.test.d.ts +2 -0
- package/package/aws-client-agent-mcp/dist/mcp-server.test.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/mcp-server.test.js +624 -0
- package/package/aws-client-agent-mcp/dist/mcp-server.test.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/mcp-tools.d.ts +78 -0
- package/package/aws-client-agent-mcp/dist/mcp-tools.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/mcp-tools.js +420 -0
- package/package/aws-client-agent-mcp/dist/mcp-tools.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/memory-store.d.ts +61 -0
- package/package/aws-client-agent-mcp/dist/memory-store.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/memory-store.js +268 -0
- package/package/aws-client-agent-mcp/dist/memory-store.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/memory-store.test.d.ts +2 -0
- package/package/aws-client-agent-mcp/dist/memory-store.test.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/memory-store.test.js +164 -0
- package/package/aws-client-agent-mcp/dist/memory-store.test.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/message-buffer.d.ts +74 -0
- package/package/aws-client-agent-mcp/dist/message-buffer.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/message-buffer.js +159 -0
- package/package/aws-client-agent-mcp/dist/message-buffer.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/message-buffer.test.d.ts +2 -0
- package/package/aws-client-agent-mcp/dist/message-buffer.test.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/message-buffer.test.js +44 -0
- package/package/aws-client-agent-mcp/dist/message-buffer.test.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/messageContent.d.ts +53 -0
- package/package/aws-client-agent-mcp/dist/messageContent.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/messageContent.js +125 -0
- package/package/aws-client-agent-mcp/dist/messageContent.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/orchestration-tools.d.ts +19 -0
- package/package/aws-client-agent-mcp/dist/orchestration-tools.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/orchestration-tools.js +317 -0
- package/package/aws-client-agent-mcp/dist/orchestration-tools.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/status-reporter.d.ts +66 -0
- package/package/aws-client-agent-mcp/dist/status-reporter.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/status-reporter.js +220 -0
- package/package/aws-client-agent-mcp/dist/status-reporter.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/status-reporter.test.d.ts +2 -0
- package/package/aws-client-agent-mcp/dist/status-reporter.test.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/status-reporter.test.js +45 -0
- package/package/aws-client-agent-mcp/dist/status-reporter.test.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/types.d.ts +286 -0
- package/package/aws-client-agent-mcp/dist/types.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/types.js +9 -0
- package/package/aws-client-agent-mcp/dist/types.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/user-config-reader.d.ts +63 -0
- package/package/aws-client-agent-mcp/dist/user-config-reader.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/user-config-reader.js +161 -0
- package/package/aws-client-agent-mcp/dist/user-config-reader.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/websocket-client.d.ts +94 -0
- package/package/aws-client-agent-mcp/dist/websocket-client.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/websocket-client.js +316 -0
- package/package/aws-client-agent-mcp/dist/websocket-client.js.map +1 -0
- package/package/aws-client-agent-mcp/dist/websocket-client.test.d.ts +2 -0
- package/package/aws-client-agent-mcp/dist/websocket-client.test.d.ts.map +1 -0
- package/package/aws-client-agent-mcp/dist/websocket-client.test.js +191 -0
- package/package/aws-client-agent-mcp/dist/websocket-client.test.js.map +1 -0
- package/package/aws-client-agent-mcp/package.json +51 -0
- package/package/cc-switch-sdk/README.md +541 -0
- package/package/cc-switch-sdk/dist/adapters/common.d.ts +38 -0
- package/package/cc-switch-sdk/dist/adapters/common.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/adapters/common.js +47 -0
- package/package/cc-switch-sdk/dist/adapters/index.d.ts +5 -0
- package/package/cc-switch-sdk/dist/adapters/index.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/adapters/index.js +28 -0
- package/package/cc-switch-sdk/dist/adapters/mcp-claude.d.ts +10 -0
- package/package/cc-switch-sdk/dist/adapters/mcp-claude.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/adapters/mcp-claude.js +39 -0
- package/package/cc-switch-sdk/dist/adapters/mcp-claudecode.d.ts +10 -0
- package/package/cc-switch-sdk/dist/adapters/mcp-claudecode.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/adapters/mcp-claudecode.js +40 -0
- package/package/cc-switch-sdk/dist/adapters/mcp-opencode.d.ts +18 -0
- package/package/cc-switch-sdk/dist/adapters/mcp-opencode.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/adapters/mcp-opencode.js +63 -0
- package/package/cc-switch-sdk/dist/adapters/mcp-opencode.test.d.ts +2 -0
- package/package/cc-switch-sdk/dist/adapters/mcp-opencode.test.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/adapters/mcp-opencode.test.js +86 -0
- package/package/cc-switch-sdk/dist/adapters/mcp-placeholder.d.ts +9 -0
- package/package/cc-switch-sdk/dist/adapters/mcp-placeholder.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/adapters/mcp-placeholder.js +14 -0
- package/package/cc-switch-sdk/dist/adapters/skill-claude.d.ts +10 -0
- package/package/cc-switch-sdk/dist/adapters/skill-claude.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/adapters/skill-claude.js +51 -0
- package/package/cc-switch-sdk/dist/adapters/skill-claudecode.d.ts +10 -0
- package/package/cc-switch-sdk/dist/adapters/skill-claudecode.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/adapters/skill-claudecode.js +51 -0
- package/package/cc-switch-sdk/dist/adapters/skill-opencode.d.ts +10 -0
- package/package/cc-switch-sdk/dist/adapters/skill-opencode.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/adapters/skill-opencode.js +51 -0
- package/package/cc-switch-sdk/dist/adapters/skill-placeholder.d.ts +9 -0
- package/package/cc-switch-sdk/dist/adapters/skill-placeholder.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/adapters/skill-placeholder.js +14 -0
- package/package/cc-switch-sdk/dist/constants.d.ts +9 -0
- package/package/cc-switch-sdk/dist/constants.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/constants.js +54 -0
- package/package/cc-switch-sdk/dist/errors.d.ts +6 -0
- package/package/cc-switch-sdk/dist/errors.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/errors.js +8 -0
- package/package/cc-switch-sdk/dist/index.d.ts +11 -0
- package/package/cc-switch-sdk/dist/index.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/index.js +9 -0
- package/package/cc-switch-sdk/dist/schemas.d.ts +8 -0
- package/package/cc-switch-sdk/dist/schemas.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/schemas.js +37 -0
- package/package/cc-switch-sdk/dist/sdk.d.ts +91 -0
- package/package/cc-switch-sdk/dist/sdk.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/sdk.js +427 -0
- package/package/cc-switch-sdk/dist/services/ai-config-service.d.ts +75 -0
- package/package/cc-switch-sdk/dist/services/ai-config-service.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/services/ai-config-service.js +280 -0
- package/package/cc-switch-sdk/dist/services/instance-service.d.ts +78 -0
- package/package/cc-switch-sdk/dist/services/instance-service.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/services/instance-service.js +180 -0
- package/package/cc-switch-sdk/dist/services/mcp-model.d.ts +17 -0
- package/package/cc-switch-sdk/dist/services/mcp-model.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/services/mcp-model.js +34 -0
- package/package/cc-switch-sdk/dist/services/mcp-service.d.ts +18 -0
- package/package/cc-switch-sdk/dist/services/mcp-service.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/services/mcp-service.js +9 -0
- package/package/cc-switch-sdk/dist/services/skill-model.d.ts +17 -0
- package/package/cc-switch-sdk/dist/services/skill-model.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/services/skill-model.js +38 -0
- package/package/cc-switch-sdk/dist/services/skill-service.d.ts +17 -0
- package/package/cc-switch-sdk/dist/services/skill-service.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/services/skill-service.js +9 -0
- package/package/cc-switch-sdk/dist/state.d.ts +4 -0
- package/package/cc-switch-sdk/dist/state.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/state.js +19 -0
- package/package/cc-switch-sdk/dist/types.d.ts +75 -0
- package/package/cc-switch-sdk/dist/types.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/types.js +1 -0
- package/package/cc-switch-sdk/dist/utils/fs.d.ts +10 -0
- package/package/cc-switch-sdk/dist/utils/fs.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/utils/fs.js +91 -0
- package/package/cc-switch-sdk/dist/utils/id.d.ts +4 -0
- package/package/cc-switch-sdk/dist/utils/id.d.ts.map +1 -0
- package/package/cc-switch-sdk/dist/utils/id.js +12 -0
- package/package/cc-switch-sdk/package.json +31 -0
- package/package.json +73 -0
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { ClaudeMcpAdapter } from "./mcp-claude.js";
|
|
2
|
+
import { ClaudecodeMcpAdapter } from "./mcp-claudecode.js";
|
|
3
|
+
import { OpenCodeMcpAdapter } from "./mcp-opencode.js";
|
|
4
|
+
import { PlaceholderMcpAdapter } from "./mcp-placeholder.js";
|
|
5
|
+
import { ClaudeSkillAdapter } from "./skill-claude.js";
|
|
6
|
+
import { ClaudecodeSkillAdapter } from "./skill-claudecode.js";
|
|
7
|
+
import { OpenCodeSkillAdapter } from "./skill-opencode.js";
|
|
8
|
+
import { PlaceholderSkillAdapter } from "./skill-placeholder.js";
|
|
9
|
+
export function createMcpAdapters(paths) {
|
|
10
|
+
return {
|
|
11
|
+
claude: new ClaudeMcpAdapter(paths.claudeConfigFile),
|
|
12
|
+
claudecode: new ClaudecodeMcpAdapter(paths.claudecodeConfigFile),
|
|
13
|
+
opencode: new OpenCodeMcpAdapter(paths.opencodeConfigFile),
|
|
14
|
+
codex: new PlaceholderMcpAdapter("codex"),
|
|
15
|
+
gemini: new PlaceholderMcpAdapter("gemini"),
|
|
16
|
+
openclaw: new PlaceholderMcpAdapter("openclaw"),
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
export function createSkillAdapters(paths) {
|
|
20
|
+
return {
|
|
21
|
+
claude: new ClaudeSkillAdapter(paths.claudeSkillsDir),
|
|
22
|
+
claudecode: new ClaudecodeSkillAdapter(paths.claudecodeSkillsDir),
|
|
23
|
+
opencode: new OpenCodeSkillAdapter(paths.opencodeSkillsDir),
|
|
24
|
+
codex: new PlaceholderSkillAdapter("codex"),
|
|
25
|
+
gemini: new PlaceholderSkillAdapter("gemini"),
|
|
26
|
+
openclaw: new PlaceholderSkillAdapter("openclaw"),
|
|
27
|
+
};
|
|
28
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { IMcpAdapter, McpServer } from "../types.js";
|
|
2
|
+
export declare class ClaudeMcpAdapter implements IMcpAdapter {
|
|
3
|
+
private readonly configPath;
|
|
4
|
+
readonly appId: "claude";
|
|
5
|
+
constructor(configPath: string);
|
|
6
|
+
importServers(): Promise<McpServer[]>;
|
|
7
|
+
syncServer(server: McpServer): Promise<void>;
|
|
8
|
+
removeServer(server: McpServer): Promise<void>;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=mcp-claude.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mcp-claude.d.ts","sourceRoot":"","sources":["../../src/adapters/mcp-claude.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAK1D,qBAAa,gBAAiB,YAAW,WAAW;IAGtC,OAAO,CAAC,QAAQ,CAAC,UAAU;IAFvC,SAAgB,KAAK,EAAG,QAAQ,CAAU;gBAEb,UAAU,EAAE,MAAM;IAEzC,aAAa,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;IAmBrC,UAAU,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAO5C,YAAY,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;CASrD"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { createId } from "../utils/id.js";
|
|
2
|
+
import { readJsonFile, writeJsonFile } from "../utils/fs.js";
|
|
3
|
+
export class ClaudeMcpAdapter {
|
|
4
|
+
constructor(configPath) {
|
|
5
|
+
this.configPath = configPath;
|
|
6
|
+
this.appId = "claude";
|
|
7
|
+
}
|
|
8
|
+
async importServers() {
|
|
9
|
+
const config = await readJsonFile(this.configPath, {});
|
|
10
|
+
const entries = Object.entries(config.mcpServers ?? {});
|
|
11
|
+
return entries.map(([name, server]) => ({
|
|
12
|
+
id: createId("mcp"),
|
|
13
|
+
name,
|
|
14
|
+
server,
|
|
15
|
+
apps: {
|
|
16
|
+
claude: true,
|
|
17
|
+
claudecode: false,
|
|
18
|
+
codex: false,
|
|
19
|
+
gemini: false,
|
|
20
|
+
opencode: false,
|
|
21
|
+
openclaw: false,
|
|
22
|
+
},
|
|
23
|
+
}));
|
|
24
|
+
}
|
|
25
|
+
async syncServer(server) {
|
|
26
|
+
const config = await readJsonFile(this.configPath, {});
|
|
27
|
+
config.mcpServers = config.mcpServers ?? {};
|
|
28
|
+
config.mcpServers[server.name] = server.server;
|
|
29
|
+
await writeJsonFile(this.configPath, config);
|
|
30
|
+
}
|
|
31
|
+
async removeServer(server) {
|
|
32
|
+
const config = await readJsonFile(this.configPath, {});
|
|
33
|
+
if (!config.mcpServers) {
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
delete config.mcpServers[server.name];
|
|
37
|
+
await writeJsonFile(this.configPath, config);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { IMcpAdapter, McpServer } from "../types.js";
|
|
2
|
+
export declare class ClaudecodeMcpAdapter implements IMcpAdapter {
|
|
3
|
+
private readonly configPath;
|
|
4
|
+
readonly appId: "claudecode";
|
|
5
|
+
constructor(configPath: string);
|
|
6
|
+
importServers(): Promise<McpServer[]>;
|
|
7
|
+
syncServer(server: McpServer): Promise<void>;
|
|
8
|
+
removeServer(server: McpServer): Promise<void>;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=mcp-claudecode.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mcp-claudecode.d.ts","sourceRoot":"","sources":["../../src/adapters/mcp-claudecode.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAM1D,qBAAa,oBAAqB,YAAW,WAAW;IAG1C,OAAO,CAAC,QAAQ,CAAC,UAAU;IAFvC,SAAgB,KAAK,EAAG,YAAY,CAAU;gBAEjB,UAAU,EAAE,MAAM;IAEzC,aAAa,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;IAmBrC,UAAU,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAO5C,YAAY,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;CASrD"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { createId } from "../utils/id.js";
|
|
2
|
+
import { readJsonFile, writeJsonFile } from "../utils/fs.js";
|
|
3
|
+
import { toMcpSpecFromClaudecode, toClaudecodeServer } from "./common.js";
|
|
4
|
+
export class ClaudecodeMcpAdapter {
|
|
5
|
+
constructor(configPath) {
|
|
6
|
+
this.configPath = configPath;
|
|
7
|
+
this.appId = "claudecode";
|
|
8
|
+
}
|
|
9
|
+
async importServers() {
|
|
10
|
+
const config = await readJsonFile(this.configPath, {});
|
|
11
|
+
const entries = Object.entries(config.mcpServers ?? {});
|
|
12
|
+
return entries.map(([name, server]) => ({
|
|
13
|
+
id: createId("mcp"),
|
|
14
|
+
name,
|
|
15
|
+
server: toMcpSpecFromClaudecode(server),
|
|
16
|
+
apps: {
|
|
17
|
+
claude: false,
|
|
18
|
+
claudecode: true,
|
|
19
|
+
codex: false,
|
|
20
|
+
gemini: false,
|
|
21
|
+
opencode: false,
|
|
22
|
+
openclaw: false,
|
|
23
|
+
},
|
|
24
|
+
}));
|
|
25
|
+
}
|
|
26
|
+
async syncServer(server) {
|
|
27
|
+
const config = await readJsonFile(this.configPath, {});
|
|
28
|
+
config.mcpServers = config.mcpServers ?? {};
|
|
29
|
+
config.mcpServers[server.name] = toClaudecodeServer(server.server);
|
|
30
|
+
await writeJsonFile(this.configPath, config);
|
|
31
|
+
}
|
|
32
|
+
async removeServer(server) {
|
|
33
|
+
const config = await readJsonFile(this.configPath, {});
|
|
34
|
+
if (!config.mcpServers) {
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
delete config.mcpServers[server.name];
|
|
38
|
+
await writeJsonFile(this.configPath, config);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { IMcpAdapter, McpServer } from "../types.js";
|
|
2
|
+
export declare class OpenCodeMcpAdapter implements IMcpAdapter {
|
|
3
|
+
private readonly configPath;
|
|
4
|
+
readonly appId: "opencode";
|
|
5
|
+
constructor(configPath: string);
|
|
6
|
+
/**
|
|
7
|
+
* 读取 OpenCode MCP 映射,优先使用合法的 mcp 字段,兼容历史错误写入的 mcpServers。
|
|
8
|
+
*/
|
|
9
|
+
private getMcpMap;
|
|
10
|
+
/**
|
|
11
|
+
* 将 MCP 服务器写回 OpenCode 配置,只保留合法的 mcp 字段并清理错误的 mcpServers。
|
|
12
|
+
*/
|
|
13
|
+
private saveMcpMap;
|
|
14
|
+
importServers(): Promise<McpServer[]>;
|
|
15
|
+
syncServer(server: McpServer): Promise<void>;
|
|
16
|
+
removeServer(server: McpServer): Promise<void>;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=mcp-opencode.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mcp-opencode.d.ts","sourceRoot":"","sources":["../../src/adapters/mcp-opencode.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAM1D,qBAAa,kBAAmB,YAAW,WAAW;IAGxC,OAAO,CAAC,QAAQ,CAAC,UAAU;IAFvC,SAAgB,KAAK,EAAG,UAAU,CAAU;gBAEf,UAAU,EAAE,MAAM;IAE/C;;OAEG;IACH,OAAO,CAAC,SAAS;IAUjB;;OAEG;YACW,UAAU;IAQlB,aAAa,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;IAmBrC,UAAU,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAO5C,YAAY,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;CAUrD"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { createId } from "../utils/id.js";
|
|
2
|
+
import { readJsonFile, writeJsonFile } from "../utils/fs.js";
|
|
3
|
+
import { toMcpSpecFromOpenCode, toOpenCodeServer } from "./common.js";
|
|
4
|
+
export class OpenCodeMcpAdapter {
|
|
5
|
+
constructor(configPath) {
|
|
6
|
+
this.configPath = configPath;
|
|
7
|
+
this.appId = "opencode";
|
|
8
|
+
}
|
|
9
|
+
/**
|
|
10
|
+
* 读取 OpenCode MCP 映射,优先使用合法的 mcp 字段,兼容历史错误写入的 mcpServers。
|
|
11
|
+
*/
|
|
12
|
+
getMcpMap(config) {
|
|
13
|
+
if (config.mcp && typeof config.mcp === "object") {
|
|
14
|
+
return config.mcp;
|
|
15
|
+
}
|
|
16
|
+
if (config.mcpServers && typeof config.mcpServers === "object") {
|
|
17
|
+
return config.mcpServers;
|
|
18
|
+
}
|
|
19
|
+
return {};
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* 将 MCP 服务器写回 OpenCode 配置,只保留合法的 mcp 字段并清理错误的 mcpServers。
|
|
23
|
+
*/
|
|
24
|
+
async saveMcpMap(config, mcp) {
|
|
25
|
+
config.mcp = mcp;
|
|
26
|
+
if ("mcpServers" in config) {
|
|
27
|
+
delete config.mcpServers;
|
|
28
|
+
}
|
|
29
|
+
await writeJsonFile(this.configPath, config);
|
|
30
|
+
}
|
|
31
|
+
async importServers() {
|
|
32
|
+
const config = await readJsonFile(this.configPath, {});
|
|
33
|
+
const entries = Object.entries(this.getMcpMap(config));
|
|
34
|
+
return entries.map(([name, server]) => ({
|
|
35
|
+
id: createId("mcp"),
|
|
36
|
+
name,
|
|
37
|
+
server: toMcpSpecFromOpenCode(server),
|
|
38
|
+
apps: {
|
|
39
|
+
claude: false,
|
|
40
|
+
claudecode: false,
|
|
41
|
+
codex: false,
|
|
42
|
+
gemini: false,
|
|
43
|
+
opencode: true,
|
|
44
|
+
openclaw: false,
|
|
45
|
+
},
|
|
46
|
+
}));
|
|
47
|
+
}
|
|
48
|
+
async syncServer(server) {
|
|
49
|
+
const config = await readJsonFile(this.configPath, {});
|
|
50
|
+
const mcp = this.getMcpMap(config);
|
|
51
|
+
mcp[server.name] = toOpenCodeServer(server.server);
|
|
52
|
+
await this.saveMcpMap(config, mcp);
|
|
53
|
+
}
|
|
54
|
+
async removeServer(server) {
|
|
55
|
+
const config = await readJsonFile(this.configPath, {});
|
|
56
|
+
const mcp = this.getMcpMap(config);
|
|
57
|
+
if (!mcp[server.name]) {
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
60
|
+
delete mcp[server.name];
|
|
61
|
+
await this.saveMcpMap(config, mcp);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mcp-opencode.test.d.ts","sourceRoot":"","sources":["../../src/adapters/mcp-opencode.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import assert from "node:assert/strict";
|
|
2
|
+
import { describe, it } from "node:test";
|
|
3
|
+
import os from "node:os";
|
|
4
|
+
import path from "node:path";
|
|
5
|
+
import { promises as fs } from "node:fs";
|
|
6
|
+
import { OpenCodeMcpAdapter } from "./mcp-opencode.js";
|
|
7
|
+
/**
|
|
8
|
+
* 创建隔离测试目录,避免污染真实用户配置。
|
|
9
|
+
*/
|
|
10
|
+
async function createTempConfigPath() {
|
|
11
|
+
const tempDir = await fs.mkdtemp(path.join(os.tmpdir(), "opencode-mcp-adapter-"));
|
|
12
|
+
return path.join(tempDir, "opencode.json");
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* 读取测试配置文件内容,便于断言 OpenCode 实际写盘结构。
|
|
16
|
+
*/
|
|
17
|
+
async function readConfig(filePath) {
|
|
18
|
+
const content = await fs.readFile(filePath, "utf-8");
|
|
19
|
+
return JSON.parse(content);
|
|
20
|
+
}
|
|
21
|
+
function buildServer(name) {
|
|
22
|
+
return {
|
|
23
|
+
id: `mcp-${name}`,
|
|
24
|
+
name,
|
|
25
|
+
server: {
|
|
26
|
+
type: "stdio",
|
|
27
|
+
command: "node",
|
|
28
|
+
args: ["server.js"],
|
|
29
|
+
env: { DEMO: "1" },
|
|
30
|
+
},
|
|
31
|
+
apps: {
|
|
32
|
+
claude: false,
|
|
33
|
+
claudecode: false,
|
|
34
|
+
codex: false,
|
|
35
|
+
gemini: false,
|
|
36
|
+
opencode: true,
|
|
37
|
+
openclaw: false,
|
|
38
|
+
},
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
describe("OpenCodeMcpAdapter", () => {
|
|
42
|
+
it("writes OpenCode MCP servers to the mcp key and removes legacy mcpServers", async () => {
|
|
43
|
+
const configPath = await createTempConfigPath();
|
|
44
|
+
await fs.writeFile(configPath, JSON.stringify({
|
|
45
|
+
$schema: "https://opencode.ai/config.json",
|
|
46
|
+
mcpServers: {
|
|
47
|
+
legacy: {
|
|
48
|
+
type: "local",
|
|
49
|
+
command: ["node", "legacy.js"],
|
|
50
|
+
enabled: true,
|
|
51
|
+
},
|
|
52
|
+
},
|
|
53
|
+
}, null, 2), "utf-8");
|
|
54
|
+
const adapter = new OpenCodeMcpAdapter(configPath);
|
|
55
|
+
await adapter.syncServer(buildServer("aws-mcp"));
|
|
56
|
+
const saved = await readConfig(configPath);
|
|
57
|
+
assert.equal("mcpServers" in saved, false);
|
|
58
|
+
assert.ok(saved.mcp);
|
|
59
|
+
assert.deepEqual(saved.mcp["aws-mcp"], {
|
|
60
|
+
type: "local",
|
|
61
|
+
command: ["node", "server.js"],
|
|
62
|
+
environment: { DEMO: "1" },
|
|
63
|
+
enabled: true,
|
|
64
|
+
});
|
|
65
|
+
});
|
|
66
|
+
it("imports existing OpenCode MCP servers from the mcp key", async () => {
|
|
67
|
+
const configPath = await createTempConfigPath();
|
|
68
|
+
await fs.writeFile(configPath, JSON.stringify({
|
|
69
|
+
mcp: {
|
|
70
|
+
aws: {
|
|
71
|
+
type: "local",
|
|
72
|
+
command: ["node", "index.js"],
|
|
73
|
+
environment: { AWS_SERVER_URL: "ws://localhost:8080/ws/agent" },
|
|
74
|
+
enabled: true,
|
|
75
|
+
},
|
|
76
|
+
},
|
|
77
|
+
}, null, 2), "utf-8");
|
|
78
|
+
const adapter = new OpenCodeMcpAdapter(configPath);
|
|
79
|
+
const imported = await adapter.importServers();
|
|
80
|
+
assert.equal(imported.length, 1);
|
|
81
|
+
assert.equal(imported[0]?.name, "aws");
|
|
82
|
+
assert.equal(imported[0]?.server.command, "node");
|
|
83
|
+
assert.deepEqual(imported[0]?.server.args, ["index.js"]);
|
|
84
|
+
assert.deepEqual(imported[0]?.server.env, { AWS_SERVER_URL: "ws://localhost:8080/ws/agent" });
|
|
85
|
+
});
|
|
86
|
+
});
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { AppId, IMcpAdapter, McpServer } from "../types.js";
|
|
2
|
+
export declare class PlaceholderMcpAdapter implements IMcpAdapter {
|
|
3
|
+
readonly appId: AppId;
|
|
4
|
+
constructor(appId: AppId);
|
|
5
|
+
importServers(): Promise<McpServer[]>;
|
|
6
|
+
syncServer(): Promise<void>;
|
|
7
|
+
removeServer(): Promise<void>;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=mcp-placeholder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mcp-placeholder.d.ts","sourceRoot":"","sources":["../../src/adapters/mcp-placeholder.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAEjE,qBAAa,qBAAsB,YAAW,WAAW;aAC3B,KAAK,EAAE,KAAK;gBAAZ,KAAK,EAAE,KAAK;IAElC,aAAa,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;IAIrC,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAI3B,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC;CAGpC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { ISkillAdapter, InstalledSkill, SkillSyncMethod } from "../types.js";
|
|
2
|
+
export declare class ClaudeSkillAdapter implements ISkillAdapter {
|
|
3
|
+
private readonly skillsDir;
|
|
4
|
+
readonly appId: "claude";
|
|
5
|
+
constructor(skillsDir: string);
|
|
6
|
+
importSkills(): Promise<Array<Pick<InstalledSkill, "id" | "name" | "directory" | "description">>>;
|
|
7
|
+
syncSkill(skill: InstalledSkill, sourceDir: string, method: SkillSyncMethod): Promise<void>;
|
|
8
|
+
removeSkill(skill: InstalledSkill): Promise<void>;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=skill-claude.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"skill-claude.d.ts","sourceRoot":"","sources":["../../src/adapters/skill-claude.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AA6BlF,qBAAa,kBAAmB,YAAW,aAAa;IAG1C,OAAO,CAAC,QAAQ,CAAC,SAAS;IAFtC,SAAgB,KAAK,EAAG,QAAQ,CAAU;gBAEb,SAAS,EAAE,MAAM;IAExC,YAAY,IAAI,OAAO,CAC3B,KAAK,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,GAAG,MAAM,GAAG,WAAW,GAAG,aAAa,CAAC,CAAC,CACzE;IAgBK,SAAS,CACb,KAAK,EAAE,cAAc,EACrB,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,eAAe,GACtB,OAAO,CAAC,IAAI,CAAC;IAKV,WAAW,CAAC,KAAK,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC;CAIxD"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import fs from "node:fs/promises";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import { removeIfExists, copyDir, ensureDir } from "../utils/fs.js";
|
|
4
|
+
import { toNameFromPath } from "../utils/id.js";
|
|
5
|
+
async function materializeSkillDir(sourceDir, targetDir, method) {
|
|
6
|
+
await removeIfExists(targetDir);
|
|
7
|
+
await ensureDir(path.dirname(targetDir));
|
|
8
|
+
if (method === "copy") {
|
|
9
|
+
await copyDir(sourceDir, targetDir);
|
|
10
|
+
return;
|
|
11
|
+
}
|
|
12
|
+
if (method === "symlink") {
|
|
13
|
+
await fs.symlink(sourceDir, targetDir, "junction");
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
try {
|
|
17
|
+
await fs.symlink(sourceDir, targetDir, "junction");
|
|
18
|
+
}
|
|
19
|
+
catch {
|
|
20
|
+
await copyDir(sourceDir, targetDir);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
export class ClaudeSkillAdapter {
|
|
24
|
+
constructor(skillsDir) {
|
|
25
|
+
this.skillsDir = skillsDir;
|
|
26
|
+
this.appId = "claude";
|
|
27
|
+
}
|
|
28
|
+
async importSkills() {
|
|
29
|
+
await ensureDir(this.skillsDir);
|
|
30
|
+
const entries = await fs.readdir(this.skillsDir, { withFileTypes: true });
|
|
31
|
+
return entries
|
|
32
|
+
.filter((entry) => entry.isDirectory() || entry.isSymbolicLink())
|
|
33
|
+
.map((entry) => {
|
|
34
|
+
const directory = path.join(this.skillsDir, entry.name);
|
|
35
|
+
return {
|
|
36
|
+
id: `skill_import_${entry.name}`,
|
|
37
|
+
name: toNameFromPath(entry.name),
|
|
38
|
+
directory,
|
|
39
|
+
description: undefined,
|
|
40
|
+
};
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
async syncSkill(skill, sourceDir, method) {
|
|
44
|
+
const targetDir = path.join(this.skillsDir, skill.name);
|
|
45
|
+
await materializeSkillDir(sourceDir, targetDir, method);
|
|
46
|
+
}
|
|
47
|
+
async removeSkill(skill) {
|
|
48
|
+
const targetDir = path.join(this.skillsDir, skill.name);
|
|
49
|
+
await removeIfExists(targetDir);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { ISkillAdapter, InstalledSkill, SkillSyncMethod } from "../types.js";
|
|
2
|
+
export declare class ClaudecodeSkillAdapter implements ISkillAdapter {
|
|
3
|
+
private readonly skillsDir;
|
|
4
|
+
readonly appId: "claudecode";
|
|
5
|
+
constructor(skillsDir: string);
|
|
6
|
+
importSkills(): Promise<Array<Pick<InstalledSkill, "id" | "name" | "directory" | "description">>>;
|
|
7
|
+
syncSkill(skill: InstalledSkill, sourceDir: string, method: SkillSyncMethod): Promise<void>;
|
|
8
|
+
removeSkill(skill: InstalledSkill): Promise<void>;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=skill-claudecode.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"skill-claudecode.d.ts","sourceRoot":"","sources":["../../src/adapters/skill-claudecode.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AA6BlF,qBAAa,sBAAuB,YAAW,aAAa;IAG9C,OAAO,CAAC,QAAQ,CAAC,SAAS;IAFtC,SAAgB,KAAK,EAAG,YAAY,CAAU;gBAEjB,SAAS,EAAE,MAAM;IAExC,YAAY,IAAI,OAAO,CAC3B,KAAK,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,GAAG,MAAM,GAAG,WAAW,GAAG,aAAa,CAAC,CAAC,CACzE;IAgBK,SAAS,CACb,KAAK,EAAE,cAAc,EACrB,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,eAAe,GACtB,OAAO,CAAC,IAAI,CAAC;IAKV,WAAW,CAAC,KAAK,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC;CAIxD"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import fs from "node:fs/promises";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import { removeIfExists, copyDir, ensureDir } from "../utils/fs.js";
|
|
4
|
+
import { toNameFromPath } from "../utils/id.js";
|
|
5
|
+
async function materializeSkillDir(sourceDir, targetDir, method) {
|
|
6
|
+
await removeIfExists(targetDir);
|
|
7
|
+
await ensureDir(path.dirname(targetDir));
|
|
8
|
+
if (method === "copy") {
|
|
9
|
+
await copyDir(sourceDir, targetDir);
|
|
10
|
+
return;
|
|
11
|
+
}
|
|
12
|
+
if (method === "symlink") {
|
|
13
|
+
await fs.symlink(sourceDir, targetDir, "junction");
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
try {
|
|
17
|
+
await fs.symlink(sourceDir, targetDir, "junction");
|
|
18
|
+
}
|
|
19
|
+
catch {
|
|
20
|
+
await copyDir(sourceDir, targetDir);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
export class ClaudecodeSkillAdapter {
|
|
24
|
+
constructor(skillsDir) {
|
|
25
|
+
this.skillsDir = skillsDir;
|
|
26
|
+
this.appId = "claudecode";
|
|
27
|
+
}
|
|
28
|
+
async importSkills() {
|
|
29
|
+
await ensureDir(this.skillsDir);
|
|
30
|
+
const entries = await fs.readdir(this.skillsDir, { withFileTypes: true });
|
|
31
|
+
return entries
|
|
32
|
+
.filter((entry) => entry.isDirectory() || entry.isSymbolicLink())
|
|
33
|
+
.map((entry) => {
|
|
34
|
+
const directory = path.join(this.skillsDir, entry.name);
|
|
35
|
+
return {
|
|
36
|
+
id: `skill_import_${entry.name}`,
|
|
37
|
+
name: toNameFromPath(entry.name),
|
|
38
|
+
directory,
|
|
39
|
+
description: undefined,
|
|
40
|
+
};
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
async syncSkill(skill, sourceDir, method) {
|
|
44
|
+
const targetDir = path.join(this.skillsDir, skill.name);
|
|
45
|
+
await materializeSkillDir(sourceDir, targetDir, method);
|
|
46
|
+
}
|
|
47
|
+
async removeSkill(skill) {
|
|
48
|
+
const targetDir = path.join(this.skillsDir, skill.name);
|
|
49
|
+
await removeIfExists(targetDir);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { ISkillAdapter, InstalledSkill, SkillSyncMethod } from "../types.js";
|
|
2
|
+
export declare class OpenCodeSkillAdapter implements ISkillAdapter {
|
|
3
|
+
private readonly skillsDir;
|
|
4
|
+
readonly appId: "opencode";
|
|
5
|
+
constructor(skillsDir: string);
|
|
6
|
+
importSkills(): Promise<Array<Pick<InstalledSkill, "id" | "name" | "directory" | "description">>>;
|
|
7
|
+
syncSkill(skill: InstalledSkill, sourceDir: string, method: SkillSyncMethod): Promise<void>;
|
|
8
|
+
removeSkill(skill: InstalledSkill): Promise<void>;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=skill-opencode.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"skill-opencode.d.ts","sourceRoot":"","sources":["../../src/adapters/skill-opencode.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AA6BlF,qBAAa,oBAAqB,YAAW,aAAa;IAG5C,OAAO,CAAC,QAAQ,CAAC,SAAS;IAFtC,SAAgB,KAAK,EAAG,UAAU,CAAU;gBAEf,SAAS,EAAE,MAAM;IAExC,YAAY,IAAI,OAAO,CAC3B,KAAK,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,GAAG,MAAM,GAAG,WAAW,GAAG,aAAa,CAAC,CAAC,CACzE;IAgBK,SAAS,CACb,KAAK,EAAE,cAAc,EACrB,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,eAAe,GACtB,OAAO,CAAC,IAAI,CAAC;IAKV,WAAW,CAAC,KAAK,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC;CAIxD"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import fs from "node:fs/promises";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import { removeIfExists, copyDir, ensureDir } from "../utils/fs.js";
|
|
4
|
+
import { toNameFromPath } from "../utils/id.js";
|
|
5
|
+
async function materializeSkillDir(sourceDir, targetDir, method) {
|
|
6
|
+
await removeIfExists(targetDir);
|
|
7
|
+
await ensureDir(path.dirname(targetDir));
|
|
8
|
+
if (method === "copy") {
|
|
9
|
+
await copyDir(sourceDir, targetDir);
|
|
10
|
+
return;
|
|
11
|
+
}
|
|
12
|
+
if (method === "symlink") {
|
|
13
|
+
await fs.symlink(sourceDir, targetDir, "junction");
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
try {
|
|
17
|
+
await fs.symlink(sourceDir, targetDir, "junction");
|
|
18
|
+
}
|
|
19
|
+
catch {
|
|
20
|
+
await copyDir(sourceDir, targetDir);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
export class OpenCodeSkillAdapter {
|
|
24
|
+
constructor(skillsDir) {
|
|
25
|
+
this.skillsDir = skillsDir;
|
|
26
|
+
this.appId = "opencode";
|
|
27
|
+
}
|
|
28
|
+
async importSkills() {
|
|
29
|
+
await ensureDir(this.skillsDir);
|
|
30
|
+
const entries = await fs.readdir(this.skillsDir, { withFileTypes: true });
|
|
31
|
+
return entries
|
|
32
|
+
.filter((entry) => entry.isDirectory() || entry.isSymbolicLink())
|
|
33
|
+
.map((entry) => {
|
|
34
|
+
const directory = path.join(this.skillsDir, entry.name);
|
|
35
|
+
return {
|
|
36
|
+
id: `skill_import_${entry.name}`,
|
|
37
|
+
name: toNameFromPath(entry.name),
|
|
38
|
+
directory,
|
|
39
|
+
description: undefined,
|
|
40
|
+
};
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
async syncSkill(skill, sourceDir, method) {
|
|
44
|
+
const targetDir = path.join(this.skillsDir, skill.name);
|
|
45
|
+
await materializeSkillDir(sourceDir, targetDir, method);
|
|
46
|
+
}
|
|
47
|
+
async removeSkill(skill) {
|
|
48
|
+
const targetDir = path.join(this.skillsDir, skill.name);
|
|
49
|
+
await removeIfExists(targetDir);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { AppId, ISkillAdapter, InstalledSkill, SkillSyncMethod } from "../types.js";
|
|
2
|
+
export declare class PlaceholderSkillAdapter implements ISkillAdapter {
|
|
3
|
+
readonly appId: AppId;
|
|
4
|
+
constructor(appId: AppId);
|
|
5
|
+
importSkills(): Promise<Array<Pick<InstalledSkill, "id" | "name" | "directory" | "description">>>;
|
|
6
|
+
syncSkill(_skill: InstalledSkill, _sourceDir: string, _method: SkillSyncMethod): Promise<void>;
|
|
7
|
+
removeSkill(_skill: InstalledSkill): Promise<void>;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=skill-placeholder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"skill-placeholder.d.ts","sourceRoot":"","sources":["../../src/adapters/skill-placeholder.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,KAAK,EACL,aAAa,EACb,cAAc,EACd,eAAe,EAChB,MAAM,aAAa,CAAC;AAErB,qBAAa,uBAAwB,YAAW,aAAa;aAC/B,KAAK,EAAE,KAAK;gBAAZ,KAAK,EAAE,KAAK;IAElC,YAAY,IAAI,OAAO,CAC3B,KAAK,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,GAAG,MAAM,GAAG,WAAW,GAAG,aAAa,CAAC,CAAC,CACzE;IAIK,SAAS,CACb,MAAM,EAAE,cAAc,EACtB,UAAU,EAAE,MAAM,EAClB,OAAO,EAAE,eAAe,GACvB,OAAO,CAAC,IAAI,CAAC;IAIV,WAAW,CAAC,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC;CAGzD"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { AppFlags, AppId, SdkOptions, SdkPaths, SkillSyncMethod } from "./types.js";
|
|
2
|
+
export declare const ALL_APPS: AppId[];
|
|
3
|
+
export declare const DEFAULT_APP_FLAGS: AppFlags;
|
|
4
|
+
export declare function normalizeAppFlags(flags?: Partial<AppFlags>): AppFlags;
|
|
5
|
+
export declare function resolvePaths(options?: SdkOptions): {
|
|
6
|
+
paths: SdkPaths;
|
|
7
|
+
skillSyncMethod: SkillSyncMethod;
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=constants.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../src/constants.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,QAAQ,EACR,KAAK,EACL,UAAU,EACV,QAAQ,EACR,eAAe,EAChB,MAAM,YAAY,CAAC;AAEpB,eAAO,MAAM,QAAQ,EAAE,KAAK,EAO3B,CAAC;AAEF,eAAO,MAAM,iBAAiB,EAAE,QAO/B,CAAC;AAEF,wBAAgB,iBAAiB,CAAC,KAAK,CAAC,EAAE,OAAO,CAAC,QAAQ,CAAC,GAAG,QAAQ,CASrE;AAED,wBAAgB,YAAY,CAAC,OAAO,GAAE,UAAe,GAAG;IACtD,KAAK,EAAE,QAAQ,CAAC;IAChB,eAAe,EAAE,eAAe,CAAC;CAClC,CAkCA"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import path from "node:path";
|
|
2
|
+
import os from "node:os";
|
|
3
|
+
export const ALL_APPS = [
|
|
4
|
+
"claude",
|
|
5
|
+
"claudecode",
|
|
6
|
+
"codex",
|
|
7
|
+
"gemini",
|
|
8
|
+
"opencode",
|
|
9
|
+
"openclaw",
|
|
10
|
+
];
|
|
11
|
+
export const DEFAULT_APP_FLAGS = {
|
|
12
|
+
claude: false,
|
|
13
|
+
claudecode: false,
|
|
14
|
+
codex: false,
|
|
15
|
+
gemini: false,
|
|
16
|
+
opencode: false,
|
|
17
|
+
openclaw: false,
|
|
18
|
+
};
|
|
19
|
+
export function normalizeAppFlags(flags) {
|
|
20
|
+
return {
|
|
21
|
+
claude: Boolean(flags?.claude),
|
|
22
|
+
claudecode: Boolean(flags?.claudecode),
|
|
23
|
+
codex: Boolean(flags?.codex),
|
|
24
|
+
gemini: Boolean(flags?.gemini),
|
|
25
|
+
opencode: Boolean(flags?.opencode),
|
|
26
|
+
openclaw: Boolean(flags?.openclaw),
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
export function resolvePaths(options = {}) {
|
|
30
|
+
const rootDir = options.rootDir ?? path.join(os.homedir(), ".cc-switch-sdk-node");
|
|
31
|
+
const paths = {
|
|
32
|
+
stateFile: options.paths?.stateFile ?? path.join(rootDir, "state.json"),
|
|
33
|
+
backupDir: options.paths?.backupDir ?? path.join(rootDir, "backups"),
|
|
34
|
+
claudeConfigFile: options.paths?.claudeConfigFile ??
|
|
35
|
+
path.join(os.homedir(), ".claude.json"),
|
|
36
|
+
claudeSkillsDir: options.paths?.claudeSkillsDir ??
|
|
37
|
+
path.join(os.homedir(), ".claude", "skills"),
|
|
38
|
+
claudecodeConfigFile: options.paths?.claudecodeConfigFile ??
|
|
39
|
+
path.join(os.homedir(), ".claudecode", "opencode.json"),
|
|
40
|
+
claudecodeSkillsDir: options.paths?.claudecodeSkillsDir ??
|
|
41
|
+
path.join(os.homedir(), ".claudecode", "skills"),
|
|
42
|
+
codexConfigFile: options.paths?.codexConfigFile ??
|
|
43
|
+
path.join(os.homedir(), ".codex", "config.toml"),
|
|
44
|
+
opencodeConfigFile: options.paths?.opencodeConfigFile ??
|
|
45
|
+
path.join(os.homedir(), ".opencode", "config.json"),
|
|
46
|
+
opencodeSkillsDir: options.paths?.opencodeSkillsDir ??
|
|
47
|
+
path.join(os.homedir(), ".opencode", "skills"),
|
|
48
|
+
ssotSkillsDir: options.paths?.ssotSkillsDir ?? path.join(rootDir, "skills"),
|
|
49
|
+
};
|
|
50
|
+
return {
|
|
51
|
+
paths,
|
|
52
|
+
skillSyncMethod: options.skillSyncMethod ?? "auto",
|
|
53
|
+
};
|
|
54
|
+
}
|