jishushell 0.6.5 → 0.6.18
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/apps/anythingllm-container.yaml +15 -170
- package/apps/browserless-chromium-container.yaml +15 -10
- package/apps/filebrowser-container.yaml +14 -9
- package/apps/hermes-container.yaml +23 -2
- package/apps/jishu-kb-container.yaml +29 -161
- package/apps/ollama-binary.yaml +32 -28
- package/apps/ollama-cpu-container.yaml +5 -0
- package/apps/ollama-with-hollama-binary.yaml +33 -28
- package/apps/openclaw-binary.yaml +34 -10
- package/apps/openclaw-container.yaml +31 -7
- package/apps/openclaw-with-ollama-container.yaml +8 -2
- package/apps/openclaw-with-searxng-container.yaml +18 -6
- package/apps/searxng-container.yaml +11 -6
- package/apps/weknora-container.yaml +21 -21
- package/dependencies/jishushell-panel-0.6.18.tgz +0 -0
- package/dist/cli/app.js +244 -213
- package/dist/cli/app.js.map +1 -1
- package/dist/cli/backup.js +15 -12
- package/dist/cli/backup.js.map +1 -1
- package/dist/cli/core.d.ts +4 -3
- package/dist/cli/core.js +392 -227
- package/dist/cli/core.js.map +1 -1
- package/dist/cli/doctor.d.ts +1 -1
- package/dist/cli/doctor.js +17 -10
- package/dist/cli/doctor.js.map +1 -1
- package/dist/cli/job.js +62 -14
- package/dist/cli/job.js.map +1 -1
- package/dist/cli/llm.js +80 -11
- package/dist/cli/llm.js.map +1 -1
- package/dist/cli/managed-list.d.ts +1 -3
- package/dist/cli/managed-list.js +18 -16
- package/dist/cli/managed-list.js.map +1 -1
- package/dist/cli/migrate.d.ts +2 -0
- package/dist/cli/migrate.js +160 -0
- package/dist/cli/migrate.js.map +1 -0
- package/dist/cli.js +1 -0
- package/dist/cli.js.map +1 -1
- package/dist/config.d.ts +23 -19
- package/dist/config.js +60 -49
- package/dist/config.js.map +1 -1
- package/dist/control.d.ts +6 -6
- package/dist/control.js +31 -23
- package/dist/control.js.map +1 -1
- package/dist/core.d.ts +5 -5
- package/dist/core.js +5 -5
- package/dist/core.js.map +1 -1
- package/dist/install.d.ts +2 -2
- package/dist/install.js +18 -18
- package/dist/install.js.map +1 -1
- package/dist/routes/apps.d.ts +1 -1
- package/dist/routes/apps.js +101 -193
- package/dist/routes/apps.js.map +1 -1
- package/dist/routes/auth.js +1 -1
- package/dist/routes/auth.js.map +1 -1
- package/dist/routes/backup.js +1 -1
- package/dist/routes/backup.js.map +1 -1
- package/dist/routes/external-mounts.d.ts +1 -1
- package/dist/routes/external-mounts.js +1 -1
- package/dist/routes/external-mounts.js.map +1 -1
- package/dist/routes/file-mounts.d.ts +4 -3
- package/dist/routes/file-mounts.js +51 -30
- package/dist/routes/file-mounts.js.map +1 -1
- package/dist/routes/files-organize.d.ts +2 -2
- package/dist/routes/files-organize.js +5 -5
- package/dist/routes/files-organize.js.map +1 -1
- package/dist/routes/files.d.ts +1 -1
- package/dist/routes/files.js +1 -1
- package/dist/routes/files.js.map +1 -1
- package/dist/routes/instances.d.ts +10 -4
- package/dist/routes/instances.js +323 -541
- package/dist/routes/instances.js.map +1 -1
- package/dist/routes/integration-apps.d.ts +14 -0
- package/dist/routes/integration-apps.js +81 -0
- package/dist/routes/integration-apps.js.map +1 -0
- package/dist/routes/integrations.d.ts +9 -0
- package/dist/routes/integrations.js +12 -0
- package/dist/routes/integrations.js.map +1 -0
- package/dist/routes/llm-proxy.js +26 -3
- package/dist/routes/llm-proxy.js.map +1 -1
- package/dist/routes/setup.js +53 -38
- package/dist/routes/setup.js.map +1 -1
- package/dist/routes/system.js +108 -68
- package/dist/routes/system.js.map +1 -1
- package/dist/routes/webdav.d.ts +1 -1
- package/dist/routes/webdav.js +2 -2
- package/dist/routes/webdav.js.map +1 -1
- package/dist/server.js +315 -213
- package/dist/server.js.map +1 -1
- package/dist/services/app-common/app-compiler.js +186 -0
- package/dist/services/app-common/app-compiler.js.map +1 -0
- package/dist/services/app-common/app-shared.d.ts +15 -0
- package/dist/services/app-common/app-shared.js +64 -0
- package/dist/services/app-common/app-shared.js.map +1 -0
- package/dist/services/app-common/capability-service.d.ts +45 -0
- package/dist/services/app-common/capability-service.js +331 -0
- package/dist/services/app-common/capability-service.js.map +1 -0
- package/dist/services/app-common/catalog-service.d.ts +59 -0
- package/dist/services/app-common/catalog-service.js +308 -0
- package/dist/services/app-common/catalog-service.js.map +1 -0
- package/dist/services/app-common/create-pipeline.d.ts +26 -0
- package/dist/services/app-common/create-pipeline.js +298 -0
- package/dist/services/app-common/create-pipeline.js.map +1 -0
- package/dist/services/app-common/delete-service.d.ts +5 -0
- package/dist/services/app-common/delete-service.js +104 -0
- package/dist/services/app-common/delete-service.js.map +1 -0
- package/dist/services/app-common/execution-owner.d.ts +23 -0
- package/dist/services/app-common/execution-owner.js +124 -0
- package/dist/services/app-common/execution-owner.js.map +1 -0
- package/dist/services/app-common/execution-service.d.ts +23 -0
- package/dist/services/app-common/execution-service.js +105 -0
- package/dist/services/app-common/execution-service.js.map +1 -0
- package/dist/services/app-common/id-normalizer.d.ts +31 -0
- package/dist/services/app-common/id-normalizer.js +83 -0
- package/dist/services/app-common/id-normalizer.js.map +1 -0
- package/dist/services/app-common/install-store.d.ts +34 -0
- package/dist/services/app-common/install-store.js +261 -0
- package/dist/services/app-common/install-store.js.map +1 -0
- package/dist/services/app-common/instance-store.d.ts +78 -0
- package/dist/services/app-common/instance-store.js +495 -0
- package/dist/services/app-common/instance-store.js.map +1 -0
- package/dist/services/app-common/integration-refs.d.ts +17 -0
- package/dist/services/app-common/integration-refs.js +47 -0
- package/dist/services/app-common/integration-refs.js.map +1 -0
- package/dist/services/app-common/lifecycle-pipeline.d.ts +62 -0
- package/dist/services/app-common/lifecycle-pipeline.js +317 -0
- package/dist/services/app-common/lifecycle-pipeline.js.map +1 -0
- package/dist/services/app-common/lifecycle-scripts.d.ts +38 -0
- package/dist/services/app-common/lifecycle-scripts.js +935 -0
- package/dist/services/app-common/lifecycle-scripts.js.map +1 -0
- package/dist/services/app-common/lifecycle-service.d.ts +68 -0
- package/dist/services/app-common/lifecycle-service.js +467 -0
- package/dist/services/app-common/lifecycle-service.js.map +1 -0
- package/dist/services/app-common/paths.d.ts +29 -0
- package/dist/services/app-common/paths.js +34 -0
- package/dist/services/app-common/paths.js.map +1 -0
- package/dist/services/app-common/platform-transform.d.ts +32 -0
- package/dist/services/app-common/platform-transform.js +65 -0
- package/dist/services/app-common/platform-transform.js.map +1 -0
- package/dist/services/app-common/provide-resolver.d.ts +29 -0
- package/dist/services/app-common/provide-resolver.js +129 -0
- package/dist/services/app-common/provide-resolver.js.map +1 -0
- package/dist/services/app-common/remote-spec.d.ts +14 -0
- package/dist/services/app-common/remote-spec.js +58 -0
- package/dist/services/app-common/remote-spec.js.map +1 -0
- package/dist/services/app-common/runtime-builder.d.ts +1 -0
- package/dist/services/app-common/runtime-builder.js +2 -0
- package/dist/services/app-common/runtime-builder.js.map +1 -0
- package/dist/services/app-common/runtime-facts.d.ts +19 -0
- package/dist/services/app-common/runtime-facts.js +126 -0
- package/dist/services/app-common/runtime-facts.js.map +1 -0
- package/dist/services/app-common/service.d.ts +9 -0
- package/dist/services/app-common/service.js +10 -0
- package/dist/services/app-common/service.js.map +1 -0
- package/dist/services/app-common/spec-materializer.d.ts +9 -0
- package/dist/services/app-common/spec-materializer.js +361 -0
- package/dist/services/app-common/spec-materializer.js.map +1 -0
- package/dist/services/app-common/status-refresh.d.ts +33 -0
- package/dist/services/app-common/status-refresh.js +759 -0
- package/dist/services/app-common/status-refresh.js.map +1 -0
- package/dist/services/app-common/task-service.d.ts +29 -0
- package/dist/services/app-common/task-service.js +93 -0
- package/dist/services/app-common/task-service.js.map +1 -0
- package/dist/services/app-common/terminal-session-manager.js +157 -0
- package/dist/services/app-common/terminal-session-manager.js.map +1 -0
- package/dist/services/app-modules/browserless/routes.d.ts +9 -0
- package/dist/services/app-modules/browserless/routes.js +517 -0
- package/dist/services/app-modules/browserless/routes.js.map +1 -0
- package/dist/services/app-modules/routes.d.ts +2 -0
- package/dist/services/app-modules/routes.js +5 -0
- package/dist/services/app-modules/routes.js.map +1 -0
- package/dist/services/backup/backup-admin.d.ts +95 -0
- package/dist/services/backup/backup-admin.js +246 -0
- package/dist/services/backup/backup-admin.js.map +1 -0
- package/dist/services/backup/backup-manager.d.ts +264 -0
- package/dist/services/backup/backup-manager.js +2318 -0
- package/dist/services/backup/backup-manager.js.map +1 -0
- package/dist/services/backup/backup-verify.js +240 -0
- package/dist/services/backup/backup-verify.js.map +1 -0
- package/dist/services/capabilities/browser-policy.d.ts +14 -0
- package/dist/services/capabilities/browser-policy.js +141 -0
- package/dist/services/capabilities/browser-policy.js.map +1 -0
- package/dist/services/capabilities/contract.d.ts +50 -0
- package/dist/services/capabilities/contract.js +129 -0
- package/dist/services/capabilities/contract.js.map +1 -0
- package/dist/services/capabilities/endpoint-validator.d.ts +42 -0
- package/dist/services/capabilities/endpoint-validator.js +114 -0
- package/dist/services/capabilities/endpoint-validator.js.map +1 -0
- package/dist/services/capabilities/health.d.ts +16 -0
- package/dist/services/capabilities/health.js +121 -0
- package/dist/services/capabilities/health.js.map +1 -0
- package/dist/services/capabilities/registry.d.ts +56 -0
- package/dist/services/capabilities/registry.js +222 -0
- package/dist/services/capabilities/registry.js.map +1 -0
- package/dist/services/capabilities/sync.d.ts +7 -0
- package/dist/services/capabilities/sync.js +223 -0
- package/dist/services/capabilities/sync.js.map +1 -0
- package/dist/services/capability-proxy/html-rewriters/browserless.d.ts +1 -0
- package/dist/services/capability-proxy/html-rewriters/browserless.js +83 -0
- package/dist/services/capability-proxy/html-rewriters/browserless.js.map +1 -0
- package/dist/services/capability-proxy/html-rewriters/index.d.ts +12 -0
- package/dist/services/capability-proxy/html-rewriters/index.js +25 -0
- package/dist/services/capability-proxy/html-rewriters/index.js.map +1 -0
- package/dist/services/capability-proxy/html-rewriters/jishukb.d.ts +1 -0
- package/dist/services/capability-proxy/html-rewriters/jishukb.js +161 -0
- package/dist/services/capability-proxy/html-rewriters/jishukb.js.map +1 -0
- package/dist/services/connections/admin.d.ts +80 -0
- package/dist/services/connections/admin.js +327 -0
- package/dist/services/connections/admin.js.map +1 -0
- package/dist/services/connections/apply.d.ts +110 -0
- package/dist/services/connections/apply.js +444 -0
- package/dist/services/connections/apply.js.map +1 -0
- package/dist/services/connections/resolver.d.ts +82 -0
- package/dist/services/connections/resolver.js +289 -0
- package/dist/services/connections/resolver.js.map +1 -0
- package/dist/services/connections/suggestions.d.ts +27 -0
- package/dist/services/connections/suggestions.js +124 -0
- package/dist/services/connections/suggestions.js.map +1 -0
- package/dist/services/connections/transactor.d.ts +39 -0
- package/dist/services/connections/transactor.js +307 -0
- package/dist/services/connections/transactor.js.map +1 -0
- package/dist/services/files/external-mounts.js +187 -0
- package/dist/services/files/external-mounts.js.map +1 -0
- package/dist/services/files/files-manager.d.ts +265 -0
- package/dist/services/files/files-manager.js +1189 -0
- package/dist/services/files/files-manager.js.map +1 -0
- package/dist/services/files/files-mounts.d.ts +42 -0
- package/dist/services/files/files-mounts.js +207 -0
- package/dist/services/files/files-mounts.js.map +1 -0
- package/dist/services/files/organize/applier.js +218 -0
- package/dist/services/files/organize/applier.js.map +1 -0
- package/dist/services/files/organize/rules.js +286 -0
- package/dist/services/files/organize/rules.js.map +1 -0
- package/dist/services/files/organize/scanner.js +366 -0
- package/dist/services/files/organize/scanner.js.map +1 -0
- package/dist/services/files/organize/store.js +82 -0
- package/dist/services/files/organize/store.js.map +1 -0
- package/dist/services/files/webdav/server.d.ts +47 -0
- package/dist/services/files/webdav/server.js +329 -0
- package/dist/services/files/webdav/server.js.map +1 -0
- package/dist/services/files/webdav/xml-builder.js.map +1 -0
- package/dist/services/instances/admin.d.ts +23 -0
- package/dist/services/instances/admin.js +218 -0
- package/dist/services/instances/admin.js.map +1 -0
- package/dist/services/instances/clone.d.ts +26 -0
- package/dist/services/instances/clone.js +78 -0
- package/dist/services/instances/clone.js.map +1 -0
- package/dist/services/instances/config-admin.d.ts +17 -0
- package/dist/services/instances/config-admin.js +181 -0
- package/dist/services/instances/config-admin.js.map +1 -0
- package/dist/services/instances/manager.d.ts +231 -0
- package/dist/services/instances/manager.js +1348 -0
- package/dist/services/instances/manager.js.map +1 -0
- package/dist/services/instances/passwords.js +173 -0
- package/dist/services/instances/passwords.js.map +1 -0
- package/dist/services/instances/types.d.ts +21 -0
- package/dist/services/instances/types.js +2 -0
- package/dist/services/instances/types.js.map +1 -0
- package/dist/services/integrations/anythingllm/integration.d.ts +25 -0
- package/dist/services/integrations/anythingllm/integration.js +251 -0
- package/dist/services/integrations/anythingllm/integration.js.map +1 -0
- package/dist/services/integrations/catalog.d.ts +3 -0
- package/dist/services/integrations/catalog.js +73 -0
- package/dist/services/integrations/catalog.js.map +1 -0
- package/dist/services/integrations/custom/integration.d.ts +28 -0
- package/dist/services/integrations/custom/integration.js +179 -0
- package/dist/services/integrations/custom/integration.js.map +1 -0
- package/dist/services/integrations/hermes/integration.d.ts +194 -0
- package/dist/services/integrations/hermes/integration.js +1669 -0
- package/dist/services/integrations/hermes/integration.js.map +1 -0
- package/dist/services/integrations/index.d.ts +40 -0
- package/dist/services/integrations/index.js +59 -0
- package/dist/services/integrations/index.js.map +1 -0
- package/dist/services/integrations/installable/catalog.d.ts +33 -0
- package/dist/services/integrations/installable/catalog.js +88 -0
- package/dist/services/integrations/installable/catalog.js.map +1 -0
- package/dist/services/integrations/installable/index.d.ts +35 -0
- package/dist/services/integrations/installable/index.js +170 -0
- package/dist/services/integrations/installable/index.js.map +1 -0
- package/dist/services/integrations/installable/installers/integration-probes.d.ts +50 -0
- package/dist/services/integrations/installable/installers/integration-probes.js +231 -0
- package/dist/services/integrations/installable/installers/integration-probes.js.map +1 -0
- package/dist/services/integrations/installable/installers/integration.d.ts +30 -0
- package/dist/services/integrations/installable/installers/integration.js +177 -0
- package/dist/services/integrations/installable/installers/integration.js.map +1 -0
- package/dist/services/integrations/installable/installers/registry-probe.js.map +1 -0
- package/dist/services/integrations/installable/installers/shell-script.d.ts +46 -0
- package/dist/services/integrations/installable/installers/shell-script.js +487 -0
- package/dist/services/integrations/installable/installers/shell-script.js.map +1 -0
- package/dist/services/integrations/installable/types.d.ts +130 -0
- package/dist/services/integrations/installable/types.js +19 -0
- package/dist/services/integrations/installable/types.js.map +1 -0
- package/dist/services/integrations/jishukb/integration.d.ts +22 -0
- package/dist/services/integrations/jishukb/integration.js +189 -0
- package/dist/services/integrations/jishukb/integration.js.map +1 -0
- package/dist/services/integrations/openclaw/anythingllm-shim.d.ts +46 -0
- package/dist/services/integrations/openclaw/anythingllm-shim.js +281 -0
- package/dist/services/integrations/openclaw/anythingllm-shim.js.map +1 -0
- package/dist/services/integrations/openclaw/drive-shim.js +490 -0
- package/dist/services/integrations/openclaw/drive-shim.js.map +1 -0
- package/dist/services/integrations/openclaw/integration.d.ts +424 -0
- package/dist/services/integrations/openclaw/integration.js +4402 -0
- package/dist/services/integrations/openclaw/integration.js.map +1 -0
- package/dist/services/integrations/openclaw/jishukb-shim.d.ts +48 -0
- package/dist/services/integrations/openclaw/jishukb-shim.js +750 -0
- package/dist/services/integrations/openclaw/jishukb-shim.js.map +1 -0
- package/dist/services/integrations/openclaw/mcporter-lite.js +276 -0
- package/dist/services/integrations/openclaw/mcporter-lite.js.map +1 -0
- package/dist/services/integrations/openclaw/mcporter.d.ts +46 -0
- package/dist/services/integrations/openclaw/mcporter.js +112 -0
- package/dist/services/integrations/openclaw/mcporter.js.map +1 -0
- package/dist/services/integrations/openclaw/routes.d.ts +21 -0
- package/dist/services/integrations/openclaw/routes.js +1191 -0
- package/dist/services/integrations/openclaw/routes.js.map +1 -0
- package/dist/services/integrations/registry.d.ts +17 -0
- package/dist/services/integrations/registry.js +36 -0
- package/dist/services/integrations/registry.js.map +1 -0
- package/dist/services/integrations/routes.d.ts +2 -0
- package/dist/services/integrations/routes.js +9 -0
- package/dist/services/integrations/routes.js.map +1 -0
- package/dist/services/integrations/types.d.ts +469 -0
- package/dist/services/integrations/types.js +2 -0
- package/dist/services/integrations/types.js.map +1 -0
- package/dist/services/legacy-migrator/classifier.d.ts +44 -0
- package/dist/services/legacy-migrator/classifier.js +309 -0
- package/dist/services/legacy-migrator/classifier.js.map +1 -0
- package/dist/services/legacy-migrator/executor.d.ts +42 -0
- package/dist/services/legacy-migrator/executor.js +637 -0
- package/dist/services/legacy-migrator/executor.js.map +1 -0
- package/dist/services/legacy-migrator/index.d.ts +31 -0
- package/dist/services/legacy-migrator/index.js +34 -0
- package/dist/services/legacy-migrator/index.js.map +1 -0
- package/dist/services/legacy-migrator/planner.d.ts +8 -0
- package/dist/services/legacy-migrator/planner.js +154 -0
- package/dist/services/legacy-migrator/planner.js.map +1 -0
- package/dist/services/legacy-migrator/provider-settings.d.ts +6 -0
- package/dist/services/legacy-migrator/provider-settings.js +72 -0
- package/dist/services/legacy-migrator/provider-settings.js.map +1 -0
- package/dist/services/legacy-migrator/report.d.ts +9 -0
- package/dist/services/legacy-migrator/report.js +99 -0
- package/dist/services/legacy-migrator/report.js.map +1 -0
- package/dist/services/legacy-migrator/scanner.d.ts +13 -0
- package/dist/services/legacy-migrator/scanner.js +157 -0
- package/dist/services/legacy-migrator/scanner.js.map +1 -0
- package/dist/services/legacy-migrator/types.d.ts +97 -0
- package/dist/services/legacy-migrator/types.js +23 -0
- package/dist/services/legacy-migrator/types.js.map +1 -0
- package/dist/services/llm-proxy/instance-proxy.d.ts +17 -1
- package/dist/services/llm-proxy/instance-proxy.js +171 -44
- package/dist/services/llm-proxy/instance-proxy.js.map +1 -1
- package/dist/services/llm-proxy/probe.js +5 -14
- package/dist/services/llm-proxy/probe.js.map +1 -1
- package/dist/services/llm-proxy/providers.js +23 -31
- package/dist/services/llm-proxy/providers.js.map +1 -1
- package/dist/services/llm-proxy/ssrf.d.ts +11 -4
- package/dist/services/llm-proxy/ssrf.js +45 -7
- package/dist/services/llm-proxy/ssrf.js.map +1 -1
- package/dist/services/llm-proxy/validate-key.js +16 -37
- package/dist/services/llm-proxy/validate-key.js.map +1 -1
- package/dist/services/repair/runtime-repair.d.ts +22 -0
- package/dist/services/repair/runtime-repair.js +307 -0
- package/dist/services/repair/runtime-repair.js.map +1 -0
- package/dist/services/runtime/driver-registry.d.ts +21 -0
- package/dist/services/runtime/driver-registry.js +22 -0
- package/dist/services/runtime/driver-registry.js.map +1 -0
- package/dist/services/runtime/drivers/nomad.d.ts +260 -0
- package/dist/services/runtime/drivers/nomad.js +3092 -0
- package/dist/services/runtime/drivers/nomad.js.map +1 -0
- package/dist/services/runtime/errors.d.ts +3 -3
- package/dist/services/runtime/errors.js +3 -3
- package/dist/services/runtime/instance.d.ts +14 -16
- package/dist/services/runtime/instance.js +93 -123
- package/dist/services/runtime/instance.js.map +1 -1
- package/dist/services/runtime/job-id.d.ts +1 -1
- package/dist/services/runtime/job-id.js +1 -1
- package/dist/services/runtime/mcp-shims/firewall.d.ts +2 -2
- package/dist/services/runtime/mcp-shims/firewall.js +2 -2
- package/dist/services/runtime/mcp-shims/searxng-shim.d.ts +3 -5
- package/dist/services/runtime/mcp-shims/searxng-shim.js +3 -5
- package/dist/services/runtime/mcp-shims/searxng-shim.js.map +1 -1
- package/dist/services/runtime/mcp-shims/write-mcp-entry.d.ts +20 -20
- package/dist/services/runtime/mcp-shims/write-mcp-entry.js +16 -16
- package/dist/services/runtime/mcp-shims/write-mcp-entry.js.map +1 -1
- package/dist/services/runtime/ownership-marker.d.ts +83 -0
- package/dist/services/runtime/ownership-marker.js +109 -0
- package/dist/services/runtime/ownership-marker.js.map +1 -0
- package/dist/services/runtime/types.d.ts +22 -501
- package/dist/services/runtime/types.js +0 -12
- package/dist/services/runtime/types.js.map +1 -1
- package/dist/services/runtime/workload-compiler.d.ts +17 -0
- package/dist/services/runtime/workload-compiler.js +525 -0
- package/dist/services/runtime/workload-compiler.js.map +1 -0
- package/dist/services/runtime/workload-types.d.ts +11 -0
- package/dist/services/runtime/workload-types.js +2 -0
- package/dist/services/runtime/workload-types.js.map +1 -0
- package/dist/services/setup/core-manager.d.ts +50 -0
- package/dist/services/setup/core-manager.js +456 -0
- package/dist/services/setup/core-manager.js.map +1 -0
- package/dist/services/setup/plugin-installer.js +136 -0
- package/dist/services/setup/plugin-installer.js.map +1 -0
- package/dist/services/setup/setup-manager.d.ts +158 -0
- package/dist/services/setup/setup-manager.js +2768 -0
- package/dist/services/setup/setup-manager.js.map +1 -0
- package/dist/services/system/cli-command.d.ts +5 -0
- package/dist/services/system/cli-command.js +18 -0
- package/dist/services/system/cli-command.js.map +1 -0
- package/dist/services/system/macos-launchd.js +312 -0
- package/dist/services/system/macos-launchd.js.map +1 -0
- package/dist/services/system/repair-orchestrator.d.ts +71 -0
- package/dist/services/system/repair-orchestrator.js +412 -0
- package/dist/services/system/repair-orchestrator.js.map +1 -0
- package/dist/services/system/system-monitor.js +96 -0
- package/dist/services/system/system-monitor.js.map +1 -0
- package/dist/services/system/system-ollama-provider.d.ts +14 -0
- package/dist/services/system/system-ollama-provider.js +129 -0
- package/dist/services/system/system-ollama-provider.js.map +1 -0
- package/dist/services/system/system-reconciler.d.ts +59 -0
- package/dist/services/system/system-reconciler.js +710 -0
- package/dist/services/system/system-reconciler.js.map +1 -0
- package/dist/services/system/update-manager.d.ts +43 -0
- package/dist/services/system/update-manager.js +315 -0
- package/dist/services/system/update-manager.js.map +1 -0
- package/dist/services/system/upgrade-finalize.d.ts +80 -0
- package/dist/services/system/upgrade-finalize.js +507 -0
- package/dist/services/system/upgrade-finalize.js.map +1 -0
- package/dist/services/tasks/registry.d.ts +44 -0
- package/dist/services/tasks/registry.js +90 -0
- package/dist/services/tasks/registry.js.map +1 -0
- package/dist/services/telemetry/activation.d.ts +6 -2
- package/dist/services/telemetry/activation.js +6 -2
- package/dist/services/telemetry/activation.js.map +1 -1
- package/dist/services/telemetry/heartbeat.d.ts +6 -2
- package/dist/services/telemetry/heartbeat.js +6 -2
- package/dist/services/telemetry/heartbeat.js.map +1 -1
- package/dist/services/workspaces/builder.d.ts +29 -0
- package/dist/services/workspaces/builder.js +186 -0
- package/dist/services/workspaces/builder.js.map +1 -0
- package/dist/types.d.ts +331 -45
- package/dist/utils/instance-lock.d.ts +2 -2
- package/dist/utils/instance-lock.js +2 -2
- package/install/jishu-install.sh +107 -26
- package/install/jishu-uninstall.sh +8 -0
- package/install/post-install.sh +162 -185
- package/install/post-uninstall.sh +6 -0
- package/node_modules/@fastify/static/.github/workflows/ci.yml +1 -1
- package/node_modules/@fastify/static/.github/workflows/lock-threads.yml +19 -0
- package/node_modules/@fastify/static/LICENSE +1 -3
- package/node_modules/@fastify/static/example/server-benchmark.js +39 -0
- package/node_modules/@fastify/static/index.js +169 -23
- package/node_modules/@fastify/static/lib/dirList.js +20 -6
- package/node_modules/@fastify/static/package.json +10 -8
- package/node_modules/@fastify/static/test/dir-list.test.js +82 -0
- package/node_modules/@fastify/static/test/static.test.js +326 -4
- package/node_modules/@fastify/static/types/index.d.ts +0 -4
- package/node_modules/@fastify/static/types/index.test-d.ts +1 -1
- package/node_modules/content-disposition/README.md +21 -22
- package/node_modules/content-disposition/index.js +122 -44
- package/node_modules/content-disposition/package.json +16 -20
- package/node_modules/glob/README.md +39 -130
- package/node_modules/glob/dist/commonjs/glob.d.ts +8 -0
- package/node_modules/glob/dist/commonjs/glob.d.ts.map +1 -1
- package/node_modules/glob/dist/commonjs/glob.js +2 -1
- package/node_modules/glob/dist/commonjs/glob.js.map +1 -1
- package/node_modules/glob/dist/commonjs/index.min.js +4 -0
- package/node_modules/glob/dist/commonjs/index.min.js.map +7 -0
- package/node_modules/glob/dist/commonjs/pattern.d.ts +3 -0
- package/node_modules/glob/dist/commonjs/pattern.d.ts.map +1 -1
- package/node_modules/glob/dist/commonjs/pattern.js +4 -0
- package/node_modules/glob/dist/commonjs/pattern.js.map +1 -1
- package/node_modules/glob/dist/esm/glob.d.ts +8 -0
- package/node_modules/glob/dist/esm/glob.d.ts.map +1 -1
- package/node_modules/glob/dist/esm/glob.js +2 -1
- package/node_modules/glob/dist/esm/glob.js.map +1 -1
- package/node_modules/glob/dist/esm/index.min.js +4 -0
- package/node_modules/glob/dist/esm/index.min.js.map +7 -0
- package/node_modules/glob/dist/esm/pattern.d.ts +3 -0
- package/node_modules/glob/dist/esm/pattern.d.ts.map +1 -1
- package/node_modules/glob/dist/esm/pattern.js +4 -0
- package/node_modules/glob/dist/esm/pattern.js.map +1 -1
- package/node_modules/glob/package.json +38 -37
- package/node_modules/jishushell-panel/README.md +4 -4
- package/node_modules/jishushell-panel/output/dist/server.js +17 -6
- package/node_modules/jishushell-panel/output/dist/server.js.map +1 -1
- package/node_modules/jishushell-panel/output/public/assets/ApiKeyField-NKcbHjNz.js +1 -0
- package/node_modules/jishushell-panel/output/public/assets/Dashboard-Da1fL38t.js +1 -0
- package/node_modules/jishushell-panel/output/public/assets/HermesChatPanel-DZvmYsoh.js +1 -0
- package/node_modules/jishushell-panel/output/public/assets/HermesConfigForm-BLUWlKwm.js +4 -0
- package/node_modules/jishushell-panel/output/public/assets/InitPassword-BAKsshzk.js +1 -0
- package/node_modules/jishushell-panel/output/public/assets/InstanceDetail-Dgyc_TX5.js +14 -0
- package/node_modules/jishushell-panel/output/public/assets/Login-DHeOmwI8.js +1 -0
- package/node_modules/jishushell-panel/output/public/assets/NewInstance-CIy0cYtp.js +1 -0
- package/node_modules/jishushell-panel/output/public/assets/ProviderRecommendations-H0ByEYF0.js +1 -0
- package/node_modules/jishushell-panel/output/public/assets/Settings-DAT-UMfP.js +1 -0
- package/node_modules/jishushell-panel/output/public/assets/Setup-g3uckFYR.js +1 -0
- package/node_modules/jishushell-panel/output/public/assets/WeixinLoginPanel-D-T6BxkQ.js +1 -0
- package/node_modules/jishushell-panel/output/public/assets/api-C70Gt678.js +4 -0
- package/node_modules/jishushell-panel/output/public/assets/index-DnnqTf7s.css +1 -0
- package/node_modules/jishushell-panel/output/public/assets/index-ERt6_ngA.js +23 -0
- package/node_modules/jishushell-panel/output/public/assets/registry-DF93EzIb.js +2 -0
- package/node_modules/jishushell-panel/output/public/assets/rolldown-runtime-QTnfLwEv.js +1 -0
- package/node_modules/jishushell-panel/output/public/assets/setup-task-q21GnI0E.js +1 -0
- package/node_modules/jishushell-panel/output/public/assets/usePolling-DeoThIQn.js +1 -0
- package/node_modules/jishushell-panel/output/public/assets/vendor-i18n-CS8DFbkQ.js +1 -0
- package/node_modules/jishushell-panel/output/public/assets/vendor-react-Cc84NArf.js +8 -0
- package/node_modules/jishushell-panel/output/public/index.html +6 -4
- package/node_modules/jishushell-panel/package.json +2 -2
- package/node_modules/semver/classes/range.js +11 -2
- package/node_modules/semver/package.json +2 -2
- package/package.json +12 -64
- package/scripts/check-app-path-boundaries.mjs +121 -0
- package/scripts/check-app-spec.mjs +127 -25
- package/scripts/check-colima-launchd.mjs +10 -8
- package/scripts/check-integration-isolation.ts +541 -0
- package/scripts/check-new-file-tests.mjs +11 -3
- package/scripts/check-open-core-boundaries.mjs +60 -10
- package/scripts/check-test-layering.sh +1 -1
- package/scripts/fixtures/instances/hermes-sample/instance.json +3 -2
- package/scripts/fixtures/instances/legacy-openclaw-sample/instance.json +1 -1
- package/scripts/local-web-upgrade-test.README +4 -3
- package/scripts/local-web-upgrade-test.example.env +2 -2
- package/scripts/local-web-upgrade-test.sh +14 -1
- package/scripts/pack-gui-and-send-pi.sh +41 -0
- package/scripts/perf/instances.js +1 -1
- package/scripts/prune-open-core-dist.mjs +89 -2
- package/scripts/smoke/hermes-bootstrap.sh +5 -5
- package/templates/hermes-entrypoint.sh +19 -29
- package/apps/openwebui-container.yaml +0 -97
- package/apps/playwright-container.yaml +0 -126
- package/dependencies/jishushell-panel-0.6.5.tgz +0 -0
- package/dist/crypto-shim.d.ts +0 -1
- package/dist/crypto-shim.js +0 -2
- package/dist/crypto-shim.js.map +0 -1
- package/dist/routes/agent-apps.d.ts +0 -14
- package/dist/routes/agent-apps.js +0 -77
- package/dist/routes/agent-apps.js.map +0 -1
- package/dist/routes/internal.d.ts +0 -2
- package/dist/routes/internal.js +0 -55
- package/dist/routes/internal.js.map +0 -1
- package/dist/routes/openclaw-routes.d.ts +0 -22
- package/dist/routes/openclaw-routes.js +0 -1020
- package/dist/routes/openclaw-routes.js.map +0 -1
- package/dist/routes/runtime.d.ts +0 -15
- package/dist/routes/runtime.js +0 -76
- package/dist/routes/runtime.js.map +0 -1
- package/dist/services/agent-apps/catalog.d.ts +0 -33
- package/dist/services/agent-apps/catalog.js +0 -88
- package/dist/services/agent-apps/catalog.js.map +0 -1
- package/dist/services/agent-apps/index.d.ts +0 -36
- package/dist/services/agent-apps/index.js +0 -171
- package/dist/services/agent-apps/index.js.map +0 -1
- package/dist/services/agent-apps/installers/adapter-probes.d.ts +0 -49
- package/dist/services/agent-apps/installers/adapter-probes.js +0 -230
- package/dist/services/agent-apps/installers/adapter-probes.js.map +0 -1
- package/dist/services/agent-apps/installers/adapter.d.ts +0 -30
- package/dist/services/agent-apps/installers/adapter.js +0 -171
- package/dist/services/agent-apps/installers/adapter.js.map +0 -1
- package/dist/services/agent-apps/installers/registry-probe.js.map +0 -1
- package/dist/services/agent-apps/installers/shell-script.d.ts +0 -47
- package/dist/services/agent-apps/installers/shell-script.js +0 -488
- package/dist/services/agent-apps/installers/shell-script.js.map +0 -1
- package/dist/services/agent-apps/types.d.ts +0 -128
- package/dist/services/agent-apps/types.js +0 -17
- package/dist/services/agent-apps/types.js.map +0 -1
- package/dist/services/app/app-compiler.js +0 -185
- package/dist/services/app/app-compiler.js.map +0 -1
- package/dist/services/app/app-manager.d.ts +0 -184
- package/dist/services/app/app-manager.js +0 -2933
- package/dist/services/app/app-manager.js.map +0 -1
- package/dist/services/app/custom-manager.d.ts +0 -27
- package/dist/services/app/custom-manager.js +0 -382
- package/dist/services/app/custom-manager.js.map +0 -1
- package/dist/services/app/hermes-agent-manager.d.ts +0 -20
- package/dist/services/app/hermes-agent-manager.js +0 -299
- package/dist/services/app/hermes-agent-manager.js.map +0 -1
- package/dist/services/app/id-normalizer.d.ts +0 -27
- package/dist/services/app/id-normalizer.js +0 -77
- package/dist/services/app/id-normalizer.js.map +0 -1
- package/dist/services/app/ollama-manager.d.ts +0 -18
- package/dist/services/app/ollama-manager.js +0 -224
- package/dist/services/app/ollama-manager.js.map +0 -1
- package/dist/services/app/openclaw-manager.d.ts +0 -63
- package/dist/services/app/openclaw-manager.js +0 -1215
- package/dist/services/app/openclaw-manager.js.map +0 -1
- package/dist/services/app/paths.d.ts +0 -27
- package/dist/services/app/paths.js +0 -40
- package/dist/services/app/paths.js.map +0 -1
- package/dist/services/app/platform-transform.d.ts +0 -32
- package/dist/services/app/platform-transform.js +0 -65
- package/dist/services/app/platform-transform.js.map +0 -1
- package/dist/services/app/provide-resolver.d.ts +0 -29
- package/dist/services/app/provide-resolver.js +0 -135
- package/dist/services/app/provide-resolver.js.map +0 -1
- package/dist/services/app/registry.d.ts +0 -17
- package/dist/services/app/registry.js +0 -31
- package/dist/services/app/registry.js.map +0 -1
- package/dist/services/app/remote-spec.d.ts +0 -14
- package/dist/services/app/remote-spec.js +0 -58
- package/dist/services/app/remote-spec.js.map +0 -1
- package/dist/services/app/terminal-session-manager.js +0 -157
- package/dist/services/app/terminal-session-manager.js.map +0 -1
- package/dist/services/app/types.d.ts +0 -74
- package/dist/services/app/types.js +0 -16
- package/dist/services/app/types.js.map +0 -1
- package/dist/services/app-config-admin.d.ts +0 -17
- package/dist/services/app-config-admin.js +0 -177
- package/dist/services/app-config-admin.js.map +0 -1
- package/dist/services/app-create-from-installed.d.ts +0 -23
- package/dist/services/app-create-from-installed.js +0 -75
- package/dist/services/app-create-from-installed.js.map +0 -1
- package/dist/services/app-passwords.js +0 -173
- package/dist/services/app-passwords.js.map +0 -1
- package/dist/services/backup-admin.d.ts +0 -101
- package/dist/services/backup-admin.js +0 -259
- package/dist/services/backup-admin.js.map +0 -1
- package/dist/services/backup-manager.d.ts +0 -264
- package/dist/services/backup-manager.js +0 -2263
- package/dist/services/backup-manager.js.map +0 -1
- package/dist/services/backup-verify.js +0 -240
- package/dist/services/backup-verify.js.map +0 -1
- package/dist/services/capability-endpoint-validator.d.ts +0 -41
- package/dist/services/capability-endpoint-validator.js +0 -114
- package/dist/services/capability-endpoint-validator.js.map +0 -1
- package/dist/services/capability-health.d.ts +0 -16
- package/dist/services/capability-health.js +0 -121
- package/dist/services/capability-health.js.map +0 -1
- package/dist/services/capability-registry.d.ts +0 -29
- package/dist/services/capability-registry.js +0 -176
- package/dist/services/capability-registry.js.map +0 -1
- package/dist/services/capability-sync.d.ts +0 -4
- package/dist/services/capability-sync.js +0 -220
- package/dist/services/capability-sync.js.map +0 -1
- package/dist/services/connection-admin.d.ts +0 -74
- package/dist/services/connection-admin.js +0 -287
- package/dist/services/connection-admin.js.map +0 -1
- package/dist/services/connection-apply.d.ts +0 -91
- package/dist/services/connection-apply.js +0 -471
- package/dist/services/connection-apply.js.map +0 -1
- package/dist/services/connection-resolver.d.ts +0 -65
- package/dist/services/connection-resolver.js +0 -281
- package/dist/services/connection-resolver.js.map +0 -1
- package/dist/services/connection-transactor.d.ts +0 -39
- package/dist/services/connection-transactor.js +0 -354
- package/dist/services/connection-transactor.js.map +0 -1
- package/dist/services/core-manager.d.ts +0 -50
- package/dist/services/core-manager.js +0 -411
- package/dist/services/core-manager.js.map +0 -1
- package/dist/services/external-mounts.js +0 -187
- package/dist/services/external-mounts.js.map +0 -1
- package/dist/services/files-manager.d.ts +0 -252
- package/dist/services/files-manager.js +0 -1156
- package/dist/services/files-manager.js.map +0 -1
- package/dist/services/files-mounts.d.ts +0 -42
- package/dist/services/files-mounts.js +0 -207
- package/dist/services/files-mounts.js.map +0 -1
- package/dist/services/instance-admin.d.ts +0 -26
- package/dist/services/instance-admin.js +0 -218
- package/dist/services/instance-admin.js.map +0 -1
- package/dist/services/instance-manager.d.ts +0 -192
- package/dist/services/instance-manager.js +0 -1289
- package/dist/services/instance-manager.js.map +0 -1
- package/dist/services/macos-launchd.js +0 -312
- package/dist/services/macos-launchd.js.map +0 -1
- package/dist/services/nomad-manager.d.ts +0 -307
- package/dist/services/nomad-manager.js +0 -3958
- package/dist/services/nomad-manager.js.map +0 -1
- package/dist/services/organize/applier.js +0 -218
- package/dist/services/organize/applier.js.map +0 -1
- package/dist/services/organize/rules.js +0 -286
- package/dist/services/organize/rules.js.map +0 -1
- package/dist/services/organize/scanner.js +0 -366
- package/dist/services/organize/scanner.js.map +0 -1
- package/dist/services/organize/store.js +0 -82
- package/dist/services/organize/store.js.map +0 -1
- package/dist/services/plugin-installer.js +0 -128
- package/dist/services/plugin-installer.js.map +0 -1
- package/dist/services/process-manager.d.ts +0 -25
- package/dist/services/process-manager.js +0 -568
- package/dist/services/process-manager.js.map +0 -1
- package/dist/services/runtime/adapters/custom.d.ts +0 -20
- package/dist/services/runtime/adapters/custom.js +0 -188
- package/dist/services/runtime/adapters/custom.js.map +0 -1
- package/dist/services/runtime/adapters/hermes.d.ts +0 -204
- package/dist/services/runtime/adapters/hermes.js +0 -1684
- package/dist/services/runtime/adapters/hermes.js.map +0 -1
- package/dist/services/runtime/adapters/openclaw-mcporter.d.ts +0 -45
- package/dist/services/runtime/adapters/openclaw-mcporter.js +0 -108
- package/dist/services/runtime/adapters/openclaw-mcporter.js.map +0 -1
- package/dist/services/runtime/adapters/openclaw.d.ts +0 -426
- package/dist/services/runtime/adapters/openclaw.js +0 -3975
- package/dist/services/runtime/adapters/openclaw.js.map +0 -1
- package/dist/services/runtime/index.d.ts +0 -34
- package/dist/services/runtime/index.js +0 -51
- package/dist/services/runtime/index.js.map +0 -1
- package/dist/services/runtime/mcp-shims/anythingllm-shim.d.ts +0 -46
- package/dist/services/runtime/mcp-shims/anythingllm-shim.js +0 -281
- package/dist/services/runtime/mcp-shims/anythingllm-shim.js.map +0 -1
- package/dist/services/runtime/mcp-shims/drive-shim.js +0 -490
- package/dist/services/runtime/mcp-shims/drive-shim.js.map +0 -1
- package/dist/services/runtime/mcp-shims/jishukb-shim.d.ts +0 -48
- package/dist/services/runtime/mcp-shims/jishukb-shim.js +0 -723
- package/dist/services/runtime/mcp-shims/jishukb-shim.js.map +0 -1
- package/dist/services/runtime/mcp-shims/mcporter-lite.js +0 -276
- package/dist/services/runtime/mcp-shims/mcporter-lite.js.map +0 -1
- package/dist/services/runtime/migrations.d.ts +0 -23
- package/dist/services/runtime/migrations.js +0 -125
- package/dist/services/runtime/migrations.js.map +0 -1
- package/dist/services/runtime/registry.d.ts +0 -13
- package/dist/services/runtime/registry.js +0 -32
- package/dist/services/runtime/registry.js.map +0 -1
- package/dist/services/runtime-identity.d.ts +0 -13
- package/dist/services/runtime-identity.js +0 -166
- package/dist/services/runtime-identity.js.map +0 -1
- package/dist/services/runtime-repair.d.ts +0 -52
- package/dist/services/runtime-repair.js +0 -352
- package/dist/services/runtime-repair.js.map +0 -1
- package/dist/services/setup-manager.d.ts +0 -158
- package/dist/services/setup-manager.js +0 -2740
- package/dist/services/setup-manager.js.map +0 -1
- package/dist/services/suggestions.d.ts +0 -27
- package/dist/services/suggestions.js +0 -133
- package/dist/services/suggestions.js.map +0 -1
- package/dist/services/system-monitor.js +0 -79
- package/dist/services/system-monitor.js.map +0 -1
- package/dist/services/system-ollama-provider.d.ts +0 -14
- package/dist/services/system-ollama-provider.js +0 -125
- package/dist/services/system-ollama-provider.js.map +0 -1
- package/dist/services/system-reconciler.d.ts +0 -72
- package/dist/services/system-reconciler.js +0 -600
- package/dist/services/system-reconciler.js.map +0 -1
- package/dist/services/task-registry.d.ts +0 -44
- package/dist/services/task-registry.js +0 -76
- package/dist/services/task-registry.js.map +0 -1
- package/dist/services/types-shim.d.ts +0 -16
- package/dist/services/types-shim.js +0 -2
- package/dist/services/types-shim.js.map +0 -1
- package/dist/services/update-manager.d.ts +0 -47
- package/dist/services/update-manager.js +0 -351
- package/dist/services/update-manager.js.map +0 -1
- package/dist/services/webdav/server.d.ts +0 -24
- package/dist/services/webdav/server.js +0 -420
- package/dist/services/webdav/server.js.map +0 -1
- package/dist/services/webdav/xml-builder.js.map +0 -1
- package/dist/services/workspace-builder.d.ts +0 -29
- package/dist/services/workspace-builder.js +0 -188
- package/dist/services/workspace-builder.js.map +0 -1
- package/node_modules/@fastify/static/.github/stale.yml +0 -21
- package/node_modules/@isaacs/cliui/LICENSE.md +0 -63
- package/node_modules/@isaacs/cliui/README.md +0 -151
- package/node_modules/@isaacs/cliui/dist/commonjs/ansi-regex/index.d.ts +0 -4
- package/node_modules/@isaacs/cliui/dist/commonjs/ansi-regex/index.d.ts.map +0 -1
- package/node_modules/@isaacs/cliui/dist/commonjs/ansi-regex/index.js +0 -16
- package/node_modules/@isaacs/cliui/dist/commonjs/ansi-regex/index.js.map +0 -1
- package/node_modules/@isaacs/cliui/dist/commonjs/ansi-styles/index.d.ts +0 -34
- package/node_modules/@isaacs/cliui/dist/commonjs/ansi-styles/index.d.ts.map +0 -1
- package/node_modules/@isaacs/cliui/dist/commonjs/ansi-styles/index.js +0 -170
- package/node_modules/@isaacs/cliui/dist/commonjs/ansi-styles/index.js.map +0 -1
- package/node_modules/@isaacs/cliui/dist/commonjs/eastasianwidth/index.d.ts +0 -6
- package/node_modules/@isaacs/cliui/dist/commonjs/eastasianwidth/index.d.ts.map +0 -1
- package/node_modules/@isaacs/cliui/dist/commonjs/eastasianwidth/index.js +0 -307
- package/node_modules/@isaacs/cliui/dist/commonjs/eastasianwidth/index.js.map +0 -1
- package/node_modules/@isaacs/cliui/dist/commonjs/emoji-regex/index.d.ts +0 -2
- package/node_modules/@isaacs/cliui/dist/commonjs/emoji-regex/index.d.ts.map +0 -1
- package/node_modules/@isaacs/cliui/dist/commonjs/emoji-regex/index.js +0 -7
- package/node_modules/@isaacs/cliui/dist/commonjs/emoji-regex/index.js.map +0 -1
- package/node_modules/@isaacs/cliui/dist/commonjs/index.d.ts +0 -41
- package/node_modules/@isaacs/cliui/dist/commonjs/index.d.ts.map +0 -1
- package/node_modules/@isaacs/cliui/dist/commonjs/index.js +0 -322
- package/node_modules/@isaacs/cliui/dist/commonjs/index.js.map +0 -1
- package/node_modules/@isaacs/cliui/dist/commonjs/index.min.js +0 -12
- package/node_modules/@isaacs/cliui/dist/commonjs/index.min.js.map +0 -7
- package/node_modules/@isaacs/cliui/dist/commonjs/package.json +0 -3
- package/node_modules/@isaacs/cliui/dist/commonjs/string-width/index.d.ts +0 -5
- package/node_modules/@isaacs/cliui/dist/commonjs/string-width/index.d.ts.map +0 -1
- package/node_modules/@isaacs/cliui/dist/commonjs/string-width/index.js +0 -49
- package/node_modules/@isaacs/cliui/dist/commonjs/string-width/index.js.map +0 -1
- package/node_modules/@isaacs/cliui/dist/commonjs/strip-ansi/index.d.ts +0 -2
- package/node_modules/@isaacs/cliui/dist/commonjs/strip-ansi/index.d.ts.map +0 -1
- package/node_modules/@isaacs/cliui/dist/commonjs/strip-ansi/index.js +0 -8
- package/node_modules/@isaacs/cliui/dist/commonjs/strip-ansi/index.js.map +0 -1
- package/node_modules/@isaacs/cliui/dist/commonjs/wrap-ansi/index.d.ts +0 -7
- package/node_modules/@isaacs/cliui/dist/commonjs/wrap-ansi/index.d.ts.map +0 -1
- package/node_modules/@isaacs/cliui/dist/commonjs/wrap-ansi/index.js +0 -176
- package/node_modules/@isaacs/cliui/dist/commonjs/wrap-ansi/index.js.map +0 -1
- package/node_modules/@isaacs/cliui/dist/esm/ansi-regex/index.d.ts +0 -4
- package/node_modules/@isaacs/cliui/dist/esm/ansi-regex/index.d.ts.map +0 -1
- package/node_modules/@isaacs/cliui/dist/esm/ansi-regex/index.js +0 -12
- package/node_modules/@isaacs/cliui/dist/esm/ansi-regex/index.js.map +0 -1
- package/node_modules/@isaacs/cliui/dist/esm/ansi-styles/index.d.ts +0 -34
- package/node_modules/@isaacs/cliui/dist/esm/ansi-styles/index.d.ts.map +0 -1
- package/node_modules/@isaacs/cliui/dist/esm/ansi-styles/index.js +0 -167
- package/node_modules/@isaacs/cliui/dist/esm/ansi-styles/index.js.map +0 -1
- package/node_modules/@isaacs/cliui/dist/esm/eastasianwidth/index.d.ts +0 -6
- package/node_modules/@isaacs/cliui/dist/esm/eastasianwidth/index.d.ts.map +0 -1
- package/node_modules/@isaacs/cliui/dist/esm/eastasianwidth/index.js +0 -299
- package/node_modules/@isaacs/cliui/dist/esm/eastasianwidth/index.js.map +0 -1
- package/node_modules/@isaacs/cliui/dist/esm/emoji-regex/index.d.ts +0 -2
- package/node_modules/@isaacs/cliui/dist/esm/emoji-regex/index.d.ts.map +0 -1
- package/node_modules/@isaacs/cliui/dist/esm/emoji-regex/index.js +0 -3
- package/node_modules/@isaacs/cliui/dist/esm/emoji-regex/index.js.map +0 -1
- package/node_modules/@isaacs/cliui/dist/esm/index.d.ts +0 -41
- package/node_modules/@isaacs/cliui/dist/esm/index.d.ts.map +0 -1
- package/node_modules/@isaacs/cliui/dist/esm/index.js +0 -317
- package/node_modules/@isaacs/cliui/dist/esm/index.js.map +0 -1
- package/node_modules/@isaacs/cliui/dist/esm/index.min.js +0 -12
- package/node_modules/@isaacs/cliui/dist/esm/index.min.js.map +0 -7
- package/node_modules/@isaacs/cliui/dist/esm/package.json +0 -3
- package/node_modules/@isaacs/cliui/dist/esm/string-width/index.d.ts +0 -5
- package/node_modules/@isaacs/cliui/dist/esm/string-width/index.d.ts.map +0 -1
- package/node_modules/@isaacs/cliui/dist/esm/string-width/index.js +0 -46
- package/node_modules/@isaacs/cliui/dist/esm/string-width/index.js.map +0 -1
- package/node_modules/@isaacs/cliui/dist/esm/strip-ansi/index.d.ts +0 -2
- package/node_modules/@isaacs/cliui/dist/esm/strip-ansi/index.d.ts.map +0 -1
- package/node_modules/@isaacs/cliui/dist/esm/strip-ansi/index.js +0 -4
- package/node_modules/@isaacs/cliui/dist/esm/strip-ansi/index.js.map +0 -1
- package/node_modules/@isaacs/cliui/dist/esm/wrap-ansi/index.d.ts +0 -7
- package/node_modules/@isaacs/cliui/dist/esm/wrap-ansi/index.d.ts.map +0 -1
- package/node_modules/@isaacs/cliui/dist/esm/wrap-ansi/index.js +0 -172
- package/node_modules/@isaacs/cliui/dist/esm/wrap-ansi/index.js.map +0 -1
- package/node_modules/@isaacs/cliui/package.json +0 -163
- package/node_modules/content-disposition/HISTORY.md +0 -60
- package/node_modules/cross-spawn/LICENSE +0 -21
- package/node_modules/cross-spawn/README.md +0 -89
- package/node_modules/cross-spawn/index.js +0 -39
- package/node_modules/cross-spawn/lib/enoent.js +0 -59
- package/node_modules/cross-spawn/lib/parse.js +0 -91
- package/node_modules/cross-spawn/lib/util/escape.js +0 -47
- package/node_modules/cross-spawn/lib/util/readShebang.js +0 -23
- package/node_modules/cross-spawn/lib/util/resolveCommand.js +0 -52
- package/node_modules/cross-spawn/package.json +0 -73
- package/node_modules/foreground-child/LICENSE +0 -15
- package/node_modules/foreground-child/README.md +0 -128
- package/node_modules/foreground-child/dist/commonjs/all-signals.d.ts +0 -2
- package/node_modules/foreground-child/dist/commonjs/all-signals.d.ts.map +0 -1
- package/node_modules/foreground-child/dist/commonjs/all-signals.js +0 -58
- package/node_modules/foreground-child/dist/commonjs/all-signals.js.map +0 -1
- package/node_modules/foreground-child/dist/commonjs/index.d.ts +0 -58
- package/node_modules/foreground-child/dist/commonjs/index.d.ts.map +0 -1
- package/node_modules/foreground-child/dist/commonjs/index.js +0 -123
- package/node_modules/foreground-child/dist/commonjs/index.js.map +0 -1
- package/node_modules/foreground-child/dist/commonjs/package.json +0 -3
- package/node_modules/foreground-child/dist/commonjs/proxy-signals.d.ts +0 -6
- package/node_modules/foreground-child/dist/commonjs/proxy-signals.d.ts.map +0 -1
- package/node_modules/foreground-child/dist/commonjs/proxy-signals.js +0 -38
- package/node_modules/foreground-child/dist/commonjs/proxy-signals.js.map +0 -1
- package/node_modules/foreground-child/dist/commonjs/watchdog.d.ts +0 -10
- package/node_modules/foreground-child/dist/commonjs/watchdog.d.ts.map +0 -1
- package/node_modules/foreground-child/dist/commonjs/watchdog.js +0 -50
- package/node_modules/foreground-child/dist/commonjs/watchdog.js.map +0 -1
- package/node_modules/foreground-child/dist/esm/all-signals.d.ts +0 -2
- package/node_modules/foreground-child/dist/esm/all-signals.d.ts.map +0 -1
- package/node_modules/foreground-child/dist/esm/all-signals.js +0 -52
- package/node_modules/foreground-child/dist/esm/all-signals.js.map +0 -1
- package/node_modules/foreground-child/dist/esm/index.d.ts +0 -58
- package/node_modules/foreground-child/dist/esm/index.d.ts.map +0 -1
- package/node_modules/foreground-child/dist/esm/index.js +0 -115
- package/node_modules/foreground-child/dist/esm/index.js.map +0 -1
- package/node_modules/foreground-child/dist/esm/package.json +0 -3
- package/node_modules/foreground-child/dist/esm/proxy-signals.d.ts +0 -6
- package/node_modules/foreground-child/dist/esm/proxy-signals.d.ts.map +0 -1
- package/node_modules/foreground-child/dist/esm/proxy-signals.js +0 -34
- package/node_modules/foreground-child/dist/esm/proxy-signals.js.map +0 -1
- package/node_modules/foreground-child/dist/esm/watchdog.d.ts +0 -10
- package/node_modules/foreground-child/dist/esm/watchdog.d.ts.map +0 -1
- package/node_modules/foreground-child/dist/esm/watchdog.js +0 -46
- package/node_modules/foreground-child/dist/esm/watchdog.js.map +0 -1
- package/node_modules/foreground-child/package.json +0 -106
- package/node_modules/glob/dist/esm/bin.d.mts +0 -3
- package/node_modules/glob/dist/esm/bin.d.mts.map +0 -1
- package/node_modules/glob/dist/esm/bin.mjs +0 -346
- package/node_modules/glob/dist/esm/bin.mjs.map +0 -1
- package/node_modules/isexe/.npmignore +0 -2
- package/node_modules/isexe/LICENSE +0 -15
- package/node_modules/isexe/README.md +0 -51
- package/node_modules/isexe/index.js +0 -57
- package/node_modules/isexe/mode.js +0 -41
- package/node_modules/isexe/package.json +0 -31
- package/node_modules/isexe/test/basic.js +0 -221
- package/node_modules/isexe/windows.js +0 -42
- package/node_modules/jackspeak/LICENSE.md +0 -55
- package/node_modules/jackspeak/README.md +0 -394
- package/node_modules/jackspeak/dist/commonjs/index.d.ts +0 -323
- package/node_modules/jackspeak/dist/commonjs/index.d.ts.map +0 -1
- package/node_modules/jackspeak/dist/commonjs/index.js +0 -944
- package/node_modules/jackspeak/dist/commonjs/index.js.map +0 -1
- package/node_modules/jackspeak/dist/commonjs/index.min.js +0 -33
- package/node_modules/jackspeak/dist/commonjs/index.min.js.map +0 -7
- package/node_modules/jackspeak/dist/commonjs/package.json +0 -3
- package/node_modules/jackspeak/dist/esm/index.d.ts +0 -323
- package/node_modules/jackspeak/dist/esm/index.d.ts.map +0 -1
- package/node_modules/jackspeak/dist/esm/index.js +0 -936
- package/node_modules/jackspeak/dist/esm/index.js.map +0 -1
- package/node_modules/jackspeak/dist/esm/index.min.js +0 -33
- package/node_modules/jackspeak/dist/esm/index.min.js.map +0 -7
- package/node_modules/jackspeak/dist/esm/package.json +0 -3
- package/node_modules/jackspeak/package.json +0 -115
- package/node_modules/jishushell-panel/output/public/assets/ApiKeyField-D1i7zWXR.js +0 -1
- package/node_modules/jishushell-panel/output/public/assets/Dashboard-sWIvL43F.js +0 -1
- package/node_modules/jishushell-panel/output/public/assets/HermesChatPanel-DQ8RyvQY.js +0 -1
- package/node_modules/jishushell-panel/output/public/assets/HermesConfigForm-tIbPP1sB.js +0 -4
- package/node_modules/jishushell-panel/output/public/assets/InitPassword-C3Slq3Dd.js +0 -1
- package/node_modules/jishushell-panel/output/public/assets/InstanceDetail-7JqY9tq4.js +0 -92
- package/node_modules/jishushell-panel/output/public/assets/Login-BXLDJlQN.js +0 -1
- package/node_modules/jishushell-panel/output/public/assets/NewInstance-dLc5Xrpx.js +0 -1
- package/node_modules/jishushell-panel/output/public/assets/ProviderRecommendations-DIAXxesl.js +0 -1
- package/node_modules/jishushell-panel/output/public/assets/Settings-Bd5utbBh.js +0 -1
- package/node_modules/jishushell-panel/output/public/assets/Setup-Yn9_20FL.js +0 -1
- package/node_modules/jishushell-panel/output/public/assets/WeixinLoginPanel-C21doQTJ.js +0 -9
- package/node_modules/jishushell-panel/output/public/assets/index-CCkaIEjn.js +0 -20
- package/node_modules/jishushell-panel/output/public/assets/index-D7qxy-Vh.css +0 -1
- package/node_modules/jishushell-panel/output/public/assets/registry-B2ZQZXWL.js +0 -2
- package/node_modules/jishushell-panel/output/public/assets/usePolling-BFZm4do_.js +0 -1
- package/node_modules/jishushell-panel/output/public/assets/vendor-i18n-DqPtOicc.js +0 -9
- package/node_modules/jishushell-panel/output/public/assets/vendor-react-DW5juQin.js +0 -59
- package/node_modules/package-json-from-dist/LICENSE.md +0 -63
- package/node_modules/package-json-from-dist/README.md +0 -110
- package/node_modules/package-json-from-dist/dist/commonjs/index.d.ts +0 -89
- package/node_modules/package-json-from-dist/dist/commonjs/index.d.ts.map +0 -1
- package/node_modules/package-json-from-dist/dist/commonjs/index.js +0 -134
- package/node_modules/package-json-from-dist/dist/commonjs/index.js.map +0 -1
- package/node_modules/package-json-from-dist/dist/commonjs/package.json +0 -3
- package/node_modules/package-json-from-dist/dist/esm/index.d.ts +0 -89
- package/node_modules/package-json-from-dist/dist/esm/index.d.ts.map +0 -1
- package/node_modules/package-json-from-dist/dist/esm/index.js +0 -129
- package/node_modules/package-json-from-dist/dist/esm/index.js.map +0 -1
- package/node_modules/package-json-from-dist/dist/esm/package.json +0 -3
- package/node_modules/package-json-from-dist/package.json +0 -68
- package/node_modules/path-key/index.d.ts +0 -40
- package/node_modules/path-key/index.js +0 -16
- package/node_modules/path-key/license +0 -9
- package/node_modules/path-key/package.json +0 -39
- package/node_modules/path-key/readme.md +0 -61
- package/node_modules/safe-buffer/LICENSE +0 -21
- package/node_modules/safe-buffer/README.md +0 -584
- package/node_modules/safe-buffer/index.d.ts +0 -187
- package/node_modules/safe-buffer/index.js +0 -65
- package/node_modules/safe-buffer/package.json +0 -51
- package/node_modules/shebang-command/index.js +0 -19
- package/node_modules/shebang-command/license +0 -9
- package/node_modules/shebang-command/package.json +0 -34
- package/node_modules/shebang-command/readme.md +0 -34
- package/node_modules/shebang-regex/index.d.ts +0 -22
- package/node_modules/shebang-regex/index.js +0 -2
- package/node_modules/shebang-regex/license +0 -9
- package/node_modules/shebang-regex/package.json +0 -35
- package/node_modules/shebang-regex/readme.md +0 -33
- package/node_modules/signal-exit/LICENSE.txt +0 -16
- package/node_modules/signal-exit/README.md +0 -74
- package/node_modules/signal-exit/dist/cjs/browser.d.ts +0 -12
- package/node_modules/signal-exit/dist/cjs/browser.d.ts.map +0 -1
- package/node_modules/signal-exit/dist/cjs/browser.js +0 -10
- package/node_modules/signal-exit/dist/cjs/browser.js.map +0 -1
- package/node_modules/signal-exit/dist/cjs/index.d.ts +0 -48
- package/node_modules/signal-exit/dist/cjs/index.d.ts.map +0 -1
- package/node_modules/signal-exit/dist/cjs/index.js +0 -279
- package/node_modules/signal-exit/dist/cjs/index.js.map +0 -1
- package/node_modules/signal-exit/dist/cjs/package.json +0 -3
- package/node_modules/signal-exit/dist/cjs/signals.d.ts +0 -29
- package/node_modules/signal-exit/dist/cjs/signals.d.ts.map +0 -1
- package/node_modules/signal-exit/dist/cjs/signals.js +0 -42
- package/node_modules/signal-exit/dist/cjs/signals.js.map +0 -1
- package/node_modules/signal-exit/dist/mjs/browser.d.ts +0 -12
- package/node_modules/signal-exit/dist/mjs/browser.d.ts.map +0 -1
- package/node_modules/signal-exit/dist/mjs/browser.js +0 -4
- package/node_modules/signal-exit/dist/mjs/browser.js.map +0 -1
- package/node_modules/signal-exit/dist/mjs/index.d.ts +0 -48
- package/node_modules/signal-exit/dist/mjs/index.d.ts.map +0 -1
- package/node_modules/signal-exit/dist/mjs/index.js +0 -275
- package/node_modules/signal-exit/dist/mjs/index.js.map +0 -1
- package/node_modules/signal-exit/dist/mjs/package.json +0 -3
- package/node_modules/signal-exit/dist/mjs/signals.d.ts +0 -29
- package/node_modules/signal-exit/dist/mjs/signals.d.ts.map +0 -1
- package/node_modules/signal-exit/dist/mjs/signals.js +0 -39
- package/node_modules/signal-exit/dist/mjs/signals.js.map +0 -1
- package/node_modules/signal-exit/package.json +0 -106
- package/node_modules/which/CHANGELOG.md +0 -166
- package/node_modules/which/LICENSE +0 -15
- package/node_modules/which/README.md +0 -54
- package/node_modules/which/bin/node-which +0 -52
- package/node_modules/which/package.json +0 -43
- package/node_modules/which/which.js +0 -125
- package/scripts/check-adapter-isolation.ts +0 -293
- /package/dist/services/{app → app-common}/app-compiler.d.ts +0 -0
- /package/dist/services/{app → app-common}/terminal-session-manager.d.ts +0 -0
- /package/dist/services/{backup-verify.d.ts → backup/backup-verify.d.ts} +0 -0
- /package/dist/services/{external-mounts.d.ts → files/external-mounts.d.ts} +0 -0
- /package/dist/services/{organize → files/organize}/applier.d.ts +0 -0
- /package/dist/services/{organize → files/organize}/rules.d.ts +0 -0
- /package/dist/services/{organize → files/organize}/scanner.d.ts +0 -0
- /package/dist/services/{organize → files/organize}/store.d.ts +0 -0
- /package/dist/services/{webdav → files/webdav}/xml-builder.d.ts +0 -0
- /package/dist/services/{webdav → files/webdav}/xml-builder.js +0 -0
- /package/dist/services/{app-passwords.d.ts → instances/passwords.d.ts} +0 -0
- /package/dist/services/{agent-apps → integrations/installable}/installers/registry-probe.d.ts +0 -0
- /package/dist/services/{agent-apps → integrations/installable}/installers/registry-probe.js +0 -0
- /package/dist/services/{runtime/mcp-shims → integrations/openclaw}/drive-shim.d.ts +0 -0
- /package/dist/services/{runtime/mcp-shims → integrations/openclaw}/mcporter-lite.d.ts +0 -0
- /package/dist/services/{plugin-installer.d.ts → setup/plugin-installer.d.ts} +0 -0
- /package/dist/services/{macos-launchd.d.ts → system/macos-launchd.d.ts} +0 -0
- /package/dist/services/{system-monitor.d.ts → system/system-monitor.d.ts} +0 -0
|
@@ -0,0 +1,541 @@
|
|
|
1
|
+
#!/usr/bin/env -S node --experimental-strip-types
|
|
2
|
+
/**
|
|
3
|
+
* check-integration-isolation — AppIntegration isolation checks.
|
|
4
|
+
*
|
|
5
|
+
* Two invariants:
|
|
6
|
+
*
|
|
7
|
+
* 1. Core framework files never import specific integration implementation
|
|
8
|
+
* modules such as OpenClaw/Hermes integrations or mcporter helpers.
|
|
9
|
+
* Framework code reaches integrations only through the integration
|
|
10
|
+
* registry/dispatch surface.
|
|
11
|
+
*
|
|
12
|
+
* 2. Fixture `instance.json` samples under
|
|
13
|
+
* `scripts/fixtures/instances/<name>/` satisfy the minimum meta
|
|
14
|
+
* contract: `id`, `name`, a fixture-local integration discriminator,
|
|
15
|
+
* and (for Hermes) the required `paths.integrationHome` /
|
|
16
|
+
* `paths.primaryConfig` / `paths.secretEnv` entries. Legacy fixtures whose
|
|
17
|
+
* name starts with
|
|
18
|
+
* `legacy-openclaw` must still resolve to integration kind `openclaw`
|
|
19
|
+
* through historical markers such as `openclaw_home`. This check is
|
|
20
|
+
* intentionally self-contained: runtime code no longer exposes a
|
|
21
|
+
* legacy marker classifier.
|
|
22
|
+
*
|
|
23
|
+
* Run via `npm run check:contracts`. Exits non-zero on violation.
|
|
24
|
+
*/
|
|
25
|
+
|
|
26
|
+
import { readFileSync, readdirSync, statSync } from "node:fs";
|
|
27
|
+
import { resolve } from "node:path";
|
|
28
|
+
|
|
29
|
+
const REPO_ROOT = resolve(import.meta.dirname ?? ".", "..");
|
|
30
|
+
|
|
31
|
+
/**
|
|
32
|
+
* Files that must not import any specific integration directly. This keeps
|
|
33
|
+
* generic framework code from depending on OpenClaw/Hermes implementation
|
|
34
|
+
* details during migration toward docs/core-app-architecture.md.
|
|
35
|
+
*/
|
|
36
|
+
const CORE_FILES = [
|
|
37
|
+
"src/services/app-common/execution-owner.ts",
|
|
38
|
+
"src/services/app-common/integration-refs.ts",
|
|
39
|
+
"src/services/instances/manager.ts",
|
|
40
|
+
"src/services/runtime/drivers/nomad.ts",
|
|
41
|
+
"src/services/setup/setup-manager.ts",
|
|
42
|
+
"src/services/backup/backup-manager.ts",
|
|
43
|
+
"src/services/connections/apply.ts",
|
|
44
|
+
"src/services/connections/transactor.ts",
|
|
45
|
+
"src/services/llm-proxy/index.ts",
|
|
46
|
+
"src/routes/instances.ts",
|
|
47
|
+
"src/routes/setup.ts",
|
|
48
|
+
"src/server.ts",
|
|
49
|
+
] as const;
|
|
50
|
+
|
|
51
|
+
/**
|
|
52
|
+
* Regexes for forbidden integration implementation imports. Covers both
|
|
53
|
+
* static imports and dynamic `import()`. Per-integration route modules are
|
|
54
|
+
* not blocked here: they are HTTP registration surfaces, not workload/runtime
|
|
55
|
+
* implementation details.
|
|
56
|
+
*/
|
|
57
|
+
const FORBIDDEN_IMPORT_PATTERNS = [
|
|
58
|
+
/from\s+["'][^"']*\/integrations\/(?:openclaw|hermes|custom)\/(?:integration|mcporter)(?:\.[jt]s)?["']/g,
|
|
59
|
+
/import\s*\(\s*["'][^"']*\/integrations\/(?:openclaw|hermes|custom)\/(?:integration|mcporter)(?:\.[jt]s)?["']\s*\)/g,
|
|
60
|
+
];
|
|
61
|
+
|
|
62
|
+
const CONNECTION_TRANSACTOR_PRIVATE_LAYOUT_PATTERNS: Array<{
|
|
63
|
+
pattern: RegExp;
|
|
64
|
+
description: string;
|
|
65
|
+
}> = [
|
|
66
|
+
{ pattern: /openclaw-home|openclaw\.json|mcporter\.json/i, description: "OpenClaw private layout" },
|
|
67
|
+
{ pattern: /agent-home|config\.yaml/i, description: "Hermes private layout" },
|
|
68
|
+
];
|
|
69
|
+
|
|
70
|
+
const INSTANCE_ROUTE_PRIVATE_SURFACE_PATTERNS: Array<{
|
|
71
|
+
pattern: RegExp;
|
|
72
|
+
description: string;
|
|
73
|
+
}> = [
|
|
74
|
+
{
|
|
75
|
+
pattern: /browserless|browser-allowlist|browser-allow-all|browser-policy/i,
|
|
76
|
+
description: "Browserless/OpenClaw browser routes belong in their owning integration/app route module",
|
|
77
|
+
},
|
|
78
|
+
];
|
|
79
|
+
|
|
80
|
+
const FORBIDDEN_PATHS: Array<{ path: string; rule: string }> = [
|
|
81
|
+
{
|
|
82
|
+
path: "src/services/integrations/browserless",
|
|
83
|
+
rule: "Browserless is a plain AppSpec app; app-owned HTTP code belongs under src/services/app-modules/browserless",
|
|
84
|
+
},
|
|
85
|
+
{
|
|
86
|
+
path: "src/services/integrations/browser-policy.ts",
|
|
87
|
+
rule: "Browser policy is capability-level shared behavior; keep it under src/services/capabilities/browser-policy.ts",
|
|
88
|
+
},
|
|
89
|
+
];
|
|
90
|
+
|
|
91
|
+
const APP_MODULES_ROOT = "src/services/app-modules";
|
|
92
|
+
const APP_MODULE_FORBIDDEN_IMPORT_PATTERNS = [
|
|
93
|
+
/from\s+["'][^"']*\/integrations\/(?:openclaw|hermes|anythingllm|jishukb|custom|installable)\/[^"']+["']/g,
|
|
94
|
+
/import\s*\(\s*["'][^"']*\/integrations\/(?:openclaw|hermes|anythingllm|jishukb|custom|installable)\/[^"']+["']\s*\)/g,
|
|
95
|
+
];
|
|
96
|
+
|
|
97
|
+
const APP_MODULE_FILE_PATTERNS: Array<{ file: string; pattern: RegExp; rule: string }> = [
|
|
98
|
+
{
|
|
99
|
+
file: "src/services/app-modules/browserless/routes.ts",
|
|
100
|
+
pattern: /\.openclaw\/agents\/main\/sessions\/sessions\.json/,
|
|
101
|
+
rule: "browserless-private-openclaw-path: Browserless route must not hardcode OpenClaw private session paths",
|
|
102
|
+
},
|
|
103
|
+
{
|
|
104
|
+
file: "src/services/app-modules/browserless/routes.ts",
|
|
105
|
+
pattern: /getIntegration\(\s*["']openclaw["']\s*\)/,
|
|
106
|
+
rule: "browserless-fixed-consumer-kind: Browserless route must not branch on a fixed OpenClaw integration kind",
|
|
107
|
+
},
|
|
108
|
+
];
|
|
109
|
+
|
|
110
|
+
/**
|
|
111
|
+
* Literal strings that indicate kind-specific bleed-through into
|
|
112
|
+
* framework files. These are advisory only for now: existing OpenClaw
|
|
113
|
+
* legacy code may still contain OPENCLAW_HOME env references etc. We log
|
|
114
|
+
* them but don't fail the build — the physical migration cleans them up
|
|
115
|
+
* in a follow-up PR. When MIGRATION_STRICT=1 is set, they become errors.
|
|
116
|
+
*/
|
|
117
|
+
const KIND_LITERAL_PATTERNS: Array<{ pattern: RegExp; description: string }> = [
|
|
118
|
+
{
|
|
119
|
+
pattern: /JOB_PREFIX\s*=\s*["']openclaw-/,
|
|
120
|
+
description: `JOB_PREFIX literal "openclaw-" — use integration.nomadJobPrefix`,
|
|
121
|
+
},
|
|
122
|
+
{
|
|
123
|
+
pattern: /OPENCLAW_HOME|OPENCLAW_INSTANCE_ID|OPENCLAW_GATEWAY_PORT/,
|
|
124
|
+
description: `OpenClaw-specific env var literal — should live in OpenClawIntegration`,
|
|
125
|
+
},
|
|
126
|
+
{
|
|
127
|
+
pattern: /isHermesInstance\s*\(/,
|
|
128
|
+
description: `isHermesInstance() — runtime-specific branch, should dispatch via getIntegration`,
|
|
129
|
+
},
|
|
130
|
+
{
|
|
131
|
+
pattern: /agentType\s*===\s*["']hermes["']|agentType\s*===\s*["']openclaw["']/,
|
|
132
|
+
description: `agentType literal comparison — dispatch through integration metadata instead`,
|
|
133
|
+
},
|
|
134
|
+
];
|
|
135
|
+
|
|
136
|
+
const STRICT = process.env.MIGRATION_STRICT === "1";
|
|
137
|
+
|
|
138
|
+
type Violation = {
|
|
139
|
+
file: string;
|
|
140
|
+
line: number;
|
|
141
|
+
column: number;
|
|
142
|
+
text: string;
|
|
143
|
+
rule: string;
|
|
144
|
+
};
|
|
145
|
+
|
|
146
|
+
function isCommentLine(lineText: string): boolean {
|
|
147
|
+
const t = lineText.trimStart();
|
|
148
|
+
return t.startsWith("//") || t.startsWith("*") || t.startsWith("/*");
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
function findViolations(filepath: string, content: string): Violation[] {
|
|
152
|
+
const violations: Violation[] = [];
|
|
153
|
+
|
|
154
|
+
// 1. Forbidden integration implementation imports (HARD errors)
|
|
155
|
+
for (const pattern of FORBIDDEN_IMPORT_PATTERNS) {
|
|
156
|
+
let match: RegExpExecArray | null;
|
|
157
|
+
const re = new RegExp(pattern.source, "g");
|
|
158
|
+
while ((match = re.exec(content)) !== null) {
|
|
159
|
+
const before = content.slice(0, match.index);
|
|
160
|
+
const line = before.split("\n").length;
|
|
161
|
+
const column = match.index - before.lastIndexOf("\n");
|
|
162
|
+
violations.push({
|
|
163
|
+
file: filepath,
|
|
164
|
+
line,
|
|
165
|
+
column,
|
|
166
|
+
text: match[0],
|
|
167
|
+
rule: "integration-import-forbidden",
|
|
168
|
+
});
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
if (filepath === "src/services/connections/transactor.ts") {
|
|
173
|
+
const lines = content.split("\n");
|
|
174
|
+
for (let i = 0; i < lines.length; i++) {
|
|
175
|
+
for (const { pattern, description } of CONNECTION_TRANSACTOR_PRIVATE_LAYOUT_PATTERNS) {
|
|
176
|
+
if (!pattern.test(lines[i])) continue;
|
|
177
|
+
violations.push({
|
|
178
|
+
file: filepath,
|
|
179
|
+
line: i + 1,
|
|
180
|
+
column: 1,
|
|
181
|
+
text: lines[i].trim().slice(0, 120),
|
|
182
|
+
rule: `connection-private-layout: ${description} belongs in its integration hook`,
|
|
183
|
+
});
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
if (filepath === "src/routes/instances.ts") {
|
|
189
|
+
const lines = content.split("\n");
|
|
190
|
+
for (let i = 0; i < lines.length; i++) {
|
|
191
|
+
const lineText = lines[i];
|
|
192
|
+
if (isCommentLine(lineText)) continue;
|
|
193
|
+
for (const { pattern, description } of INSTANCE_ROUTE_PRIVATE_SURFACE_PATTERNS) {
|
|
194
|
+
if (!pattern.test(lineText)) continue;
|
|
195
|
+
violations.push({
|
|
196
|
+
file: filepath,
|
|
197
|
+
line: i + 1,
|
|
198
|
+
column: 1,
|
|
199
|
+
text: lineText.trim().slice(0, 120),
|
|
200
|
+
rule: `instance-route-private-surface: ${description}`,
|
|
201
|
+
});
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
// 2. Kind-specific literals (SOFT warnings unless MIGRATION_STRICT=1).
|
|
207
|
+
// Comment lines are skipped because docstrings are not actual code
|
|
208
|
+
// bleed-through.
|
|
209
|
+
if (STRICT) {
|
|
210
|
+
const lines = content.split("\n");
|
|
211
|
+
for (let i = 0; i < lines.length; i++) {
|
|
212
|
+
const lineText = lines[i];
|
|
213
|
+
if (isCommentLine(lineText)) continue;
|
|
214
|
+
for (const { pattern, description } of KIND_LITERAL_PATTERNS) {
|
|
215
|
+
if (pattern.test(lineText)) {
|
|
216
|
+
violations.push({
|
|
217
|
+
file: filepath,
|
|
218
|
+
line: i + 1,
|
|
219
|
+
column: 1,
|
|
220
|
+
text: lineText.trim().slice(0, 120),
|
|
221
|
+
rule: `kind-literal: ${description}`,
|
|
222
|
+
});
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
|
|
228
|
+
return violations;
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
function walkFiles(relRoot: string): string[] {
|
|
232
|
+
const absRoot = resolve(REPO_ROOT, relRoot);
|
|
233
|
+
const out: string[] = [];
|
|
234
|
+
const visit = (relDir: string): void => {
|
|
235
|
+
const absDir = resolve(REPO_ROOT, relDir);
|
|
236
|
+
let entries: string[];
|
|
237
|
+
try {
|
|
238
|
+
entries = readdirSync(absDir);
|
|
239
|
+
} catch {
|
|
240
|
+
return;
|
|
241
|
+
}
|
|
242
|
+
for (const entry of entries) {
|
|
243
|
+
const relPath = resolve(absDir, entry).replace(`${REPO_ROOT}/`, "");
|
|
244
|
+
try {
|
|
245
|
+
const stats = statSync(resolve(REPO_ROOT, relPath));
|
|
246
|
+
if (stats.isDirectory()) {
|
|
247
|
+
visit(relPath);
|
|
248
|
+
continue;
|
|
249
|
+
}
|
|
250
|
+
if (stats.isFile()) out.push(relPath);
|
|
251
|
+
} catch {
|
|
252
|
+
continue;
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
};
|
|
256
|
+
try {
|
|
257
|
+
if (!statSync(absRoot).isDirectory()) return [];
|
|
258
|
+
} catch {
|
|
259
|
+
return [];
|
|
260
|
+
}
|
|
261
|
+
visit(relRoot);
|
|
262
|
+
return out;
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
// ── Fixture schema checks (plan §30.3) ───────────────────────────────
|
|
266
|
+
//
|
|
267
|
+
// Keep the schema rules inline: we only validate a handful of fields and
|
|
268
|
+
// pulling in ajv for a single static script adds disproportionate churn.
|
|
269
|
+
// Keep the historical fixture classifier inline:
|
|
270
|
+
// - every meta must carry `id` / `name`
|
|
271
|
+
// - declared `integrations[].kind` wins; otherwise fixture checks fall
|
|
272
|
+
// back to legacy markers (openclaw_home, hermes_home, app_type, ...)
|
|
273
|
+
// - Hermes fixtures must declare `paths.integrationHome` +
|
|
274
|
+
// `paths.primaryConfig`
|
|
275
|
+
// - fixtures named `legacy-openclaw*` must still resolve to
|
|
276
|
+
// integration kind `openclaw` via a legacy marker.
|
|
277
|
+
|
|
278
|
+
type FixtureViolation = { fixture: string; rule: string; detail: string };
|
|
279
|
+
|
|
280
|
+
function nonEmpty(v: unknown): string {
|
|
281
|
+
return typeof v === "string" ? v.trim() : "";
|
|
282
|
+
}
|
|
283
|
+
|
|
284
|
+
function runtimeEnv(meta: Record<string, unknown>): Record<string, unknown> {
|
|
285
|
+
const env = (meta.runtime as Record<string, unknown> | undefined)?.env;
|
|
286
|
+
return env && typeof env === "object" && !Array.isArray(env)
|
|
287
|
+
? (env as Record<string, unknown>)
|
|
288
|
+
: {};
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
/**
|
|
292
|
+
* Self-contained classifier for historical fixture samples. Runtime code
|
|
293
|
+
* must not depend on these legacy markers after Step 13.
|
|
294
|
+
*/
|
|
295
|
+
function resolveFixtureIntegrationKind(meta: Record<string, unknown>): string | null {
|
|
296
|
+
const canonical = nonEmpty(((meta.integrations as Array<Record<string, unknown>> | undefined)?.[0])?.kind);
|
|
297
|
+
if (canonical) return canonical;
|
|
298
|
+
const derived = nonEmpty(meta.integrationKind);
|
|
299
|
+
if (derived) return derived;
|
|
300
|
+
const declared = nonEmpty(meta.agentType);
|
|
301
|
+
if (declared) return declared;
|
|
302
|
+
|
|
303
|
+
const appType = nonEmpty(meta.app_type);
|
|
304
|
+
if (appType === "hermes-agent") return "hermes";
|
|
305
|
+
if (appType === "custom") return "custom";
|
|
306
|
+
if (appType === "openclaw") return "openclaw";
|
|
307
|
+
if (appType === "ollama") return null;
|
|
308
|
+
|
|
309
|
+
const env = runtimeEnv(meta);
|
|
310
|
+
if (nonEmpty(meta.ollama_home) || nonEmpty(env.OLLAMA_HOST) || nonEmpty(env.OLLAMA_MODELS)) {
|
|
311
|
+
return null;
|
|
312
|
+
}
|
|
313
|
+
if (nonEmpty(meta.app_spec_ref)) return "custom";
|
|
314
|
+
if (meta.definition && !meta.agent) return "custom";
|
|
315
|
+
if (
|
|
316
|
+
nonEmpty(meta.hermes_home)
|
|
317
|
+
|| nonEmpty(meta.hermes_env_file)
|
|
318
|
+
|| nonEmpty(env.HERMES_HOME)
|
|
319
|
+
|| nonEmpty(env.HERMES_WEBUI_PORT)
|
|
320
|
+
|| nonEmpty(env.JISHUSHELL_HERMES_SOURCE_REF)
|
|
321
|
+
) return "hermes";
|
|
322
|
+
if (
|
|
323
|
+
nonEmpty(meta.openclaw_home)
|
|
324
|
+
|| nonEmpty(env.OPENCLAW_HOME)
|
|
325
|
+
|| nonEmpty(env.OPENCLAW_CONFIG_PATH)
|
|
326
|
+
|| nonEmpty(env.OPENCLAW_GATEWAY_PORT)
|
|
327
|
+
) return "openclaw";
|
|
328
|
+
return null;
|
|
329
|
+
}
|
|
330
|
+
|
|
331
|
+
function checkFixture(fixtureName: string, meta: Record<string, unknown>): FixtureViolation[] {
|
|
332
|
+
const out: FixtureViolation[] = [];
|
|
333
|
+
const integrationKind = resolveFixtureIntegrationKind(meta);
|
|
334
|
+
if (typeof meta.id !== "string" || !meta.id) {
|
|
335
|
+
out.push({ fixture: fixtureName, rule: "missing-id", detail: "instance.json must carry a non-empty string id" });
|
|
336
|
+
}
|
|
337
|
+
if (typeof meta.name !== "string" || !meta.name) {
|
|
338
|
+
out.push({ fixture: fixtureName, rule: "missing-name", detail: "instance.json must carry a non-empty string name" });
|
|
339
|
+
}
|
|
340
|
+
if (integrationKind === "hermes") {
|
|
341
|
+
const paths = (meta.paths ?? {}) as Record<string, unknown>;
|
|
342
|
+
const integrationHome = typeof paths.integrationHome === "string" && paths.integrationHome
|
|
343
|
+
? paths.integrationHome
|
|
344
|
+
: typeof paths.agentHome === "string" && paths.agentHome
|
|
345
|
+
? paths.agentHome
|
|
346
|
+
: "";
|
|
347
|
+
if (!integrationHome) {
|
|
348
|
+
out.push({
|
|
349
|
+
fixture: fixtureName,
|
|
350
|
+
rule: "hermes-paths-integrationHome",
|
|
351
|
+
detail: "hermes instance.json requires paths.integrationHome",
|
|
352
|
+
});
|
|
353
|
+
}
|
|
354
|
+
for (const key of ["primaryConfig", "secretEnv"] as const) {
|
|
355
|
+
if (typeof paths[key] !== "string" || !paths[key]) {
|
|
356
|
+
out.push({
|
|
357
|
+
fixture: fixtureName,
|
|
358
|
+
rule: `hermes-paths-${key}`,
|
|
359
|
+
detail: `hermes instance.json requires paths.${key}`,
|
|
360
|
+
});
|
|
361
|
+
}
|
|
362
|
+
}
|
|
363
|
+
}
|
|
364
|
+
if (fixtureName.startsWith("legacy-openclaw") && integrationKind !== "openclaw") {
|
|
365
|
+
out.push({
|
|
366
|
+
fixture: fixtureName,
|
|
367
|
+
rule: "legacy-backfill",
|
|
368
|
+
detail: `legacy fixture must resolve to integration kind "openclaw" via legacy markers, got ${integrationKind === null ? "null" : `"${integrationKind}"`}`,
|
|
369
|
+
});
|
|
370
|
+
}
|
|
371
|
+
return out;
|
|
372
|
+
}
|
|
373
|
+
|
|
374
|
+
function loadFixtures(): FixtureViolation[] {
|
|
375
|
+
const fixturesRoot = resolve(REPO_ROOT, "scripts/fixtures/instances");
|
|
376
|
+
let entries: string[];
|
|
377
|
+
try {
|
|
378
|
+
entries = readdirSync(fixturesRoot);
|
|
379
|
+
} catch {
|
|
380
|
+
return []; // directory optional during early migrations
|
|
381
|
+
}
|
|
382
|
+
const violations: FixtureViolation[] = [];
|
|
383
|
+
for (const entry of entries) {
|
|
384
|
+
const fullPath = resolve(fixturesRoot, entry);
|
|
385
|
+
try {
|
|
386
|
+
if (!statSync(fullPath).isDirectory()) continue;
|
|
387
|
+
} catch {
|
|
388
|
+
continue;
|
|
389
|
+
}
|
|
390
|
+
const metaPath = resolve(fullPath, "instance.json");
|
|
391
|
+
let raw: string;
|
|
392
|
+
try {
|
|
393
|
+
raw = readFileSync(metaPath, "utf-8");
|
|
394
|
+
} catch {
|
|
395
|
+
violations.push({ fixture: entry, rule: "missing-instance-json", detail: metaPath });
|
|
396
|
+
continue;
|
|
397
|
+
}
|
|
398
|
+
try {
|
|
399
|
+
const meta = JSON.parse(raw) as Record<string, unknown>;
|
|
400
|
+
violations.push(...checkFixture(entry, meta));
|
|
401
|
+
} catch (e: any) {
|
|
402
|
+
violations.push({ fixture: entry, rule: "invalid-json", detail: e?.message ?? String(e) });
|
|
403
|
+
}
|
|
404
|
+
}
|
|
405
|
+
return violations;
|
|
406
|
+
}
|
|
407
|
+
|
|
408
|
+
function main(): void {
|
|
409
|
+
const allViolations: Violation[] = [];
|
|
410
|
+
const softFindings: Array<{ file: string; line: number; text: string; description: string }> = [];
|
|
411
|
+
|
|
412
|
+
for (const item of FORBIDDEN_PATHS) {
|
|
413
|
+
const abs = resolve(REPO_ROOT, item.path);
|
|
414
|
+
try {
|
|
415
|
+
statSync(abs);
|
|
416
|
+
allViolations.push({
|
|
417
|
+
file: item.path,
|
|
418
|
+
line: 1,
|
|
419
|
+
column: 1,
|
|
420
|
+
text: item.path,
|
|
421
|
+
rule: `forbidden-path: ${item.rule}`,
|
|
422
|
+
});
|
|
423
|
+
} catch {
|
|
424
|
+
// Expected: forbidden path does not exist.
|
|
425
|
+
}
|
|
426
|
+
}
|
|
427
|
+
|
|
428
|
+
for (const relPath of CORE_FILES) {
|
|
429
|
+
const abs = resolve(REPO_ROOT, relPath);
|
|
430
|
+
let content: string;
|
|
431
|
+
try {
|
|
432
|
+
content = readFileSync(abs, "utf-8");
|
|
433
|
+
} catch {
|
|
434
|
+
console.warn(`[check-integration-isolation] skip (not found): ${relPath}`);
|
|
435
|
+
continue;
|
|
436
|
+
}
|
|
437
|
+
allViolations.push(...findViolations(relPath, content));
|
|
438
|
+
|
|
439
|
+
// Collect soft findings separately so non-strict runs can still report them.
|
|
440
|
+
if (!STRICT) {
|
|
441
|
+
const lines = content.split("\n");
|
|
442
|
+
for (let i = 0; i < lines.length; i++) {
|
|
443
|
+
const lineText = lines[i];
|
|
444
|
+
if (isCommentLine(lineText)) continue;
|
|
445
|
+
for (const { pattern, description } of KIND_LITERAL_PATTERNS) {
|
|
446
|
+
if (pattern.test(lineText)) {
|
|
447
|
+
softFindings.push({
|
|
448
|
+
file: relPath,
|
|
449
|
+
line: i + 1,
|
|
450
|
+
text: lineText.trim().slice(0, 120),
|
|
451
|
+
description,
|
|
452
|
+
});
|
|
453
|
+
}
|
|
454
|
+
}
|
|
455
|
+
}
|
|
456
|
+
}
|
|
457
|
+
}
|
|
458
|
+
|
|
459
|
+
for (const relPath of walkFiles(APP_MODULES_ROOT)) {
|
|
460
|
+
if (!/\.[cm]?[jt]s$/.test(relPath)) continue;
|
|
461
|
+
let content: string;
|
|
462
|
+
try {
|
|
463
|
+
content = readFileSync(resolve(REPO_ROOT, relPath), "utf-8");
|
|
464
|
+
} catch {
|
|
465
|
+
continue;
|
|
466
|
+
}
|
|
467
|
+
|
|
468
|
+
for (const pattern of APP_MODULE_FORBIDDEN_IMPORT_PATTERNS) {
|
|
469
|
+
let match: RegExpExecArray | null;
|
|
470
|
+
const re = new RegExp(pattern.source, "g");
|
|
471
|
+
while ((match = re.exec(content)) !== null) {
|
|
472
|
+
const before = content.slice(0, match.index);
|
|
473
|
+
const line = before.split("\n").length;
|
|
474
|
+
const column = match.index - before.lastIndexOf("\n");
|
|
475
|
+
allViolations.push({
|
|
476
|
+
file: relPath,
|
|
477
|
+
line,
|
|
478
|
+
column,
|
|
479
|
+
text: match[0],
|
|
480
|
+
rule: "app-module-integration-import-forbidden",
|
|
481
|
+
});
|
|
482
|
+
}
|
|
483
|
+
}
|
|
484
|
+
}
|
|
485
|
+
|
|
486
|
+
for (const { file, pattern, rule } of APP_MODULE_FILE_PATTERNS) {
|
|
487
|
+
let content: string;
|
|
488
|
+
try {
|
|
489
|
+
content = readFileSync(resolve(REPO_ROOT, file), "utf-8");
|
|
490
|
+
} catch {
|
|
491
|
+
continue;
|
|
492
|
+
}
|
|
493
|
+
const lines = content.split("\n");
|
|
494
|
+
for (let i = 0; i < lines.length; i++) {
|
|
495
|
+
if (!pattern.test(lines[i])) continue;
|
|
496
|
+
allViolations.push({
|
|
497
|
+
file,
|
|
498
|
+
line: i + 1,
|
|
499
|
+
column: 1,
|
|
500
|
+
text: lines[i].trim().slice(0, 160),
|
|
501
|
+
rule,
|
|
502
|
+
});
|
|
503
|
+
}
|
|
504
|
+
}
|
|
505
|
+
|
|
506
|
+
const fixtureViolations = loadFixtures();
|
|
507
|
+
|
|
508
|
+
if (allViolations.length === 0 && softFindings.length === 0 && fixtureViolations.length === 0) {
|
|
509
|
+
console.log("[check-integration-isolation] OK — core files are fully decoupled from specific integrations");
|
|
510
|
+
process.exit(0);
|
|
511
|
+
}
|
|
512
|
+
|
|
513
|
+
if (allViolations.length > 0) {
|
|
514
|
+
console.error(`\n[check-integration-isolation] ${allViolations.length} HARD violation(s):\n`);
|
|
515
|
+
for (const v of allViolations) {
|
|
516
|
+
console.error(` ${v.file}:${v.line}:${v.column} [${v.rule}]`);
|
|
517
|
+
console.error(` ${v.text}`);
|
|
518
|
+
}
|
|
519
|
+
}
|
|
520
|
+
|
|
521
|
+
if (fixtureViolations.length > 0) {
|
|
522
|
+
console.error(`\n[check-integration-isolation] ${fixtureViolations.length} fixture violation(s):\n`);
|
|
523
|
+
for (const v of fixtureViolations) {
|
|
524
|
+
console.error(` fixtures/${v.fixture} [${v.rule}] ${v.detail}`);
|
|
525
|
+
}
|
|
526
|
+
}
|
|
527
|
+
|
|
528
|
+
if (softFindings.length > 0) {
|
|
529
|
+
console.warn(
|
|
530
|
+
`\n[check-integration-isolation] ${softFindings.length} soft finding(s) (remaining framework bleed-through — migrate in follow-up PRs; run with MIGRATION_STRICT=1 to fail on these):\n`,
|
|
531
|
+
);
|
|
532
|
+
for (const f of softFindings) {
|
|
533
|
+
console.warn(` ${f.file}:${f.line} ${f.description}`);
|
|
534
|
+
console.warn(` ${f.text}`);
|
|
535
|
+
}
|
|
536
|
+
}
|
|
537
|
+
|
|
538
|
+
process.exit(allViolations.length > 0 || fixtureViolations.length > 0 ? 1 : 0);
|
|
539
|
+
}
|
|
540
|
+
|
|
541
|
+
main();
|
|
@@ -9,8 +9,8 @@
|
|
|
9
9
|
* --base: CI_MERGE_REQUEST_TARGET_BRANCH_NAME (MR) or origin/main (fallback)
|
|
10
10
|
*
|
|
11
11
|
* Exit codes:
|
|
12
|
-
* 0 — all new files have tests
|
|
13
|
-
* 1 — some new files are missing tests
|
|
12
|
+
* 0 — all new files have tests, no new files, or warning-mode findings
|
|
13
|
+
* 1 — strict mode only: some new files are missing tests
|
|
14
14
|
*/
|
|
15
15
|
|
|
16
16
|
import { execSync } from "node:child_process";
|
|
@@ -51,6 +51,9 @@ const EXEMPT_PATH_PREFIXES = [
|
|
|
51
51
|
/** Directories where backend tests live (searched for basename match). */
|
|
52
52
|
const BACKEND_TEST_DIRS = ["tests/unit", "tests/integration"];
|
|
53
53
|
|
|
54
|
+
/** Warning by default; set CHECK_NEW_FILE_TESTS_STRICT=1 to fail on findings. */
|
|
55
|
+
const STRICT = process.env.CHECK_NEW_FILE_TESTS_STRICT === "1";
|
|
56
|
+
|
|
54
57
|
// ── Helpers ────────────────────────────────────────────────────────────
|
|
55
58
|
|
|
56
59
|
function git(cmd) {
|
|
@@ -188,4 +191,9 @@ console.log(
|
|
|
188
191
|
"See docs/testing.md for testing conventions.\n",
|
|
189
192
|
);
|
|
190
193
|
|
|
191
|
-
|
|
194
|
+
if (STRICT) {
|
|
195
|
+
process.exit(1);
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
console.log("Warning mode: findings reported but not blocking CI. Set CHECK_NEW_FILE_TESTS_STRICT=1 to fail.");
|
|
199
|
+
process.exit(0);
|
|
@@ -89,7 +89,11 @@ violations.push(
|
|
|
89
89
|
|
|
90
90
|
violations.push(
|
|
91
91
|
...serviceFiles
|
|
92
|
-
.filter((file) =>
|
|
92
|
+
.filter((file) =>
|
|
93
|
+
!adminFiles.includes(file)
|
|
94
|
+
&& !runtimeFiles.includes(file)
|
|
95
|
+
&& !file.endsWith("/routes.ts"),
|
|
96
|
+
)
|
|
93
97
|
.flatMap((file) =>
|
|
94
98
|
lineViolations(file, [
|
|
95
99
|
{ pattern: /from\s+["'][^"']*routes\//, message: "service must not import routes" },
|
|
@@ -107,13 +111,24 @@ violations.push(
|
|
|
107
111
|
),
|
|
108
112
|
);
|
|
109
113
|
|
|
114
|
+
for (const file of llmProxyFiles) {
|
|
115
|
+
const path = rel(file);
|
|
116
|
+
const text = readFileSync(file, "utf8");
|
|
117
|
+
if (/panel\.json/.test(text)) {
|
|
118
|
+
violations.push(`${path} reads legacy panel.json; only legacy-migrator may import Panel provider settings`);
|
|
119
|
+
}
|
|
120
|
+
if (/raw\.providerId/.test(text)) {
|
|
121
|
+
violations.push(`${path} accepts legacy providerId as a canonical provider id; move that conversion into legacy-migrator`);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
|
|
110
125
|
violations.push(
|
|
111
126
|
...runtimeFiles.flatMap((file) =>
|
|
112
127
|
lineViolations(file, [
|
|
113
128
|
{ pattern: /from\s+["'][^"']*routes\//, message: "runtime service must not import routes" },
|
|
114
|
-
{ pattern: /from\s+["'][^"']*openclaw-routes(\.js|\.ts)?["']/, message: "runtime service must not import route
|
|
129
|
+
{ pattern: /from\s+["'][^"']*(openclaw-routes|integrations\/openclaw\/routes)(\.js|\.ts)?["']/, message: "runtime service must not import integration route modules" },
|
|
115
130
|
{ pattern: /import\s*\(\s*["'][^"']*routes\//, message: "runtime service must not import routes" },
|
|
116
|
-
{ pattern: /import\s*\(\s*["'][^"']*openclaw-routes(\.js|\.ts)?["']/, message: "runtime service must not import route
|
|
131
|
+
{ pattern: /import\s*\(\s*["'][^"']*(openclaw-routes|integrations\/openclaw\/routes)(\.js|\.ts)?["']/, message: "runtime service must not import integration route modules" },
|
|
117
132
|
]),
|
|
118
133
|
),
|
|
119
134
|
);
|
|
@@ -171,14 +186,46 @@ if (rootPackage.name !== "jishushell") {
|
|
|
171
186
|
if (rootPackage.bin?.jishushell !== "./dist/cli.js") {
|
|
172
187
|
violations.push("package.json bin must expose the CLI command as jishushell -> ./dist/cli.js");
|
|
173
188
|
}
|
|
174
|
-
|
|
175
|
-
|
|
189
|
+
const allowedRootExports = new Set(["./core", "./config", "./auth", "./types", "./constants"]);
|
|
190
|
+
for (const exportKey of Object.keys(rootPackage.exports ?? {})) {
|
|
191
|
+
if (!allowedRootExports.has(exportKey)) {
|
|
192
|
+
violations.push(
|
|
193
|
+
`package.json exports ${exportKey}; package exports must stay at product-level entry points and keep services/utils internal`,
|
|
194
|
+
);
|
|
195
|
+
}
|
|
196
|
+
if (exportKey.startsWith("./services/") || exportKey.startsWith("./utils/")) {
|
|
197
|
+
violations.push(`package.json exports internal module ${exportKey}; use ./core or a public HTTP/CLI API instead`);
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
for (const exportKey of allowedRootExports) {
|
|
201
|
+
if (!rootPackage.exports?.[exportKey]) {
|
|
202
|
+
violations.push(`package.json exports must include product-level entry ${exportKey}`);
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
const rootPanelDep = rootPackage.dependencies?.["jishushell-panel"];
|
|
206
|
+
const rootOptionalPanelDep = rootPackage.optionalDependencies?.["jishushell-panel"];
|
|
207
|
+
const rootPanelBundled =
|
|
208
|
+
rootPackage.bundleDependencies?.includes("jishushell-panel")
|
|
209
|
+
|| rootPackage.bundledDependencies?.includes("jishushell-panel");
|
|
210
|
+
const rootGuiBin = rootPackage.bin?.["jishushell-gui"];
|
|
211
|
+
|
|
212
|
+
if (rootGuiBin) {
|
|
213
|
+
violations.push("package.json must not expose jishushell-gui in the source manifest; scripts/pack-with-gui.mjs injects it only for GUI release tarballs");
|
|
214
|
+
}
|
|
215
|
+
if (rootPanelDep) {
|
|
216
|
+
violations.push("package.json must not depend on jishushell-panel in the source manifest; GUI releases consume a prebuilt dependencies/ tarball through scripts/pack-with-gui.mjs");
|
|
217
|
+
}
|
|
218
|
+
if (rootOptionalPanelDep) {
|
|
219
|
+
violations.push("package.json must not place jishushell-panel under optionalDependencies; the source manifest must stay Core/CLI-only");
|
|
176
220
|
}
|
|
177
|
-
if (
|
|
178
|
-
violations.push("
|
|
221
|
+
if (rootPanelBundled) {
|
|
222
|
+
violations.push("package.json must not bundle jishushell-panel in the source manifest; GUI release packaging owns that composition");
|
|
179
223
|
}
|
|
180
|
-
if (rootPackage.
|
|
181
|
-
violations.push("
|
|
224
|
+
if (rootPackage.scripts?.["release:pack"] !== "npm run build:pack:gui") {
|
|
225
|
+
violations.push("package.json release:pack must build the final GUI release tarball via npm run build:pack:gui");
|
|
226
|
+
}
|
|
227
|
+
if (rootPackage.scripts?.["build:pack:gui"] !== "npm run build && node scripts/pack-with-gui.mjs") {
|
|
228
|
+
violations.push("package.json build:pack:gui must use scripts/pack-with-gui.mjs to inject the prebuilt Panel tarball");
|
|
182
229
|
}
|
|
183
230
|
if (panelPackage) {
|
|
184
231
|
if (panelPackage.name !== "jishushell-panel") {
|
|
@@ -224,6 +271,9 @@ for (const fileEntry of rootPackage.files ?? []) {
|
|
|
224
271
|
if (fileEntry === "vendor/" || fileEntry === "build/") {
|
|
225
272
|
violations.push(`package.json files includes ${fileEntry}; Core package must not ship vendored Panel release state`);
|
|
226
273
|
}
|
|
274
|
+
if (/^dependencies\/jishushell-panel(?:[-.].*)?\.tgz$/.test(fileEntry)) {
|
|
275
|
+
violations.push(`package.json files includes ${fileEntry}; scripts/pack-with-gui.mjs adds the selected Panel tarball only for GUI release packaging`);
|
|
276
|
+
}
|
|
227
277
|
}
|
|
228
278
|
for (const relativePath of [
|
|
229
279
|
"scripts/build-local-panel-bundle.mjs",
|
|
@@ -264,7 +314,7 @@ for (const file of srcFiles) {
|
|
|
264
314
|
|
|
265
315
|
for (const file of [...cliFiles, ...serviceFiles]) {
|
|
266
316
|
const path = rel(file);
|
|
267
|
-
if (path === "src/services/suggestions.ts") continue;
|
|
317
|
+
if (path === "src/services/connections/suggestions.ts") continue;
|
|
268
318
|
const text = readFileSync(file, "utf8");
|
|
269
319
|
const hits = hasImportLikeReference(text, [
|
|
270
320
|
/["'][^"']*services\/suggestions(?:\.js|\.ts)?["']/,
|