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
|
@@ -277,6 +277,11 @@ const parseComparator = (comp, options) => {
|
|
|
277
277
|
|
|
278
278
|
const isX = id => !id || id.toLowerCase() === 'x' || id === '*'
|
|
279
279
|
|
|
280
|
+
const invalidXRangeOrder = (M, m, p) => (
|
|
281
|
+
(isX(M) && !isX(m)) ||
|
|
282
|
+
(isX(m) && p && !isX(p))
|
|
283
|
+
)
|
|
284
|
+
|
|
280
285
|
// ~, ~> --> * (any, kinda silly)
|
|
281
286
|
// ~2, ~2.x, ~2.x.x, ~>2, ~>2.x ~>2.x.x --> >=2.0.0 <3.0.0-0
|
|
282
287
|
// ~2.0, ~2.0.x, ~>2.0, ~>2.0.x --> >=2.0.0 <2.1.0-0
|
|
@@ -373,10 +378,10 @@ const replaceCaret = (comp, options) => {
|
|
|
373
378
|
if (M === '0') {
|
|
374
379
|
if (m === '0') {
|
|
375
380
|
ret = `>=${M}.${m}.${p
|
|
376
|
-
}
|
|
381
|
+
} <${M}.${m}.${+p + 1}-0`
|
|
377
382
|
} else {
|
|
378
383
|
ret = `>=${M}.${m}.${p
|
|
379
|
-
}
|
|
384
|
+
} <${M}.${+m + 1}.0-0`
|
|
380
385
|
}
|
|
381
386
|
} else {
|
|
382
387
|
ret = `>=${M}.${m}.${p
|
|
@@ -402,6 +407,10 @@ const replaceXRange = (comp, options) => {
|
|
|
402
407
|
const r = options.loose ? re[t.XRANGELOOSE] : re[t.XRANGE]
|
|
403
408
|
return comp.replace(r, (ret, gtlt, M, m, p, pr) => {
|
|
404
409
|
debug('xRange', comp, ret, gtlt, M, m, p, pr)
|
|
410
|
+
if (invalidXRangeOrder(M, m, p)) {
|
|
411
|
+
return comp
|
|
412
|
+
}
|
|
413
|
+
|
|
405
414
|
const xM = isX(M)
|
|
406
415
|
const xm = xM || isX(m)
|
|
407
416
|
const xp = xm || isX(p)
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "semver",
|
|
3
|
-
"version": "7.8.
|
|
3
|
+
"version": "7.8.4",
|
|
4
4
|
"description": "The semantic version parser used by npm.",
|
|
5
5
|
"main": "index.js",
|
|
6
6
|
"scripts": {
|
|
@@ -14,7 +14,7 @@
|
|
|
14
14
|
"eslint": "eslint \"**/*.{js,cjs,ts,mjs,jsx,tsx}\""
|
|
15
15
|
},
|
|
16
16
|
"devDependencies": {
|
|
17
|
-
"@npmcli/eslint-config": "^
|
|
17
|
+
"@npmcli/eslint-config": "^7.0.0",
|
|
18
18
|
"@npmcli/template-oss": "5.0.0",
|
|
19
19
|
"benchmark": "^2.1.4",
|
|
20
20
|
"tap": "^16.0.0"
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "jishushell",
|
|
3
|
-
"version": "0.6.
|
|
3
|
+
"version": "0.6.18",
|
|
4
4
|
"description": "JishuShell — Raspberry Pi server management panel (Core + Web UI)",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"jishushellPanel": {
|
|
@@ -15,62 +15,7 @@
|
|
|
15
15
|
"./config": "./dist/config.js",
|
|
16
16
|
"./auth": "./dist/auth.js",
|
|
17
17
|
"./types": "./dist/types.js",
|
|
18
|
-
"./constants": "./dist/constants.js"
|
|
19
|
-
"./services/instance-admin": "./dist/services/instance-admin.js",
|
|
20
|
-
"./services/connection-admin": "./dist/services/connection-admin.js",
|
|
21
|
-
"./services/app-config-admin": "./dist/services/app-config-admin.js",
|
|
22
|
-
"./services/app-create-from-installed": "./dist/services/app-create-from-installed.js",
|
|
23
|
-
"./services/backup-admin": "./dist/services/backup-admin.js",
|
|
24
|
-
"./services/instance-manager": "./dist/services/instance-manager.js",
|
|
25
|
-
"./services/backup-manager": "./dist/services/backup-manager.js",
|
|
26
|
-
"./services/backup-verify": "./dist/services/backup-verify.js",
|
|
27
|
-
"./services/capability-registry": "./dist/services/capability-registry.js",
|
|
28
|
-
"./services/connection-resolver": "./dist/services/connection-resolver.js",
|
|
29
|
-
"./services/connection-transactor": "./dist/services/connection-transactor.js",
|
|
30
|
-
"./services/plugin-installer": "./dist/services/plugin-installer.js",
|
|
31
|
-
"./services/files-mounts": "./dist/services/files-mounts.js",
|
|
32
|
-
"./services/nomad-manager": "./dist/services/nomad-manager.js",
|
|
33
|
-
"./services/process-manager": "./dist/services/process-manager.js",
|
|
34
|
-
"./services/setup-manager": "./dist/services/setup-manager.js",
|
|
35
|
-
"./services/task-registry": "./dist/services/task-registry.js",
|
|
36
|
-
"./services/update-manager": "./dist/services/update-manager.js",
|
|
37
|
-
"./services/app-passwords": "./dist/services/app-passwords.js",
|
|
38
|
-
"./services/workspace-builder": "./dist/services/workspace-builder.js",
|
|
39
|
-
"./services/external-mounts": "./dist/services/external-mounts.js",
|
|
40
|
-
"./services/files-manager": "./dist/services/files-manager.js",
|
|
41
|
-
"./services/system-monitor": "./dist/services/system-monitor.js",
|
|
42
|
-
"./services/suggestions": "./dist/services/suggestions.js",
|
|
43
|
-
"./services/app/app-manager": "./dist/services/app/app-manager.js",
|
|
44
|
-
"./services/app/remote-spec": "./dist/services/app/remote-spec.js",
|
|
45
|
-
"./services/app/terminal-session-manager": "./dist/services/app/terminal-session-manager.js",
|
|
46
|
-
"./services/agent-apps/index": "./dist/services/agent-apps/index.js",
|
|
47
|
-
"./services/llm-proxy/encryption": "./dist/services/llm-proxy/encryption.js",
|
|
48
|
-
"./services/llm-proxy/adapters": "./dist/services/llm-proxy/adapters.js",
|
|
49
|
-
"./services/llm-proxy/circuit-breaker": "./dist/services/llm-proxy/circuit-breaker.js",
|
|
50
|
-
"./services/llm-proxy/index": "./dist/services/llm-proxy/index.js",
|
|
51
|
-
"./services/llm-proxy/instance-proxy": "./dist/services/llm-proxy/instance-proxy.js",
|
|
52
|
-
"./services/llm-proxy/providers": "./dist/services/llm-proxy/providers.js",
|
|
53
|
-
"./services/llm-proxy/proxy-runtime": "./dist/services/llm-proxy/proxy-runtime.js",
|
|
54
|
-
"./services/llm-proxy/rate-limiter": "./dist/services/llm-proxy/rate-limiter.js",
|
|
55
|
-
"./services/llm-proxy/sse": "./dist/services/llm-proxy/sse.js",
|
|
56
|
-
"./services/llm-proxy/ssrf": "./dist/services/llm-proxy/ssrf.js",
|
|
57
|
-
"./services/llm-proxy/probe": "./dist/services/llm-proxy/probe.js",
|
|
58
|
-
"./services/llm-proxy/types": "./dist/services/llm-proxy/types.js",
|
|
59
|
-
"./services/llm-proxy/usage": "./dist/services/llm-proxy/usage.js",
|
|
60
|
-
"./services/llm-proxy/validate-key": "./dist/services/llm-proxy/validate-key.js",
|
|
61
|
-
"./services/organize/applier": "./dist/services/organize/applier.js",
|
|
62
|
-
"./services/organize/rules": "./dist/services/organize/rules.js",
|
|
63
|
-
"./services/organize/scanner": "./dist/services/organize/scanner.js",
|
|
64
|
-
"./services/organize/store": "./dist/services/organize/store.js",
|
|
65
|
-
"./services/core-manager": "./dist/services/core-manager.js",
|
|
66
|
-
"./services/runtime/index": "./dist/services/runtime/index.js",
|
|
67
|
-
"./services/runtime/instance": "./dist/services/runtime/instance.js",
|
|
68
|
-
"./services/runtime/migrations": "./dist/services/runtime/migrations.js",
|
|
69
|
-
"./services/runtime/types": "./dist/services/runtime/types.js",
|
|
70
|
-
"./services/webdav/server": "./dist/services/webdav/server.js",
|
|
71
|
-
"./utils/fs": "./dist/utils/fs.js",
|
|
72
|
-
"./utils/safe-json": "./dist/utils/safe-json.js",
|
|
73
|
-
"./utils/ttl-cache": "./dist/utils/ttl-cache.js"
|
|
18
|
+
"./constants": "./dist/constants.js"
|
|
74
19
|
},
|
|
75
20
|
"files": [
|
|
76
21
|
"dist/",
|
|
@@ -83,7 +28,7 @@
|
|
|
83
28
|
"openclaw-entry.sh",
|
|
84
29
|
"INSTALL-NOTICE",
|
|
85
30
|
"THIRD-PARTY-NOTICES",
|
|
86
|
-
"dependencies/jishushell-panel-0.6.
|
|
31
|
+
"dependencies/jishushell-panel-0.6.18.tgz"
|
|
87
32
|
],
|
|
88
33
|
"scripts": {
|
|
89
34
|
"build": "npm install && npm run compile:backend",
|
|
@@ -117,12 +62,12 @@
|
|
|
117
62
|
"build:pack": "npm run build && npm pack",
|
|
118
63
|
"build:pack:cli": "npm run build:pack",
|
|
119
64
|
"build:pack:gui": "npm run build && node scripts/pack-with-gui.mjs",
|
|
120
|
-
"check:contracts": "node --experimental-strip-types scripts/check-
|
|
65
|
+
"check:contracts": "node --experimental-strip-types scripts/check-integration-isolation.ts && node scripts/check-app-path-boundaries.mjs && node scripts/check-open-core-boundaries.mjs && node scripts/check-colima-launchd.mjs",
|
|
121
66
|
"check:open-core-boundaries": "node scripts/check-open-core-boundaries.mjs",
|
|
122
67
|
"check:i18n": "echo 'i18n checks live in sibling repo ../jishushell-panel.'",
|
|
123
68
|
"check:app-spec": "node scripts/check-app-spec.mjs",
|
|
124
69
|
"check:new-file-tests": "node scripts/check-new-file-tests.mjs",
|
|
125
|
-
"release:pack": "npm run build
|
|
70
|
+
"release:pack": "npm run build:pack:gui",
|
|
126
71
|
"release:pack:gui": "npm run build:pack:gui"
|
|
127
72
|
},
|
|
128
73
|
"engines": {
|
|
@@ -142,7 +87,7 @@
|
|
|
142
87
|
"license": "Apache-2.0",
|
|
143
88
|
"dependencies": {
|
|
144
89
|
"@fastify/multipart": "^10.0.0",
|
|
145
|
-
"@fastify/static": "^
|
|
90
|
+
"@fastify/static": "^9.1.3",
|
|
146
91
|
"@noble/hashes": "^2.0.1",
|
|
147
92
|
"bcryptjs": "^2.4.3",
|
|
148
93
|
"exifr": "^7.1.3",
|
|
@@ -150,11 +95,14 @@
|
|
|
150
95
|
"jsonwebtoken": "^9.0.2",
|
|
151
96
|
"systeminformation": "^5.23.0",
|
|
152
97
|
"yaml": "^2.8.3",
|
|
153
|
-
"jishushell-panel": "file:dependencies/jishushell-panel-0.6.
|
|
98
|
+
"jishushell-panel": "file:dependencies/jishushell-panel-0.6.18.tgz"
|
|
154
99
|
},
|
|
155
100
|
"optionalDependencies": {
|
|
156
101
|
"macos-temperature-sensor": "^1.0.4"
|
|
157
102
|
},
|
|
103
|
+
"overrides": {
|
|
104
|
+
"qs": "6.15.2"
|
|
105
|
+
},
|
|
158
106
|
"devDependencies": {
|
|
159
107
|
"@biomejs/biome": "^2.4.14",
|
|
160
108
|
"@stryker-mutator/core": "^9.6.1",
|
|
@@ -163,10 +111,10 @@
|
|
|
163
111
|
"@types/bcryptjs": "^2.4.6",
|
|
164
112
|
"@types/jsonwebtoken": "^9.0.7",
|
|
165
113
|
"@types/node": "^22.19.15",
|
|
166
|
-
"@vitest/coverage-v8": "^4.1.
|
|
114
|
+
"@vitest/coverage-v8": "^4.1.9",
|
|
167
115
|
"pptxgenjs": "^4.0.1",
|
|
168
116
|
"typescript": "^5.7.0",
|
|
169
|
-
"vitest": "^4.1.
|
|
117
|
+
"vitest": "^4.1.9"
|
|
170
118
|
},
|
|
171
119
|
"bundleDependencies": [
|
|
172
120
|
"jishushell-panel"
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
/**
|
|
3
|
+
* Enforce the canonical instance path boundary.
|
|
4
|
+
*
|
|
5
|
+
* Normal service code must resolve instance directories through
|
|
6
|
+
* src/services/app-common/paths.ts. Migration and repair code are excluded
|
|
7
|
+
* because they intentionally inspect historical or partially broken layouts.
|
|
8
|
+
*/
|
|
9
|
+
|
|
10
|
+
import { readdirSync, readFileSync, statSync } from "node:fs";
|
|
11
|
+
import { relative, resolve, sep } from "node:path";
|
|
12
|
+
|
|
13
|
+
const REPO_ROOT = resolve(import.meta.dirname ?? ".", "..");
|
|
14
|
+
const SERVICES_ROOT = resolve(REPO_ROOT, "src/services");
|
|
15
|
+
const PATHS_MODULE = "src/services/app-common/paths.ts";
|
|
16
|
+
|
|
17
|
+
const EXCLUDED_SEGMENTS = new Set(["legacy-migrator", "repair"]);
|
|
18
|
+
const ALLOWED_DIR_RESOLVERS = new Set([
|
|
19
|
+
"resolveAppDir",
|
|
20
|
+
"resolveInstalledAppDir",
|
|
21
|
+
]);
|
|
22
|
+
|
|
23
|
+
const PATH_JOIN_PATTERN = /join\s*\(\s*APPS_DIR\s*,\s*([A-Za-z_$][\w$]*)\s*\)/g;
|
|
24
|
+
const CONFIG_INSTANCE_DIR_PATTERN = /\bgetInstanceDir\s*\(\s*(?:instanceId|id)\s*\)/g;
|
|
25
|
+
const DIR_RESOLVER_PATTERNS = [
|
|
26
|
+
/\b(?:export\s+)?function\s+([A-Za-z_$][\w$]*(?:AppDir|InstanceDir))\s*\(\s*(?:instanceId|id)\b/g,
|
|
27
|
+
/\b(?:export\s+)?const\s+([A-Za-z_$][\w$]*(?:AppDir|InstanceDir))\s*=\s*(?:async\s*)?\(?\s*(?:instanceId|id)\b/g,
|
|
28
|
+
];
|
|
29
|
+
|
|
30
|
+
function isSourceFile(path) {
|
|
31
|
+
return path.endsWith(".ts") && !path.endsWith(".d.ts");
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
function isExcluded(path) {
|
|
35
|
+
const rel = relative(SERVICES_ROOT, path);
|
|
36
|
+
if (rel.startsWith("..")) return true;
|
|
37
|
+
return rel.split(sep).some((segment) => EXCLUDED_SEGMENTS.has(segment));
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
function* walk(dir) {
|
|
41
|
+
for (const entry of readdirSync(dir)) {
|
|
42
|
+
const full = resolve(dir, entry);
|
|
43
|
+
const stat = statSync(full);
|
|
44
|
+
if (stat.isDirectory()) {
|
|
45
|
+
yield* walk(full);
|
|
46
|
+
} else if (stat.isFile() && isSourceFile(full) && !isExcluded(full)) {
|
|
47
|
+
yield full;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
function lineForIndex(content, index) {
|
|
53
|
+
return content.slice(0, index).split("\n").length;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
function isCommentLine(content, index) {
|
|
57
|
+
const lineStart = content.lastIndexOf("\n", index) + 1;
|
|
58
|
+
const lineEnd = content.indexOf("\n", index);
|
|
59
|
+
const line = content.slice(lineStart, lineEnd === -1 ? content.length : lineEnd).trimStart();
|
|
60
|
+
return line.startsWith("//") || line.startsWith("*") || line.startsWith("/*");
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
const violations = [];
|
|
64
|
+
|
|
65
|
+
for (const abs of walk(SERVICES_ROOT)) {
|
|
66
|
+
const rel = relative(REPO_ROOT, abs).split(sep).join("/");
|
|
67
|
+
const content = readFileSync(abs, "utf-8");
|
|
68
|
+
const isPathsModule = rel === PATHS_MODULE;
|
|
69
|
+
|
|
70
|
+
if (!isPathsModule) {
|
|
71
|
+
let match;
|
|
72
|
+
const pathJoinPattern = new RegExp(PATH_JOIN_PATTERN.source, "g");
|
|
73
|
+
while ((match = pathJoinPattern.exec(content)) !== null) {
|
|
74
|
+
if (isCommentLine(content, match.index)) continue;
|
|
75
|
+
violations.push({
|
|
76
|
+
file: rel,
|
|
77
|
+
line: lineForIndex(content, match.index),
|
|
78
|
+
rule: "instance-path-join",
|
|
79
|
+
text: match[0],
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
const configInstanceDirPattern = new RegExp(CONFIG_INSTANCE_DIR_PATTERN.source, "g");
|
|
84
|
+
while ((match = configInstanceDirPattern.exec(content)) !== null) {
|
|
85
|
+
if (isCommentLine(content, match.index)) continue;
|
|
86
|
+
violations.push({
|
|
87
|
+
file: rel,
|
|
88
|
+
line: lineForIndex(content, match.index),
|
|
89
|
+
rule: "config-instance-dir",
|
|
90
|
+
text: match[0],
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
for (const pattern of DIR_RESOLVER_PATTERNS) {
|
|
96
|
+
let match;
|
|
97
|
+
const dirResolverPattern = new RegExp(pattern.source, "g");
|
|
98
|
+
while ((match = dirResolverPattern.exec(content)) !== null) {
|
|
99
|
+
if (isCommentLine(content, match.index)) continue;
|
|
100
|
+
const name = match[1];
|
|
101
|
+
if (isPathsModule && name === "resolveAppDir") continue;
|
|
102
|
+
if (ALLOWED_DIR_RESOLVERS.has(name)) continue;
|
|
103
|
+
violations.push({
|
|
104
|
+
file: rel,
|
|
105
|
+
line: lineForIndex(content, match.index),
|
|
106
|
+
rule: "duplicate-dir-resolver",
|
|
107
|
+
text: name,
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
if (violations.length > 0) {
|
|
114
|
+
console.error(`check-app-path-boundaries FAILED: ${violations.length} violation(s)\n`);
|
|
115
|
+
for (const violation of violations) {
|
|
116
|
+
console.error(` ${violation.file}:${violation.line} [${violation.rule}] ${violation.text}`);
|
|
117
|
+
}
|
|
118
|
+
process.exit(1);
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
console.log("check-app-path-boundaries OK");
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
/**
|
|
3
|
-
* Validates `apps/*.yaml` against the
|
|
4
|
-
* (docs/app-interconnect-design.md §13.2.3).
|
|
3
|
+
* Validates `apps/*.yaml` against the provider authoring contract.
|
|
5
4
|
*
|
|
6
5
|
* Three provide classes:
|
|
7
6
|
* A. Bindable category — capability has CAPABILITY_CATEGORIES prefix
|
|
@@ -31,27 +30,35 @@ const APPS_DIR = process.env.APPS_DIR_OVERRIDE ?? join(__dirname, "..", "apps");
|
|
|
31
30
|
|
|
32
31
|
// ── Allowlists (kept here so check-app-spec stays mechanically driven) ──
|
|
33
32
|
|
|
34
|
-
// Keep in sync with
|
|
35
|
-
//
|
|
36
|
-
//
|
|
33
|
+
// Keep in sync with src/services/capabilities/contract.ts. These values are
|
|
34
|
+
// deliberately small and closed: provider app ids stay free-form, but
|
|
35
|
+
// matching protocol must be explicit and statically checkable.
|
|
37
36
|
const CAPABILITY_CATEGORIES = new Set([
|
|
38
|
-
"llm", "search", "browser", "mcp", "files", "knowledge",
|
|
37
|
+
"llm", "search", "browser", "mcp", "files", "knowledge", "ui", "terminal",
|
|
39
38
|
]);
|
|
40
39
|
|
|
40
|
+
const INTERFACES_BY_KIND = {
|
|
41
|
+
llm: new Set(["openai-compatible"]),
|
|
42
|
+
search: new Set(["searxng-json"]),
|
|
43
|
+
browser: new Set(["cdp-ws"]),
|
|
44
|
+
mcp: new Set(["mcp-http", "mcp-sse", "mcp-stdio"]),
|
|
45
|
+
files: new Set(["web-file-manager"]),
|
|
46
|
+
knowledge: new Set(["kb-search"]),
|
|
47
|
+
ui: new Set(["web-ui"]),
|
|
48
|
+
terminal: new Set(["terminal"]),
|
|
49
|
+
};
|
|
50
|
+
|
|
41
51
|
const LEGACY_BINDABLE_EXACT_ALLOWLIST = new Set([
|
|
42
52
|
"ollama-api",
|
|
43
53
|
"browserless-api",
|
|
44
54
|
]);
|
|
45
55
|
|
|
46
56
|
const UI_LEGACY_ALLOWLIST = new Set([
|
|
47
|
-
"openwebui-web",
|
|
48
57
|
"hollama-web",
|
|
49
|
-
"playwright-ui",
|
|
50
58
|
"openclaw-dashboard",
|
|
51
59
|
"ollama-terminal",
|
|
52
60
|
"web-ui",
|
|
53
61
|
"web-searxng",
|
|
54
|
-
"web-openwebui",
|
|
55
62
|
"web-hermes",
|
|
56
63
|
"browserless-debugger",
|
|
57
64
|
"browserless-docs",
|
|
@@ -68,18 +75,116 @@ const PROTOCOL_WHITELIST = {
|
|
|
68
75
|
// AnythingLLM exposes an OpenAI-compatible HTTP API for kb_search; baseUrl
|
|
69
76
|
// is always http(s) regardless of LAN vs container host topology.
|
|
70
77
|
knowledge: new Set(["http", "https"]),
|
|
78
|
+
ui: new Set(["http", "https"]),
|
|
79
|
+
terminal: new Set(["tcp"]),
|
|
71
80
|
default: new Set(["http", "https", "ws", "wss", "tcp"]),
|
|
72
81
|
};
|
|
73
82
|
|
|
74
83
|
// ── Helpers ──
|
|
75
84
|
|
|
76
85
|
function categoryOf(capability) {
|
|
86
|
+
if (CAPABILITY_CATEGORIES.has(capability)) return capability;
|
|
77
87
|
const dashIdx = capability.indexOf("-");
|
|
78
88
|
if (dashIdx <= 0) return null;
|
|
79
89
|
const head = capability.slice(0, dashIdx);
|
|
80
90
|
return CAPABILITY_CATEGORIES.has(head) ? head : null;
|
|
81
91
|
}
|
|
82
92
|
|
|
93
|
+
function inferLegacyInterface(kind, capability, protocol) {
|
|
94
|
+
switch (kind) {
|
|
95
|
+
case "llm": return "openai-compatible";
|
|
96
|
+
case "search": return capability === "search" || capability === "search-searxng" ? "searxng-json" : null;
|
|
97
|
+
case "browser": return "cdp-ws";
|
|
98
|
+
case "files": return "web-file-manager";
|
|
99
|
+
case "knowledge": return "kb-search";
|
|
100
|
+
case "ui": return "web-ui";
|
|
101
|
+
case "terminal": return "terminal";
|
|
102
|
+
case "mcp": {
|
|
103
|
+
const normalized = typeof protocol === "string" ? protocol.trim().toLowerCase() : "";
|
|
104
|
+
if (normalized === "sse") return "mcp-sse";
|
|
105
|
+
if (normalized === "stdio") return "mcp-stdio";
|
|
106
|
+
return "mcp-http";
|
|
107
|
+
}
|
|
108
|
+
default: return null;
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
function capabilityContract(obj) {
|
|
113
|
+
const capability = typeof obj?.capability === "string" ? obj.capability : "";
|
|
114
|
+
const explicitKind = typeof obj?.kind === "string" && CAPABILITY_CATEGORIES.has(obj.kind) ? obj.kind : null;
|
|
115
|
+
const kind = explicitKind ?? categoryOf(capability);
|
|
116
|
+
if (!kind) return null;
|
|
117
|
+
const iface = typeof obj?.interface === "string" && INTERFACES_BY_KIND[kind]?.has(obj.interface)
|
|
118
|
+
? obj.interface
|
|
119
|
+
: inferLegacyInterface(kind, capability, obj?.protocol);
|
|
120
|
+
return iface ? { kind, interface: iface } : null;
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
function isContractRequire(req) {
|
|
124
|
+
// Keep mirrored with src/services/capabilities/contract.ts. The checker runs
|
|
125
|
+
// as a standalone Node script, so this local copy must preserve the same
|
|
126
|
+
// domain rule: category tokens (`llm`, `search`) use kind/interface
|
|
127
|
+
// matching; concrete provider capabilities (`llm-ollama`) remain exact.
|
|
128
|
+
return typeof req?.capability === "string" && CAPABILITY_CATEGORIES.has(req.capability);
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
function capabilityMatchesRequire(req, provider) {
|
|
132
|
+
if (!isContractRequire(req)) {
|
|
133
|
+
return provider?.capability === req?.capability;
|
|
134
|
+
}
|
|
135
|
+
const reqContract = capabilityContract(req);
|
|
136
|
+
const providerContract = capabilityContract(provider);
|
|
137
|
+
if (reqContract && providerContract) {
|
|
138
|
+
return providerContract.kind === reqContract.kind && providerContract.interface === reqContract.interface;
|
|
139
|
+
}
|
|
140
|
+
return provider?.capability === req?.capability;
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
function validateStructuredContract(file, label, item) {
|
|
144
|
+
const hasKind = item.kind !== undefined;
|
|
145
|
+
const hasInterface = item.interface !== undefined;
|
|
146
|
+
if (!hasKind && !hasInterface) return;
|
|
147
|
+
if (typeof item.kind !== "string" || !CAPABILITY_CATEGORIES.has(item.kind)) {
|
|
148
|
+
err(file, `${label} kind must be one of ${[...CAPABILITY_CATEGORIES].join("|")}`);
|
|
149
|
+
return;
|
|
150
|
+
}
|
|
151
|
+
if (typeof item.interface !== "string" || !INTERFACES_BY_KIND[item.kind]?.has(item.interface)) {
|
|
152
|
+
err(file, `${label} interface '${item.interface}' is not valid for kind '${item.kind}'`);
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
function validateEndpoint(file, spec, cap, provide) {
|
|
157
|
+
if (provide.endpoint === undefined) return;
|
|
158
|
+
if (typeof provide.endpoint !== "object" || provide.endpoint === null || Array.isArray(provide.endpoint)) {
|
|
159
|
+
err(file, `provide '${cap}' endpoint must be an object`);
|
|
160
|
+
return;
|
|
161
|
+
}
|
|
162
|
+
if (typeof provide.endpoint.portName !== "string" || !provide.endpoint.portName) {
|
|
163
|
+
err(file, `provide '${cap}' endpoint.portName is required when endpoint is declared`);
|
|
164
|
+
}
|
|
165
|
+
if ("hostPort" in provide.endpoint || "host" in provide.endpoint) {
|
|
166
|
+
err(file, `provide '${cap}' endpoint must not declare host/hostPort; use runtime.ports[].hostPort`);
|
|
167
|
+
}
|
|
168
|
+
for (const key of Object.keys(provide.endpoint)) {
|
|
169
|
+
if (key !== "portName") {
|
|
170
|
+
err(file, `provide '${cap}' endpoint.${key} is not supported; keep protocol/path as top-level provide fields`);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
if (typeof provide.task !== "string" || !provide.task) {
|
|
174
|
+
err(file, `provide '${cap}' endpoint.portName requires provide.task so it can be checked against task ports[]`);
|
|
175
|
+
return;
|
|
176
|
+
}
|
|
177
|
+
const task = findTask(spec, provide.task);
|
|
178
|
+
if (!task) return;
|
|
179
|
+
if (
|
|
180
|
+
typeof provide.endpoint.portName === "string"
|
|
181
|
+
&& provide.endpoint.portName
|
|
182
|
+
&& !findNamedPortInTask(task, provide.endpoint.portName)
|
|
183
|
+
) {
|
|
184
|
+
err(file, `provide '${cap}' endpoint.portName '${provide.endpoint.portName}' not in task '${provide.task}' ports[]`);
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
|
|
83
188
|
function isUILegacy(capability) {
|
|
84
189
|
if (UI_LEGACY_ALLOWLIST.has(capability)) return true;
|
|
85
190
|
if (capability.startsWith("web-")) return true;
|
|
@@ -172,6 +277,10 @@ function findPortInTask(task, providePort) {
|
|
|
172
277
|
return (task?.ports ?? []).find((p) => hostPortOf(p) === providePort);
|
|
173
278
|
}
|
|
174
279
|
|
|
280
|
+
function findNamedPortInTask(task, portName) {
|
|
281
|
+
return (task?.ports ?? []).find((p) => p?.name === portName);
|
|
282
|
+
}
|
|
283
|
+
|
|
175
284
|
// ── Main ──
|
|
176
285
|
|
|
177
286
|
const errors = [];
|
|
@@ -219,27 +328,16 @@ const allowedRequiresExact = new Set([
|
|
|
219
328
|
]);
|
|
220
329
|
|
|
221
330
|
// Index every provide capability across the repo for orphan-require check.
|
|
222
|
-
const
|
|
331
|
+
const allProviders = [];
|
|
223
332
|
for (const { spec } of specs) {
|
|
224
333
|
for (const provide of spec.provides ?? []) {
|
|
225
334
|
if (typeof provide?.capability !== "string") continue;
|
|
226
|
-
|
|
227
|
-
providersByCapability.set(provide.capability, []);
|
|
228
|
-
}
|
|
229
|
-
providersByCapability.get(provide.capability).push({ spec });
|
|
335
|
+
allProviders.push(provide);
|
|
230
336
|
}
|
|
231
337
|
}
|
|
232
338
|
|
|
233
339
|
function hasProviderForRequire(req) {
|
|
234
|
-
|
|
235
|
-
if (CAPABILITY_CATEGORIES.has(req)) {
|
|
236
|
-
for (const cap of providersByCapability.keys()) {
|
|
237
|
-
if (cap.startsWith(req + "-")) return true;
|
|
238
|
-
}
|
|
239
|
-
return false;
|
|
240
|
-
}
|
|
241
|
-
// B path: exact match.
|
|
242
|
-
return providersByCapability.has(req);
|
|
340
|
+
return allProviders.some((provider) => capabilityMatchesRequire(req, provider));
|
|
243
341
|
}
|
|
244
342
|
|
|
245
343
|
// Second pass: validate each spec.
|
|
@@ -254,6 +352,7 @@ for (const { file, spec } of specs) {
|
|
|
254
352
|
}
|
|
255
353
|
const cap = provide.capability;
|
|
256
354
|
const cat = categoryOf(cap);
|
|
355
|
+
validateStructuredContract(file, `provide '${cap}'`, provide);
|
|
257
356
|
const isB =
|
|
258
357
|
!cat &&
|
|
259
358
|
(LEGACY_BINDABLE_EXACT_ALLOWLIST.has(cap) || exactRequiresInRepo.has(cap)) &&
|
|
@@ -267,6 +366,7 @@ for (const { file, spec } of specs) {
|
|
|
267
366
|
}
|
|
268
367
|
continue;
|
|
269
368
|
}
|
|
369
|
+
validateEndpoint(file, spec, cap, provide);
|
|
270
370
|
|
|
271
371
|
if (cat) {
|
|
272
372
|
// Class A
|
|
@@ -321,6 +421,7 @@ for (const { file, spec } of specs) {
|
|
|
321
421
|
if (provide.auth !== undefined) {
|
|
322
422
|
err(file, `provide '${cap}' auth is not allowed on UI-only or url-only provides`);
|
|
323
423
|
}
|
|
424
|
+
|
|
324
425
|
if (typeof provide.port === "number") {
|
|
325
426
|
if (typeof provide.task === "string" && provide.task) {
|
|
326
427
|
const task = findTask(spec, provide.task);
|
|
@@ -338,7 +439,7 @@ for (const { file, spec } of specs) {
|
|
|
338
439
|
}
|
|
339
440
|
|
|
340
441
|
// ── §17 (PR 8): tool_schema validation — applies to any bindable
|
|
341
|
-
// capability that an LLM
|
|
442
|
+
// capability that an LLM integration hook may turn into an MCP
|
|
342
443
|
// server entry (i.e. category A search-/mcp-, plus any future
|
|
343
444
|
// bindable cap). Warn-only this release; promoted to err in v0.5.
|
|
344
445
|
if (provide.tool_schema !== undefined) {
|
|
@@ -388,6 +489,7 @@ for (const { file, spec } of specs) {
|
|
|
388
489
|
}
|
|
389
490
|
const isCategory = CAPABILITY_CATEGORIES.has(req.capability);
|
|
390
491
|
const isExact = allowedRequiresExact.has(req.capability);
|
|
492
|
+
validateStructuredContract(file, `require '${req.capability}'`, req);
|
|
391
493
|
if (!isCategory && !isExact) {
|
|
392
494
|
err(
|
|
393
495
|
file,
|
|
@@ -422,7 +524,7 @@ for (const { file, spec } of specs) {
|
|
|
422
524
|
}
|
|
423
525
|
|
|
424
526
|
// Orphan-require check: at least one provider in the repo must satisfy.
|
|
425
|
-
if (!hasProviderForRequire(req
|
|
527
|
+
if (!hasProviderForRequire(req)) {
|
|
426
528
|
const isRequired = req.required !== false; // default true
|
|
427
529
|
if (isRequired) {
|
|
428
530
|
err(
|
|
@@ -71,17 +71,17 @@ must(/checkColimaLaunchd[,\s]/.test(doctor) && /ALL_CHECKS/.test(doctor),
|
|
|
71
71
|
|
|
72
72
|
// ─────────────────────────────────────────────────────────────────────
|
|
73
73
|
// Follow-up #14 — TypeScript install path parity. `jishushell install`
|
|
74
|
-
// and the Setup wizard go through src/services/setup-manager.ts, which
|
|
74
|
+
// and the Setup wizard go through src/services/setup/setup-manager.ts, which
|
|
75
75
|
// must produce the SAME hardened launchd artifacts as the bash installer
|
|
76
76
|
// (otherwise any reinstall/update reverts the headless-reboot fix).
|
|
77
77
|
// These assertions read the canonical TS builders in macos-launchd.ts.
|
|
78
|
-
const tsLaunchd = readFileSync(join(ROOT, "src/services/macos-launchd.ts"), "utf8");
|
|
79
|
-
const setupMgr = readFileSync(join(ROOT, "src/services/setup-manager.ts"), "utf8");
|
|
78
|
+
const tsLaunchd = readFileSync(join(ROOT, "src/services/system/macos-launchd.ts"), "utf8");
|
|
79
|
+
const setupMgr = readFileSync(join(ROOT, "src/services/setup/setup-manager.ts"), "utf8");
|
|
80
80
|
const tsLaunchdNoComments = tsLaunchd.replace(/\/\/.*$/gm, "").replace(/\/\*[\s\S]*?\*\//g, "");
|
|
81
81
|
|
|
82
82
|
// setup-manager must import + use the canonical builders.
|
|
83
|
-
must(/from\s+"
|
|
84
|
-
"setup-manager.ts must import the canonical builders from
|
|
83
|
+
must(/from\s+"\.\.\/system\/macos-launchd\.js"/.test(setupMgr),
|
|
84
|
+
"setup-manager.ts must import the canonical builders from ../system/macos-launchd.js");
|
|
85
85
|
must(/buildColimaWrapperScript\(/.test(setupMgr) && /buildColimaPlist\(/.test(setupMgr)
|
|
86
86
|
&& /buildNomadWaitWrapper\(/.test(setupMgr) && /buildNomadPlist\(/.test(setupMgr)
|
|
87
87
|
&& /buildCoreGateWrapper\(/.test(setupMgr) && /buildCorePlist\(/.test(setupMgr),
|
|
@@ -124,6 +124,8 @@ must(/CORE_DOCKER_WAIT_DEADLINE_SECONDS\s*=\s*60\b/.test(tsLaunchd),
|
|
|
124
124
|
"TS core gate deadline constant must be 60s");
|
|
125
125
|
must(/CORE_DOCKER_WAIT_DEADLINE=\$\{CORE_DOCKER_WAIT_DEADLINE_SECONDS\}/.test(tsLaunchd),
|
|
126
126
|
"TS core gate wrapper must interpolate CORE_DOCKER_WAIT_DEADLINE_SECONDS");
|
|
127
|
+
must(/exec "\$\{coreStartWrapper\}"/.test(tsLaunchd) && !/exec \/bin\/sh "\$\{coreStartWrapper\}"/.test(tsLaunchd),
|
|
128
|
+
"TS core gate wrapper must exec jishushell-core-start directly so its bash shebang is honored");
|
|
127
129
|
must(/docker info/.test(tsLaunchd) && /exec "\$\{nomadBin\}" agent/.test(tsLaunchd),
|
|
128
130
|
"TS nomad wait wrapper must poll docker then exec nomad");
|
|
129
131
|
|
|
@@ -146,7 +148,7 @@ const crossLink = (label, bashRe, tsRe) => {
|
|
|
146
148
|
if (b !== null && t !== null) {
|
|
147
149
|
must(b === t,
|
|
148
150
|
`${label} budget drift: bash=${b} != TS=${t} ` +
|
|
149
|
-
`(install/jishu-install.sh vs src/services/macos-launchd.ts must stay lockstep)`);
|
|
151
|
+
`(install/jishu-install.sh vs src/services/system/macos-launchd.ts must stay lockstep)`);
|
|
150
152
|
}
|
|
151
153
|
};
|
|
152
154
|
|
|
@@ -196,7 +198,7 @@ must(staleReclaimRe.test(installer),
|
|
|
196
198
|
"bash colima-wrapper heredoc (install/jishu-install.sh) must reclaim a stale mkdir-lock " +
|
|
197
199
|
'before acquiring it ([ -d "$LOCKDIR" ] && find ... -mmin +N -exec rmdir {} \\;)');
|
|
198
200
|
must(staleReclaimRe.test(tsLaunchd),
|
|
199
|
-
"TS buildColimaWrapperScript (src/services/macos-launchd.ts) must reclaim a stale " +
|
|
201
|
+
"TS buildColimaWrapperScript (src/services/system/macos-launchd.ts) must reclaim a stale " +
|
|
200
202
|
'mkdir-lock before acquiring it ([ -d "$LOCKDIR" ] && find ... -mmin +N -exec rmdir {} \\;)');
|
|
201
203
|
|
|
202
204
|
// staleness budget literal (-mmin +10) must match bash↔TS.
|
|
@@ -220,7 +222,7 @@ must(lockRefreshRe.test(installer),
|
|
|
220
222
|
'lock mtime each retry attempt (touch "$LOCKDIR" 2>/dev/null || true) so a ' +
|
|
221
223
|
"long in-progress start is never reclaimed as stale");
|
|
222
224
|
must(lockRefreshRe.test(tsLaunchd),
|
|
223
|
-
"TS buildColimaWrapperScript (src/services/macos-launchd.ts) must refresh its own " +
|
|
225
|
+
"TS buildColimaWrapperScript (src/services/system/macos-launchd.ts) must refresh its own " +
|
|
224
226
|
'lock mtime each retry attempt (touch "$LOCKDIR" 2>/dev/null || true) so a ' +
|
|
225
227
|
"long in-progress start is never reclaimed as stale");
|
|
226
228
|
|