@better-openclaw/core 1.0.26 → 1.0.31
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +67 -7
- package/dist/addon-stack.cjs +41 -28
- package/dist/addon-stack.cjs.map +1 -1
- package/dist/addon-stack.d.cts +1 -1
- package/dist/addon-stack.d.cts.map +1 -1
- package/dist/addon-stack.d.mts +1 -1
- package/dist/addon-stack.d.mts.map +1 -1
- package/dist/addon-stack.mjs +40 -27
- package/dist/addon-stack.mjs.map +1 -1
- package/dist/addon-stack.test.cjs +14 -14
- package/dist/addon-stack.test.cjs.map +1 -1
- package/dist/addon-stack.test.mjs +13 -13
- package/dist/addon-stack.test.mjs.map +1 -1
- package/dist/bare-metal-partition.d.cts +1 -1
- package/dist/bare-metal-partition.d.mts +1 -1
- package/dist/bare-metal-partition.test.cjs +1 -1
- package/dist/bare-metal-partition.test.mjs +1 -1
- package/dist/callback-sink-CdMKYayY.d.mts +15 -0
- package/dist/callback-sink-CdMKYayY.d.mts.map +1 -0
- package/dist/callback-sink-iNThWRnQ.d.cts +15 -0
- package/dist/callback-sink-iNThWRnQ.d.cts.map +1 -0
- package/dist/claude-code-fw-CrbAlzTM.d.mts +7 -0
- package/dist/claude-code-fw-CrbAlzTM.d.mts.map +1 -0
- package/dist/claude-code-fw-dKYH2prH.d.cts +7 -0
- package/dist/claude-code-fw-dKYH2prH.d.cts.map +1 -0
- package/dist/codex-fw-Ct8q4pzo.d.mts +7 -0
- package/dist/codex-fw-Ct8q4pzo.d.mts.map +1 -0
- package/dist/codex-fw-l7Ku8ZI8.d.cts +7 -0
- package/dist/codex-fw-l7Ku8ZI8.d.cts.map +1 -0
- package/dist/compose-validation.test.cjs +1 -1
- package/dist/composer.cjs +89 -129
- package/dist/composer.cjs.map +1 -1
- package/dist/composer.d.cts +3 -3
- package/dist/composer.d.cts.map +1 -1
- package/dist/composer.d.mts +3 -3
- package/dist/composer.d.mts.map +1 -1
- package/dist/composer.mjs +88 -128
- package/dist/composer.mjs.map +1 -1
- package/dist/composer.snapshot.test.cjs +1 -1
- package/dist/composer.snapshot.test.mjs +1 -1
- package/dist/composer.test.cjs +53 -2
- package/dist/composer.test.cjs.map +1 -1
- package/dist/composer.test.mjs +52 -1
- package/dist/composer.test.mjs.map +1 -1
- package/dist/console-sink-BHQpRyCt.d.cts +13 -0
- package/dist/console-sink-BHQpRyCt.d.cts.map +1 -0
- package/dist/console-sink-bouG_M1K.d.mts +13 -0
- package/dist/console-sink-bouG_M1K.d.mts.map +1 -0
- package/dist/{coolify-BVGGcMrT.d.mts → coolify-D5E0z01M.d.mts} +2 -2
- package/dist/{coolify-BVGGcMrT.d.mts.map → coolify-D5E0z01M.d.mts.map} +1 -1
- package/dist/{coolify-vlb1G9V2.d.cts → coolify-DjHecHCr.d.cts} +2 -2
- package/dist/{coolify-vlb1G9V2.d.cts.map → coolify-DjHecHCr.d.cts.map} +1 -1
- package/dist/copaw-BQyjioz7.d.cts +7 -0
- package/dist/copaw-BQyjioz7.d.cts.map +1 -0
- package/dist/copaw-C_3N7eQu.d.mts +7 -0
- package/dist/copaw-C_3N7eQu.d.mts.map +1 -0
- package/dist/deployers/coolify.cjs +25 -0
- package/dist/deployers/coolify.cjs.map +1 -1
- package/dist/deployers/coolify.d.cts +1 -1
- package/dist/deployers/coolify.d.mts +1 -1
- package/dist/deployers/coolify.mjs +25 -0
- package/dist/deployers/coolify.mjs.map +1 -1
- package/dist/deployers/coolify.test.cjs +156 -0
- package/dist/deployers/coolify.test.cjs.map +1 -0
- package/dist/deployers/coolify.test.d.cts +1 -0
- package/dist/deployers/coolify.test.d.mts +1 -0
- package/dist/deployers/coolify.test.mjs +157 -0
- package/dist/deployers/coolify.test.mjs.map +1 -0
- package/dist/deployers/dokploy.cjs +25 -0
- package/dist/deployers/dokploy.cjs.map +1 -1
- package/dist/deployers/dokploy.d.cts +1 -1
- package/dist/deployers/dokploy.d.mts +1 -1
- package/dist/deployers/dokploy.mjs +25 -0
- package/dist/deployers/dokploy.mjs.map +1 -1
- package/dist/deployers/dokploy.test.cjs +108 -0
- package/dist/deployers/dokploy.test.cjs.map +1 -0
- package/dist/deployers/dokploy.test.d.cts +1 -0
- package/dist/deployers/dokploy.test.d.mts +1 -0
- package/dist/deployers/dokploy.test.mjs +109 -0
- package/dist/deployers/dokploy.test.mjs.map +1 -0
- package/dist/deployers/index.d.cts +3 -3
- package/dist/deployers/index.d.mts +3 -3
- package/dist/deployers/strip-host-ports.cjs +1 -1
- package/dist/deployers/strip-host-ports.test.cjs +1 -1
- package/dist/deployers/strip-host-ports.test.mjs +1 -1
- package/dist/deployers/types.d.cts +1 -1
- package/dist/deployers/types.d.mts +1 -1
- package/dist/{dokploy-8cbrxUun.d.cts → dokploy-BnVDjWCV.d.cts} +2 -2
- package/dist/{dokploy-8cbrxUun.d.cts.map → dokploy-BnVDjWCV.d.cts.map} +1 -1
- package/dist/{dokploy-BTflLhTM.d.mts → dokploy-BqLdCfyR.d.mts} +2 -2
- package/dist/{dokploy-BTflLhTM.d.mts.map → dokploy-BqLdCfyR.d.mts.map} +1 -1
- package/dist/frameworks/claude-code-fw.cjs +79 -0
- package/dist/frameworks/claude-code-fw.cjs.map +1 -0
- package/dist/frameworks/claude-code-fw.d.cts +2 -0
- package/dist/frameworks/claude-code-fw.d.mts +2 -0
- package/dist/frameworks/claude-code-fw.mjs +78 -0
- package/dist/frameworks/claude-code-fw.mjs.map +1 -0
- package/dist/frameworks/codex-fw.cjs +67 -0
- package/dist/frameworks/codex-fw.cjs.map +1 -0
- package/dist/frameworks/codex-fw.d.cts +2 -0
- package/dist/frameworks/codex-fw.d.mts +2 -0
- package/dist/frameworks/codex-fw.mjs +66 -0
- package/dist/frameworks/codex-fw.mjs.map +1 -0
- package/dist/frameworks/copaw.cjs +118 -0
- package/dist/frameworks/copaw.cjs.map +1 -0
- package/dist/frameworks/copaw.d.cts +2 -0
- package/dist/frameworks/copaw.d.mts +2 -0
- package/dist/frameworks/copaw.mjs +117 -0
- package/dist/frameworks/copaw.mjs.map +1 -0
- package/dist/frameworks/frameworks.test.cjs +94 -0
- package/dist/frameworks/frameworks.test.cjs.map +1 -0
- package/dist/frameworks/frameworks.test.d.cts +1 -0
- package/dist/frameworks/frameworks.test.d.mts +1 -0
- package/dist/frameworks/frameworks.test.mjs +94 -0
- package/dist/frameworks/frameworks.test.mjs.map +1 -0
- package/dist/frameworks/index.cjs +35 -0
- package/dist/frameworks/index.cjs.map +1 -0
- package/dist/frameworks/index.d.cts +11 -0
- package/dist/frameworks/index.d.mts +11 -0
- package/dist/frameworks/index.mjs +22 -0
- package/dist/frameworks/index.mjs.map +1 -0
- package/dist/frameworks/memu.cjs +118 -0
- package/dist/frameworks/memu.cjs.map +1 -0
- package/dist/frameworks/memu.d.cts +2 -0
- package/dist/frameworks/memu.d.mts +2 -0
- package/dist/frameworks/memu.mjs +117 -0
- package/dist/frameworks/memu.mjs.map +1 -0
- package/dist/frameworks/nanobot.cjs +126 -0
- package/dist/frameworks/nanobot.cjs.map +1 -0
- package/dist/frameworks/nanobot.d.cts +2 -0
- package/dist/frameworks/nanobot.d.mts +2 -0
- package/dist/frameworks/nanobot.mjs +125 -0
- package/dist/frameworks/nanobot.mjs.map +1 -0
- package/dist/frameworks/nanoclaw.cjs +99 -0
- package/dist/frameworks/nanoclaw.cjs.map +1 -0
- package/dist/frameworks/nanoclaw.d.cts +2 -0
- package/dist/frameworks/nanoclaw.d.mts +2 -0
- package/dist/frameworks/nanoclaw.mjs +98 -0
- package/dist/frameworks/nanoclaw.mjs.map +1 -0
- package/dist/frameworks/openclaw.cjs +253 -0
- package/dist/frameworks/openclaw.cjs.map +1 -0
- package/dist/frameworks/openclaw.d.cts +2 -0
- package/dist/frameworks/openclaw.d.mts +2 -0
- package/dist/frameworks/openclaw.mjs +251 -0
- package/dist/frameworks/openclaw.mjs.map +1 -0
- package/dist/frameworks/registry.cjs +31 -0
- package/dist/frameworks/registry.cjs.map +1 -0
- package/dist/frameworks/registry.d.cts +2 -0
- package/dist/frameworks/registry.d.mts +2 -0
- package/dist/frameworks/registry.mjs +26 -0
- package/dist/frameworks/registry.mjs.map +1 -0
- package/dist/frameworks/registry.test.cjs +110 -0
- package/dist/frameworks/registry.test.cjs.map +1 -0
- package/dist/frameworks/registry.test.d.cts +1 -0
- package/dist/frameworks/registry.test.d.mts +1 -0
- package/dist/frameworks/registry.test.mjs +111 -0
- package/dist/frameworks/registry.test.mjs.map +1 -0
- package/dist/frameworks/types.cjs +0 -0
- package/dist/frameworks/types.d.cts +2 -0
- package/dist/frameworks/types.d.mts +2 -0
- package/dist/frameworks/types.mjs +1 -0
- package/dist/frameworks/zeroclaw.cjs +123 -0
- package/dist/frameworks/zeroclaw.cjs.map +1 -0
- package/dist/frameworks/zeroclaw.d.cts +2 -0
- package/dist/frameworks/zeroclaw.d.mts +2 -0
- package/dist/frameworks/zeroclaw.mjs +122 -0
- package/dist/frameworks/zeroclaw.mjs.map +1 -0
- package/dist/generate.cjs +64 -13
- package/dist/generate.cjs.map +1 -1
- package/dist/generate.d.cts +5 -2
- package/dist/generate.d.cts.map +1 -1
- package/dist/generate.d.mts +5 -2
- package/dist/generate.d.mts.map +1 -1
- package/dist/generate.mjs +63 -12
- package/dist/generate.mjs.map +1 -1
- package/dist/generate.test.cjs +42 -6
- package/dist/generate.test.cjs.map +1 -1
- package/dist/generate.test.mjs +41 -5
- package/dist/generate.test.mjs.map +1 -1
- package/dist/generators/bare-metal-install.d.cts +1 -1
- package/dist/generators/bare-metal-install.d.mts +1 -1
- package/dist/generators/bare-metal-install.test.cjs +1 -1
- package/dist/generators/bare-metal-install.test.mjs +1 -1
- package/dist/generators/caddy.cjs +9 -3
- package/dist/generators/caddy.cjs.map +1 -1
- package/dist/generators/caddy.d.cts +1 -1
- package/dist/generators/caddy.d.mts +1 -1
- package/dist/generators/caddy.mjs +9 -3
- package/dist/generators/caddy.mjs.map +1 -1
- package/dist/generators/caddy.test.cjs +30 -2
- package/dist/generators/caddy.test.cjs.map +1 -1
- package/dist/generators/caddy.test.mjs +30 -2
- package/dist/generators/caddy.test.mjs.map +1 -1
- package/dist/generators/clone-repos.cjs.map +1 -1
- package/dist/generators/clone-repos.d.cts +1 -1
- package/dist/generators/clone-repos.d.mts +1 -1
- package/dist/generators/clone-repos.mjs.map +1 -1
- package/dist/generators/clone-repos.test.cjs +1 -1
- package/dist/generators/clone-repos.test.cjs.map +1 -1
- package/dist/generators/clone-repos.test.mjs +1 -1
- package/dist/generators/clone-repos.test.mjs.map +1 -1
- package/dist/generators/cloud-init.test.cjs +58 -0
- package/dist/generators/cloud-init.test.cjs.map +1 -0
- package/dist/generators/cloud-init.test.d.cts +1 -0
- package/dist/generators/cloud-init.test.d.mts +1 -0
- package/dist/generators/cloud-init.test.mjs +59 -0
- package/dist/generators/cloud-init.test.mjs.map +1 -0
- package/dist/generators/env.cjs +28 -103
- package/dist/generators/env.cjs.map +1 -1
- package/dist/generators/env.d.cts +4 -1
- package/dist/generators/env.d.cts.map +1 -1
- package/dist/generators/env.d.mts +4 -1
- package/dist/generators/env.d.mts.map +1 -1
- package/dist/generators/env.mjs +27 -102
- package/dist/generators/env.mjs.map +1 -1
- package/dist/generators/env.test.cjs +3 -3
- package/dist/generators/env.test.cjs.map +1 -1
- package/dist/generators/env.test.mjs +3 -3
- package/dist/generators/env.test.mjs.map +1 -1
- package/dist/generators/get-shit-done.d.cts +1 -1
- package/dist/generators/get-shit-done.d.mts +1 -1
- package/dist/generators/get-shit-done.test.cjs +48 -0
- package/dist/generators/get-shit-done.test.cjs.map +1 -0
- package/dist/generators/get-shit-done.test.d.cts +1 -0
- package/dist/generators/get-shit-done.test.d.mts +1 -0
- package/dist/generators/get-shit-done.test.mjs +49 -0
- package/dist/generators/get-shit-done.test.mjs.map +1 -0
- package/dist/generators/grafana.test.cjs +74 -0
- package/dist/generators/grafana.test.cjs.map +1 -0
- package/dist/generators/grafana.test.d.cts +1 -0
- package/dist/generators/grafana.test.d.mts +1 -0
- package/dist/generators/grafana.test.mjs +74 -0
- package/dist/generators/grafana.test.mjs.map +1 -0
- package/dist/generators/health-check.cjs +6 -6
- package/dist/generators/health-check.cjs.map +1 -1
- package/dist/generators/health-check.d.cts +1 -1
- package/dist/generators/health-check.d.mts +1 -1
- package/dist/generators/health-check.mjs +6 -6
- package/dist/generators/health-check.mjs.map +1 -1
- package/dist/generators/health-check.test.cjs +1 -1
- package/dist/generators/health-check.test.mjs +1 -1
- package/dist/generators/n8n-workflows.d.cts +1 -1
- package/dist/generators/n8n-workflows.d.mts +1 -1
- package/dist/generators/n8n-workflows.test.cjs +75 -0
- package/dist/generators/n8n-workflows.test.cjs.map +1 -0
- package/dist/generators/n8n-workflows.test.d.cts +1 -0
- package/dist/generators/n8n-workflows.test.d.mts +1 -0
- package/dist/generators/n8n-workflows.test.mjs +76 -0
- package/dist/generators/n8n-workflows.test.mjs.map +1 -0
- package/dist/generators/native-services.d.cts +1 -1
- package/dist/generators/native-services.d.mts +1 -1
- package/dist/generators/openclaw-install-script.test.cjs +35 -0
- package/dist/generators/openclaw-install-script.test.cjs.map +1 -0
- package/dist/generators/openclaw-install-script.test.d.cts +1 -0
- package/dist/generators/openclaw-install-script.test.d.mts +1 -0
- package/dist/generators/openclaw-install-script.test.mjs +36 -0
- package/dist/generators/openclaw-install-script.test.mjs.map +1 -0
- package/dist/generators/openclaw-json.cjs +60 -4
- package/dist/generators/openclaw-json.cjs.map +1 -1
- package/dist/generators/openclaw-json.d.cts +1 -5
- package/dist/generators/openclaw-json.d.cts.map +1 -1
- package/dist/generators/openclaw-json.d.mts +1 -5
- package/dist/generators/openclaw-json.d.mts.map +1 -1
- package/dist/generators/openclaw-json.mjs +60 -4
- package/dist/generators/openclaw-json.mjs.map +1 -1
- package/dist/generators/postgres-init.cjs +20 -0
- package/dist/generators/postgres-init.cjs.map +1 -1
- package/dist/generators/postgres-init.d.cts +1 -1
- package/dist/generators/postgres-init.d.cts.map +1 -1
- package/dist/generators/postgres-init.d.mts +1 -1
- package/dist/generators/postgres-init.d.mts.map +1 -1
- package/dist/generators/postgres-init.mjs +20 -0
- package/dist/generators/postgres-init.mjs.map +1 -1
- package/dist/generators/postgres-init.test.cjs +111 -0
- package/dist/generators/postgres-init.test.cjs.map +1 -0
- package/dist/generators/postgres-init.test.d.cts +1 -0
- package/dist/generators/postgres-init.test.d.mts +1 -0
- package/dist/generators/postgres-init.test.mjs +112 -0
- package/dist/generators/postgres-init.test.mjs.map +1 -0
- package/dist/generators/prometheus.d.cts +1 -1
- package/dist/generators/prometheus.d.mts +1 -1
- package/dist/generators/prometheus.test.cjs +99 -0
- package/dist/generators/prometheus.test.cjs.map +1 -0
- package/dist/generators/prometheus.test.d.cts +1 -0
- package/dist/generators/prometheus.test.d.mts +1 -0
- package/dist/generators/prometheus.test.mjs +99 -0
- package/dist/generators/prometheus.test.mjs.map +1 -0
- package/dist/generators/readme.cjs +50 -7
- package/dist/generators/readme.cjs.map +1 -1
- package/dist/generators/readme.d.cts +3 -1
- package/dist/generators/readme.d.cts.map +1 -1
- package/dist/generators/readme.d.mts +3 -1
- package/dist/generators/readme.d.mts.map +1 -1
- package/dist/generators/readme.mjs +50 -7
- package/dist/generators/readme.mjs.map +1 -1
- package/dist/generators/scripts.test.cjs +2 -2
- package/dist/generators/scripts.test.cjs.map +1 -1
- package/dist/generators/scripts.test.mjs +2 -2
- package/dist/generators/scripts.test.mjs.map +1 -1
- package/dist/generators/skills.cjs +1 -1
- package/dist/generators/skills.d.cts +1 -1
- package/dist/generators/skills.d.cts.map +1 -1
- package/dist/generators/skills.d.mts +1 -1
- package/dist/generators/skills.d.mts.map +1 -1
- package/dist/generators/skills.mjs +310 -0
- package/dist/generators/skills.mjs.map +1 -1
- package/dist/generators/stack-manifest.d.cts +1 -1
- package/dist/generators/stack-manifest.d.mts +1 -1
- package/dist/generators/stack-manifest.test.cjs +97 -0
- package/dist/generators/stack-manifest.test.cjs.map +1 -0
- package/dist/generators/stack-manifest.test.d.cts +1 -0
- package/dist/generators/stack-manifest.test.d.mts +1 -0
- package/dist/generators/stack-manifest.test.mjs +98 -0
- package/dist/generators/stack-manifest.test.mjs.map +1 -0
- package/dist/generators/traefik.d.cts +1 -1
- package/dist/generators/traefik.d.mts +1 -1
- package/dist/generators/traefik.test.cjs +12 -12
- package/dist/generators/traefik.test.cjs.map +1 -1
- package/dist/generators/traefik.test.mjs +12 -12
- package/dist/generators/traefik.test.mjs.map +1 -1
- package/dist/index.cjs +18 -2
- package/dist/index.d.cts +13 -7
- package/dist/index.d.mts +13 -7
- package/dist/index.mjs +9 -3
- package/dist/logger/__tests__/logger.test.cjs +308 -0
- package/dist/logger/__tests__/logger.test.cjs.map +1 -0
- package/dist/logger/__tests__/logger.test.d.cts +1 -0
- package/dist/logger/__tests__/logger.test.d.mts +1 -0
- package/dist/logger/__tests__/logger.test.mjs +308 -0
- package/dist/logger/__tests__/logger.test.mjs.map +1 -0
- package/dist/logger/index.cjs +8 -0
- package/dist/logger/index.d.cts +5 -0
- package/dist/logger/index.d.mts +5 -0
- package/dist/logger/index.mjs +4 -0
- package/dist/logger/logger.cjs +270 -0
- package/dist/logger/logger.cjs.map +1 -0
- package/dist/logger/logger.d.cts +2 -0
- package/dist/logger/logger.d.mts +2 -0
- package/dist/logger/logger.mjs +267 -0
- package/dist/logger/logger.mjs.map +1 -0
- package/dist/logger/sinks/callback-sink.cjs +18 -0
- package/dist/logger/sinks/callback-sink.cjs.map +1 -0
- package/dist/logger/sinks/callback-sink.d.cts +2 -0
- package/dist/logger/sinks/callback-sink.d.mts +2 -0
- package/dist/logger/sinks/callback-sink.mjs +17 -0
- package/dist/logger/sinks/callback-sink.mjs.map +1 -0
- package/dist/logger/sinks/console-sink.cjs +39 -0
- package/dist/logger/sinks/console-sink.cjs.map +1 -0
- package/dist/logger/sinks/console-sink.d.cts +2 -0
- package/dist/logger/sinks/console-sink.d.mts +2 -0
- package/dist/logger/sinks/console-sink.mjs +38 -0
- package/dist/logger/sinks/console-sink.mjs.map +1 -0
- package/dist/logger/sinks/file-sink.cjs +72 -0
- package/dist/logger/sinks/file-sink.cjs.map +1 -0
- package/dist/logger/sinks/file-sink.d.cts +36 -0
- package/dist/logger/sinks/file-sink.d.cts.map +1 -0
- package/dist/logger/sinks/file-sink.d.mts +36 -0
- package/dist/logger/sinks/file-sink.d.mts.map +1 -0
- package/dist/logger/sinks/file-sink.mjs +70 -0
- package/dist/logger/sinks/file-sink.mjs.map +1 -0
- package/dist/logger/types.cjs +0 -0
- package/dist/logger/types.d.cts +2 -0
- package/dist/logger/types.d.mts +2 -0
- package/dist/logger/types.mjs +1 -0
- package/dist/logger-CZ0Qnyiu.d.mts +66 -0
- package/dist/logger-CZ0Qnyiu.d.mts.map +1 -0
- package/dist/logger-DDfwai-A.d.cts +66 -0
- package/dist/logger-DDfwai-A.d.cts.map +1 -0
- package/dist/memu-BfRXtwmL.d.cts +7 -0
- package/dist/memu-BfRXtwmL.d.cts.map +1 -0
- package/dist/memu-C-fXbWr-.d.mts +7 -0
- package/dist/memu-C-fXbWr-.d.mts.map +1 -0
- package/dist/migrations.cjs +17 -9
- package/dist/migrations.cjs.map +1 -1
- package/dist/migrations.d.cts +1 -1
- package/dist/migrations.d.cts.map +1 -1
- package/dist/migrations.d.mts +1 -1
- package/dist/migrations.d.mts.map +1 -1
- package/dist/migrations.mjs +17 -9
- package/dist/migrations.mjs.map +1 -1
- package/dist/migrations.test.cjs +4 -4
- package/dist/migrations.test.mjs +4 -4
- package/dist/nanobot-2c0bS4lu.d.cts +7 -0
- package/dist/nanobot-2c0bS4lu.d.cts.map +1 -0
- package/dist/nanobot-BUO6pVQc.d.mts +7 -0
- package/dist/nanobot-BUO6pVQc.d.mts.map +1 -0
- package/dist/nanoclaw-CgHubEig.d.mts +7 -0
- package/dist/nanoclaw-CgHubEig.d.mts.map +1 -0
- package/dist/nanoclaw-Dvz0ef6J.d.cts +7 -0
- package/dist/nanoclaw-Dvz0ef6J.d.cts.map +1 -0
- package/dist/openclaw-D8lVecjC.d.mts +7 -0
- package/dist/openclaw-D8lVecjC.d.mts.map +1 -0
- package/dist/openclaw-DThj8i3N.d.cts +7 -0
- package/dist/openclaw-DThj8i3N.d.cts.map +1 -0
- package/dist/port-scanner.d.cts +1 -1
- package/dist/port-scanner.d.mts +1 -1
- package/dist/port-scanner.test.cjs +155 -0
- package/dist/port-scanner.test.cjs.map +1 -0
- package/dist/port-scanner.test.d.cts +1 -0
- package/dist/port-scanner.test.d.mts +1 -0
- package/dist/port-scanner.test.mjs +156 -0
- package/dist/port-scanner.test.mjs.map +1 -0
- package/dist/presets/presets.test.cjs +5 -5
- package/dist/presets/presets.test.cjs.map +1 -1
- package/dist/presets/presets.test.mjs +4 -4
- package/dist/presets/presets.test.mjs.map +1 -1
- package/dist/presets/registry.d.cts +1 -1
- package/dist/presets/registry.d.mts +1 -1
- package/dist/presets/registry.test.cjs +7 -7
- package/dist/presets/registry.test.cjs.map +1 -1
- package/dist/presets/registry.test.mjs +7 -7
- package/dist/presets/registry.test.mjs.map +1 -1
- package/dist/registry-DHX7vnVo.d.cts +16 -0
- package/dist/registry-DHX7vnVo.d.cts.map +1 -0
- package/dist/registry-DTAILnga.d.mts +16 -0
- package/dist/registry-DTAILnga.d.mts.map +1 -0
- package/dist/resolver.cjs +13 -3
- package/dist/resolver.cjs.map +1 -1
- package/dist/resolver.d.cts +1 -1
- package/dist/resolver.d.cts.map +1 -1
- package/dist/resolver.d.mts +1 -1
- package/dist/resolver.d.mts.map +1 -1
- package/dist/resolver.mjs +13 -3
- package/dist/resolver.mjs.map +1 -1
- package/dist/resolver.test.cjs +35 -3
- package/dist/resolver.test.cjs.map +1 -1
- package/dist/resolver.test.mjs +35 -3
- package/dist/resolver.test.mjs.map +1 -1
- package/dist/{schema-BQnZrcw8.d.cts → schema-BSl9wiFe.d.mts} +134 -2
- package/dist/schema-BSl9wiFe.d.mts.map +1 -0
- package/dist/{schema-SBpL0bdI.d.mts → schema-Bd9l2r7p.d.cts} +134 -2
- package/dist/schema-Bd9l2r7p.d.cts.map +1 -0
- package/dist/schema.cjs +28 -4
- package/dist/schema.cjs.map +1 -1
- package/dist/schema.d.cts +2 -2
- package/dist/schema.d.mts +2 -2
- package/dist/schema.mjs +27 -4
- package/dist/schema.mjs.map +1 -1
- package/dist/schema.test.cjs +3 -3
- package/dist/schema.test.cjs.map +1 -1
- package/dist/schema.test.mjs +3 -3
- package/dist/schema.test.mjs.map +1 -1
- package/dist/services/definitions/adguard-home.d.cts +1 -1
- package/dist/services/definitions/adguard-home.d.mts +1 -1
- package/dist/services/definitions/agent-browser.cjs +161 -0
- package/dist/services/definitions/agent-browser.cjs.map +1 -0
- package/dist/services/definitions/agent-browser.d.cts +7 -0
- package/dist/services/definitions/agent-browser.d.cts.map +1 -0
- package/dist/services/definitions/agent-browser.d.mts +7 -0
- package/dist/services/definitions/agent-browser.d.mts.map +1 -0
- package/dist/services/definitions/agent-browser.mjs +160 -0
- package/dist/services/definitions/agent-browser.mjs.map +1 -0
- package/dist/services/definitions/airbyte.d.cts +1 -1
- package/dist/services/definitions/airbyte.d.mts +1 -1
- package/dist/services/definitions/airflow.d.cts +1 -1
- package/dist/services/definitions/airflow.d.mts +1 -1
- package/dist/services/definitions/anything-llm.d.cts +1 -1
- package/dist/services/definitions/anything-llm.d.mts +1 -1
- package/dist/services/definitions/appflowy.d.cts +1 -1
- package/dist/services/definitions/appflowy.d.mts +1 -1
- package/dist/services/definitions/apptension-saas.cjs.map +1 -1
- package/dist/services/definitions/apptension-saas.d.cts +1 -1
- package/dist/services/definitions/apptension-saas.d.mts +1 -1
- package/dist/services/definitions/apptension-saas.mjs.map +1 -1
- package/dist/services/definitions/appwrite.d.cts +1 -1
- package/dist/services/definitions/appwrite.d.mts +1 -1
- package/dist/services/definitions/audiobookshelf.d.cts +1 -1
- package/dist/services/definitions/audiobookshelf.d.mts +1 -1
- package/dist/services/definitions/authelia.d.cts +1 -1
- package/dist/services/definitions/authelia.d.mts +1 -1
- package/dist/services/definitions/authentik.d.cts +1 -1
- package/dist/services/definitions/authentik.d.mts +1 -1
- package/dist/services/definitions/axolotl.d.cts +1 -1
- package/dist/services/definitions/axolotl.d.mts +1 -1
- package/dist/services/definitions/baserow.d.cts +1 -1
- package/dist/services/definitions/baserow.d.mts +1 -1
- package/dist/services/definitions/beszel.d.cts +1 -1
- package/dist/services/definitions/beszel.d.mts +1 -1
- package/dist/services/definitions/boxyhq-saas.d.cts +1 -1
- package/dist/services/definitions/boxyhq-saas.d.mts +1 -1
- package/dist/services/definitions/browserless.d.cts +1 -1
- package/dist/services/definitions/browserless.d.mts +1 -1
- package/dist/services/definitions/burnlink.d.cts +1 -1
- package/dist/services/definitions/burnlink.d.mts +1 -1
- package/dist/services/definitions/caddy.d.cts +1 -1
- package/dist/services/definitions/caddy.d.mts +1 -1
- package/dist/services/definitions/cal-com.d.cts +1 -1
- package/dist/services/definitions/cal-com.d.mts +1 -1
- package/dist/services/definitions/calibre-web.d.cts +1 -1
- package/dist/services/definitions/calibre-web.d.mts +1 -1
- package/dist/services/definitions/chatwoot-worker.d.cts +1 -1
- package/dist/services/definitions/chatwoot-worker.d.mts +1 -1
- package/dist/services/definitions/chatwoot.d.cts +1 -1
- package/dist/services/definitions/chatwoot.d.mts +1 -1
- package/dist/services/definitions/chromadb.cjs +4 -1
- package/dist/services/definitions/chromadb.cjs.map +1 -1
- package/dist/services/definitions/chromadb.d.cts +1 -1
- package/dist/services/definitions/chromadb.d.mts +1 -1
- package/dist/services/definitions/chromadb.mjs +4 -1
- package/dist/services/definitions/chromadb.mjs.map +1 -1
- package/dist/services/definitions/claude-code.cjs +1 -1
- package/dist/services/definitions/claude-code.cjs.map +1 -1
- package/dist/services/definitions/claude-code.d.cts +1 -1
- package/dist/services/definitions/claude-code.d.mts +1 -1
- package/dist/services/definitions/claude-code.mjs +1 -1
- package/dist/services/definitions/claude-code.mjs.map +1 -1
- package/dist/services/definitions/clawrouter.cjs +138 -0
- package/dist/services/definitions/clawrouter.cjs.map +1 -0
- package/dist/services/definitions/clawrouter.d.cts +7 -0
- package/dist/services/definitions/clawrouter.d.cts.map +1 -0
- package/dist/services/definitions/clawrouter.d.mts +7 -0
- package/dist/services/definitions/clawrouter.d.mts.map +1 -0
- package/dist/services/definitions/clawrouter.mjs +137 -0
- package/dist/services/definitions/clawrouter.mjs.map +1 -0
- package/dist/services/definitions/clickhouse.d.cts +1 -1
- package/dist/services/definitions/clickhouse.d.mts +1 -1
- package/dist/services/definitions/cloudflared.d.cts +1 -1
- package/dist/services/definitions/cloudflared.d.mts +1 -1
- package/dist/services/definitions/cmsaas-starter.d.cts +1 -1
- package/dist/services/definitions/cmsaas-starter.d.mts +1 -1
- package/dist/services/definitions/cockroachdb.d.cts +1 -1
- package/dist/services/definitions/cockroachdb.d.mts +1 -1
- package/dist/services/definitions/code-server.d.cts +1 -1
- package/dist/services/definitions/code-server.d.mts +1 -1
- package/dist/services/definitions/coder.d.cts +1 -1
- package/dist/services/definitions/coder.d.mts +1 -1
- package/dist/services/definitions/codex.cjs +1 -1
- package/dist/services/definitions/codex.cjs.map +1 -1
- package/dist/services/definitions/codex.d.cts +1 -1
- package/dist/services/definitions/codex.d.mts +1 -1
- package/dist/services/definitions/codex.mjs +1 -1
- package/dist/services/definitions/codex.mjs.map +1 -1
- package/dist/services/definitions/comfyui.d.cts +1 -1
- package/dist/services/definitions/comfyui.d.mts +1 -1
- package/dist/services/definitions/convex-dashboard.d.cts +1 -1
- package/dist/services/definitions/convex-dashboard.d.mts +1 -1
- package/dist/services/definitions/convex.cjs.map +1 -1
- package/dist/services/definitions/convex.d.cts +1 -1
- package/dist/services/definitions/convex.d.mts +1 -1
- package/dist/services/definitions/convex.mjs.map +1 -1
- package/dist/services/definitions/coolify.d.cts +1 -1
- package/dist/services/definitions/coolify.d.mts +1 -1
- package/dist/services/definitions/copaw.cjs +97 -0
- package/dist/services/definitions/copaw.cjs.map +1 -0
- package/dist/services/definitions/copaw.d.cts +7 -0
- package/dist/services/definitions/copaw.d.cts.map +1 -0
- package/dist/services/definitions/copaw.d.mts +7 -0
- package/dist/services/definitions/copaw.d.mts.map +1 -0
- package/dist/services/definitions/copaw.mjs +96 -0
- package/dist/services/definitions/copaw.mjs.map +1 -0
- package/dist/services/definitions/crowdsec.d.cts +1 -1
- package/dist/services/definitions/crowdsec.d.mts +1 -1
- package/dist/services/definitions/dagster.d.cts +1 -1
- package/dist/services/definitions/dagster.d.mts +1 -1
- package/dist/services/definitions/desktop-environment.cjs +2 -1
- package/dist/services/definitions/desktop-environment.cjs.map +1 -1
- package/dist/services/definitions/desktop-environment.d.cts +1 -1
- package/dist/services/definitions/desktop-environment.d.mts +1 -1
- package/dist/services/definitions/desktop-environment.mjs +2 -1
- package/dist/services/definitions/desktop-environment.mjs.map +1 -1
- package/dist/services/definitions/dify.d.cts +1 -1
- package/dist/services/definitions/dify.d.mts +1 -1
- package/dist/services/definitions/directus.d.cts +1 -1
- package/dist/services/definitions/directus.d.mts +1 -1
- package/dist/services/definitions/docsgpt.d.cts +1 -1
- package/dist/services/definitions/docsgpt.d.mts +1 -1
- package/dist/services/definitions/dokploy.d.cts +1 -1
- package/dist/services/definitions/dokploy.d.mts +1 -1
- package/dist/services/definitions/dozzle.d.cts +1 -1
- package/dist/services/definitions/dozzle.d.mts +1 -1
- package/dist/services/definitions/dragonfly.d.cts +1 -1
- package/dist/services/definitions/dragonfly.d.mts +1 -1
- package/dist/services/definitions/drone-ci.d.cts +1 -1
- package/dist/services/definitions/drone-ci.d.mts +1 -1
- package/dist/services/definitions/duplicati.d.cts +1 -1
- package/dist/services/definitions/duplicati.d.mts +1 -1
- package/dist/services/definitions/element-web.d.cts +1 -1
- package/dist/services/definitions/element-web.d.mts +1 -1
- package/dist/services/definitions/excalidraw.d.cts +1 -1
- package/dist/services/definitions/excalidraw.d.mts +1 -1
- package/dist/services/definitions/ffmpeg.d.cts +1 -1
- package/dist/services/definitions/ffmpeg.d.mts +1 -1
- package/dist/services/definitions/firecrawl-playwright.d.cts +1 -1
- package/dist/services/definitions/firecrawl-playwright.d.mts +1 -1
- package/dist/services/definitions/firecrawl.d.cts +1 -1
- package/dist/services/definitions/firecrawl.d.mts +1 -1
- package/dist/services/definitions/flagsmith.d.cts +1 -1
- package/dist/services/definitions/flagsmith.d.mts +1 -1
- package/dist/services/definitions/flowise.d.cts +1 -1
- package/dist/services/definitions/flowise.d.mts +1 -1
- package/dist/services/definitions/focalboard.d.cts +1 -1
- package/dist/services/definitions/focalboard.d.mts +1 -1
- package/dist/services/definitions/fonoster.d.cts +1 -1
- package/dist/services/definitions/fonoster.d.mts +1 -1
- package/dist/services/definitions/forgejo.d.cts +1 -1
- package/dist/services/definitions/forgejo.d.mts +1 -1
- package/dist/services/definitions/formbricks.d.cts +1 -1
- package/dist/services/definitions/formbricks.d.mts +1 -1
- package/dist/services/definitions/gemini-cli.d.cts +1 -1
- package/dist/services/definitions/gemini-cli.d.mts +1 -1
- package/dist/services/definitions/ghost.d.cts +1 -1
- package/dist/services/definitions/ghost.d.mts +1 -1
- package/dist/services/definitions/gitea.d.cts +1 -1
- package/dist/services/definitions/gitea.d.mts +1 -1
- package/dist/services/definitions/gotify.d.cts +1 -1
- package/dist/services/definitions/gotify.d.mts +1 -1
- package/dist/services/definitions/grafana.d.cts +1 -1
- package/dist/services/definitions/grafana.d.mts +1 -1
- package/dist/services/definitions/graylog.d.cts +1 -1
- package/dist/services/definitions/graylog.d.mts +1 -1
- package/dist/services/definitions/headscale.d.cts +1 -1
- package/dist/services/definitions/headscale.d.mts +1 -1
- package/dist/services/definitions/hedgedoc.d.cts +1 -1
- package/dist/services/definitions/hedgedoc.d.mts +1 -1
- package/dist/services/definitions/hexstrike.d.cts +1 -1
- package/dist/services/definitions/hexstrike.d.mts +1 -1
- package/dist/services/definitions/heyform.d.cts +1 -1
- package/dist/services/definitions/heyform.d.mts +1 -1
- package/dist/services/definitions/hindsight.cjs +4 -1
- package/dist/services/definitions/hindsight.cjs.map +1 -1
- package/dist/services/definitions/hindsight.d.cts +1 -1
- package/dist/services/definitions/hindsight.d.mts +1 -1
- package/dist/services/definitions/hindsight.mjs +4 -1
- package/dist/services/definitions/hindsight.mjs.map +1 -1
- package/dist/services/definitions/homeassistant.d.cts +1 -1
- package/dist/services/definitions/homeassistant.d.mts +1 -1
- package/dist/services/definitions/hoppscotch.d.cts +1 -1
- package/dist/services/definitions/hoppscotch.d.mts +1 -1
- package/dist/services/definitions/immich.d.cts +1 -1
- package/dist/services/definitions/immich.d.mts +1 -1
- package/dist/services/definitions/index.cjs +42 -6
- package/dist/services/definitions/index.cjs.map +1 -1
- package/dist/services/definitions/index.d.cts +16 -4
- package/dist/services/definitions/index.d.cts.map +1 -1
- package/dist/services/definitions/index.d.mts +16 -4
- package/dist/services/definitions/index.d.mts.map +1 -1
- package/dist/services/definitions/index.mjs +31 -7
- package/dist/services/definitions/index.mjs.map +1 -1
- package/dist/services/definitions/infisical.d.cts +1 -1
- package/dist/services/definitions/infisical.d.mts +1 -1
- package/dist/services/definitions/influxdb.d.cts +1 -1
- package/dist/services/definitions/influxdb.d.mts +1 -1
- package/dist/services/definitions/invoke-ai.d.cts +1 -1
- package/dist/services/definitions/invoke-ai.d.mts +1 -1
- package/dist/services/definitions/ixartz-saas.d.cts +1 -1
- package/dist/services/definitions/ixartz-saas.d.mts +1 -1
- package/dist/services/definitions/jaeger.d.cts +1 -1
- package/dist/services/definitions/jaeger.d.mts +1 -1
- package/dist/services/definitions/jan.d.cts +1 -1
- package/dist/services/definitions/jan.d.mts +1 -1
- package/dist/services/definitions/jellyfin.d.cts +1 -1
- package/dist/services/definitions/jellyfin.d.mts +1 -1
- package/dist/services/definitions/jenkins.d.cts +1 -1
- package/dist/services/definitions/jenkins.d.mts +1 -1
- package/dist/services/definitions/jitsi-meet.d.cts +1 -1
- package/dist/services/definitions/jitsi-meet.d.mts +1 -1
- package/dist/services/definitions/keycloak.d.cts +1 -1
- package/dist/services/definitions/keycloak.d.mts +1 -1
- package/dist/services/definitions/kimi.d.cts +1 -1
- package/dist/services/definitions/kimi.d.mts +1 -1
- package/dist/services/definitions/kong.d.cts +1 -1
- package/dist/services/definitions/kong.d.mts +1 -1
- package/dist/services/definitions/lago.d.cts +1 -1
- package/dist/services/definitions/lago.d.mts +1 -1
- package/dist/services/definitions/langflow.d.cts +1 -1
- package/dist/services/definitions/langflow.d.mts +1 -1
- package/dist/services/definitions/langfuse.d.cts +1 -1
- package/dist/services/definitions/langfuse.d.mts +1 -1
- package/dist/services/definitions/lasuite-meet-agents.d.cts +1 -1
- package/dist/services/definitions/lasuite-meet-agents.d.mts +1 -1
- package/dist/services/definitions/lasuite-meet-backend.d.cts +1 -1
- package/dist/services/definitions/lasuite-meet-backend.d.mts +1 -1
- package/dist/services/definitions/lasuite-meet-frontend.d.cts +1 -1
- package/dist/services/definitions/lasuite-meet-frontend.d.mts +1 -1
- package/dist/services/definitions/librechat.d.cts +1 -1
- package/dist/services/definitions/librechat.d.mts +1 -1
- package/dist/services/definitions/lightpanda.d.cts +1 -1
- package/dist/services/definitions/lightpanda.d.mts +1 -1
- package/dist/services/definitions/listmonk.d.cts +1 -1
- package/dist/services/definitions/listmonk.d.mts +1 -1
- package/dist/services/definitions/litellm.d.cts +1 -1
- package/dist/services/definitions/litellm.d.mts +1 -1
- package/dist/services/definitions/livekit.d.cts +1 -1
- package/dist/services/definitions/livekit.d.mts +1 -1
- package/dist/services/definitions/local-ai.d.cts +1 -1
- package/dist/services/definitions/local-ai.d.mts +1 -1
- package/dist/services/definitions/loki.d.cts +1 -1
- package/dist/services/definitions/loki.d.mts +1 -1
- package/dist/services/definitions/mariadb.d.cts +1 -1
- package/dist/services/definitions/mariadb.d.mts +1 -1
- package/dist/services/definitions/matomo.d.cts +1 -1
- package/dist/services/definitions/matomo.d.mts +1 -1
- package/dist/services/definitions/matrix-synapse.d.cts +1 -1
- package/dist/services/definitions/matrix-synapse.d.mts +1 -1
- package/dist/services/definitions/mattermost.d.cts +1 -1
- package/dist/services/definitions/mattermost.d.mts +1 -1
- package/dist/services/definitions/mautic.d.cts +1 -1
- package/dist/services/definitions/mautic.d.mts +1 -1
- package/dist/services/definitions/medusa.d.cts +1 -1
- package/dist/services/definitions/medusa.d.mts +1 -1
- package/dist/services/definitions/meilisearch.d.cts +1 -1
- package/dist/services/definitions/meilisearch.d.mts +1 -1
- package/dist/services/definitions/mem0.cjs +133 -0
- package/dist/services/definitions/mem0.cjs.map +1 -0
- package/dist/services/definitions/mem0.d.cts +7 -0
- package/dist/services/definitions/mem0.d.cts.map +1 -0
- package/dist/services/definitions/mem0.d.mts +7 -0
- package/dist/services/definitions/mem0.d.mts.map +1 -0
- package/dist/services/definitions/mem0.mjs +132 -0
- package/dist/services/definitions/mem0.mjs.map +1 -0
- package/dist/services/definitions/memu.cjs +96 -0
- package/dist/services/definitions/memu.cjs.map +1 -0
- package/dist/services/definitions/memu.d.cts +7 -0
- package/dist/services/definitions/memu.d.cts.map +1 -0
- package/dist/services/definitions/memu.d.mts +7 -0
- package/dist/services/definitions/memu.d.mts.map +1 -0
- package/dist/services/definitions/memu.mjs +95 -0
- package/dist/services/definitions/memu.mjs.map +1 -0
- package/dist/services/definitions/metabase.d.cts +1 -1
- package/dist/services/definitions/metabase.d.mts +1 -1
- package/dist/services/definitions/milvus.cjs +4 -1
- package/dist/services/definitions/milvus.cjs.map +1 -1
- package/dist/services/definitions/milvus.d.cts +1 -1
- package/dist/services/definitions/milvus.d.mts +1 -1
- package/dist/services/definitions/milvus.mjs +4 -1
- package/dist/services/definitions/milvus.mjs.map +1 -1
- package/dist/services/definitions/minio.d.cts +1 -1
- package/dist/services/definitions/minio.d.mts +1 -1
- package/dist/services/definitions/mission-control.d.cts +1 -1
- package/dist/services/definitions/mission-control.d.mts +1 -1
- package/dist/services/definitions/mixpost.d.cts +1 -1
- package/dist/services/definitions/mixpost.d.mts +1 -1
- package/dist/services/definitions/mosquitto.d.cts +1 -1
- package/dist/services/definitions/mosquitto.d.mts +1 -1
- package/dist/services/definitions/motion-canvas.d.cts +1 -1
- package/dist/services/definitions/motion-canvas.d.mts +1 -1
- package/dist/services/definitions/mysql.d.cts +1 -1
- package/dist/services/definitions/mysql.d.mts +1 -1
- package/dist/services/definitions/n8n.d.cts +1 -1
- package/dist/services/definitions/n8n.d.mts +1 -1
- package/dist/services/definitions/nanobot.cjs +86 -0
- package/dist/services/definitions/nanobot.cjs.map +1 -0
- package/dist/services/definitions/nanobot.d.cts +7 -0
- package/dist/services/definitions/nanobot.d.cts.map +1 -0
- package/dist/services/definitions/nanobot.d.mts +7 -0
- package/dist/services/definitions/nanobot.d.mts.map +1 -0
- package/dist/services/definitions/nanobot.mjs +85 -0
- package/dist/services/definitions/nanobot.mjs.map +1 -0
- package/dist/services/definitions/nanoclaw.cjs +79 -0
- package/dist/services/definitions/nanoclaw.cjs.map +1 -0
- package/dist/services/definitions/nanoclaw.d.cts +7 -0
- package/dist/services/definitions/nanoclaw.d.cts.map +1 -0
- package/dist/services/definitions/nanoclaw.d.mts +7 -0
- package/dist/services/definitions/nanoclaw.d.mts.map +1 -0
- package/dist/services/definitions/nanoclaw.mjs +78 -0
- package/dist/services/definitions/nanoclaw.mjs.map +1 -0
- package/dist/services/definitions/navidrome.d.cts +1 -1
- package/dist/services/definitions/navidrome.d.mts +1 -1
- package/dist/services/definitions/neo4j.d.cts +1 -1
- package/dist/services/definitions/neo4j.d.mts +1 -1
- package/dist/services/definitions/nextcloud.d.cts +1 -1
- package/dist/services/definitions/nextcloud.d.mts +1 -1
- package/dist/services/definitions/nginx-proxy-manager.d.cts +1 -1
- package/dist/services/definitions/nginx-proxy-manager.d.mts +1 -1
- package/dist/services/definitions/nocodb.d.cts +1 -1
- package/dist/services/definitions/nocodb.d.mts +1 -1
- package/dist/services/definitions/node-red.d.cts +1 -1
- package/dist/services/definitions/node-red.d.mts +1 -1
- package/dist/services/definitions/ntfy.d.cts +1 -1
- package/dist/services/definitions/ntfy.d.mts +1 -1
- package/dist/services/definitions/ollama.d.cts +1 -1
- package/dist/services/definitions/ollama.d.mts +1 -1
- package/dist/services/definitions/open-saas.d.cts +1 -1
- package/dist/services/definitions/open-saas.d.mts +1 -1
- package/dist/services/definitions/open-webui.d.cts +1 -1
- package/dist/services/definitions/open-webui.d.mts +1 -1
- package/dist/services/definitions/opencode.d.cts +1 -1
- package/dist/services/definitions/opencode.d.mts +1 -1
- package/dist/services/definitions/openhands.d.cts +1 -1
- package/dist/services/definitions/openhands.d.mts +1 -1
- package/dist/services/definitions/openpanel.d.cts +1 -1
- package/dist/services/definitions/openpanel.d.mts +1 -1
- package/dist/services/definitions/opensandbox.cjs +2 -1
- package/dist/services/definitions/opensandbox.cjs.map +1 -1
- package/dist/services/definitions/opensandbox.d.cts +1 -1
- package/dist/services/definitions/opensandbox.d.mts +1 -1
- package/dist/services/definitions/opensandbox.mjs +2 -1
- package/dist/services/definitions/opensandbox.mjs.map +1 -1
- package/dist/services/definitions/opensearch.d.cts +1 -1
- package/dist/services/definitions/opensearch.d.mts +1 -1
- package/dist/services/definitions/outline.d.cts +1 -1
- package/dist/services/definitions/outline.d.mts +1 -1
- package/dist/services/definitions/paperless-ngx.d.cts +1 -1
- package/dist/services/definitions/paperless-ngx.d.mts +1 -1
- package/dist/services/definitions/pentagi.d.cts +1 -1
- package/dist/services/definitions/pentagi.d.mts +1 -1
- package/dist/services/definitions/pentestagent.d.cts +1 -1
- package/dist/services/definitions/pentestagent.d.mts +1 -1
- package/dist/services/definitions/photoprism.d.cts +1 -1
- package/dist/services/definitions/photoprism.d.mts +1 -1
- package/dist/services/definitions/pihole.d.cts +1 -1
- package/dist/services/definitions/pihole.d.mts +1 -1
- package/dist/services/definitions/piper-tts.d.cts +1 -1
- package/dist/services/definitions/piper-tts.d.mts +1 -1
- package/dist/services/definitions/plane.d.cts +1 -1
- package/dist/services/definitions/plane.d.mts +1 -1
- package/dist/services/definitions/plausible.d.cts +1 -1
- package/dist/services/definitions/plausible.d.mts +1 -1
- package/dist/services/definitions/playwright-server.d.cts +1 -1
- package/dist/services/definitions/playwright-server.d.mts +1 -1
- package/dist/services/definitions/pocket-id.d.cts +1 -1
- package/dist/services/definitions/pocket-id.d.mts +1 -1
- package/dist/services/definitions/pocketbase.d.cts +1 -1
- package/dist/services/definitions/pocketbase.d.mts +1 -1
- package/dist/services/definitions/portainer.d.cts +1 -1
- package/dist/services/definitions/portainer.d.mts +1 -1
- package/dist/services/definitions/postgresql.d.cts +1 -1
- package/dist/services/definitions/postgresql.d.mts +1 -1
- package/dist/services/definitions/posthog.d.cts +1 -1
- package/dist/services/definitions/posthog.d.mts +1 -1
- package/dist/services/definitions/postiz.d.cts +1 -1
- package/dist/services/definitions/postiz.d.mts +1 -1
- package/dist/services/definitions/prometheus.d.cts +1 -1
- package/dist/services/definitions/prometheus.d.mts +1 -1
- package/dist/services/definitions/qdrant.d.cts +1 -1
- package/dist/services/definitions/qdrant.d.mts +1 -1
- package/dist/services/definitions/rabbitmq.d.cts +1 -1
- package/dist/services/definitions/rabbitmq.d.mts +1 -1
- package/dist/services/definitions/ragflow.d.cts +1 -1
- package/dist/services/definitions/ragflow.d.mts +1 -1
- package/dist/services/definitions/redis.d.cts +1 -1
- package/dist/services/definitions/redis.d.mts +1 -1
- package/dist/services/definitions/relaticle-horizon.cjs +48 -0
- package/dist/services/definitions/relaticle-horizon.cjs.map +1 -0
- package/dist/services/definitions/relaticle-horizon.d.cts +7 -0
- package/dist/services/definitions/relaticle-horizon.d.cts.map +1 -0
- package/dist/services/definitions/relaticle-horizon.d.mts +7 -0
- package/dist/services/definitions/relaticle-horizon.d.mts.map +1 -0
- package/dist/services/definitions/relaticle-horizon.mjs +48 -0
- package/dist/services/definitions/relaticle-horizon.mjs.map +1 -0
- package/dist/services/definitions/relaticle-scheduler.cjs +44 -0
- package/dist/services/definitions/relaticle-scheduler.cjs.map +1 -0
- package/dist/services/definitions/relaticle-scheduler.d.cts +7 -0
- package/dist/services/definitions/relaticle-scheduler.d.cts.map +1 -0
- package/dist/services/definitions/relaticle-scheduler.d.mts +7 -0
- package/dist/services/definitions/relaticle-scheduler.d.mts.map +1 -0
- package/dist/services/definitions/relaticle-scheduler.mjs +44 -0
- package/dist/services/definitions/relaticle-scheduler.mjs.map +1 -0
- package/dist/services/definitions/relaticle.cjs +151 -0
- package/dist/services/definitions/relaticle.cjs.map +1 -0
- package/dist/services/definitions/relaticle.d.cts +80 -0
- package/dist/services/definitions/relaticle.d.cts.map +1 -0
- package/dist/services/definitions/relaticle.d.mts +80 -0
- package/dist/services/definitions/relaticle.d.mts.map +1 -0
- package/dist/services/definitions/relaticle.mjs +149 -0
- package/dist/services/definitions/relaticle.mjs.map +1 -0
- package/dist/services/definitions/remotion.d.cts +1 -1
- package/dist/services/definitions/remotion.d.mts +1 -1
- package/dist/services/definitions/restic.d.cts +1 -1
- package/dist/services/definitions/restic.d.mts +1 -1
- package/dist/services/definitions/revolt.d.cts +1 -1
- package/dist/services/definitions/revolt.d.mts +1 -1
- package/dist/services/definitions/rocketchat.d.cts +1 -1
- package/dist/services/definitions/rocketchat.d.mts +1 -1
- package/dist/services/definitions/saleor.d.cts +1 -1
- package/dist/services/definitions/saleor.d.mts +1 -1
- package/dist/services/definitions/scrapling.d.cts +1 -1
- package/dist/services/definitions/scrapling.d.mts +1 -1
- package/dist/services/definitions/searxng.d.cts +1 -1
- package/dist/services/definitions/searxng.d.mts +1 -1
- package/dist/services/definitions/sentry.d.cts +1 -1
- package/dist/services/definitions/sentry.d.mts +1 -1
- package/dist/services/definitions/signoz.d.cts +1 -1
- package/dist/services/definitions/signoz.d.mts +1 -1
- package/dist/services/definitions/solidityguard.d.cts +1 -1
- package/dist/services/definitions/solidityguard.d.mts +1 -1
- package/dist/services/definitions/sonarqube.d.cts +1 -1
- package/dist/services/definitions/sonarqube.d.mts +1 -1
- package/dist/services/definitions/stable-diffusion.d.cts +1 -1
- package/dist/services/definitions/stable-diffusion.d.mts +1 -1
- package/dist/services/definitions/steel-browser.d.cts +1 -1
- package/dist/services/definitions/steel-browser.d.mts +1 -1
- package/dist/services/definitions/stirling-pdf.d.cts +1 -1
- package/dist/services/definitions/stirling-pdf.d.mts +1 -1
- package/dist/services/definitions/strapi.d.cts +1 -1
- package/dist/services/definitions/strapi.d.mts +1 -1
- package/dist/services/definitions/stream-gateway.d.cts +1 -1
- package/dist/services/definitions/stream-gateway.d.mts +1 -1
- package/dist/services/definitions/supabase.d.cts +1 -1
- package/dist/services/definitions/supabase.d.mts +1 -1
- package/dist/services/definitions/superset.d.cts +1 -1
- package/dist/services/definitions/superset.d.mts +1 -1
- package/dist/services/definitions/surrealdb.d.cts +1 -1
- package/dist/services/definitions/surrealdb.d.mts +1 -1
- package/dist/services/definitions/tabby-ml.d.cts +1 -1
- package/dist/services/definitions/tabby-ml.d.mts +1 -1
- package/dist/services/definitions/tailscale.d.cts +1 -1
- package/dist/services/definitions/tailscale.d.mts +1 -1
- package/dist/services/definitions/tempo.d.cts +1 -1
- package/dist/services/definitions/tempo.d.mts +1 -1
- package/dist/services/definitions/temporal.d.cts +1 -1
- package/dist/services/definitions/temporal.d.mts +1 -1
- package/dist/services/definitions/text-gen-webui.d.cts +1 -1
- package/dist/services/definitions/text-gen-webui.d.mts +1 -1
- package/dist/services/definitions/timescaledb.d.cts +1 -1
- package/dist/services/definitions/timescaledb.d.mts +1 -1
- package/dist/services/definitions/traefik.d.cts +1 -1
- package/dist/services/definitions/traefik.d.mts +1 -1
- package/dist/services/definitions/twenty-worker.cjs +73 -0
- package/dist/services/definitions/twenty-worker.cjs.map +1 -0
- package/dist/services/definitions/twenty-worker.d.cts +7 -0
- package/dist/services/definitions/twenty-worker.d.cts.map +1 -0
- package/dist/services/definitions/twenty-worker.d.mts +7 -0
- package/dist/services/definitions/twenty-worker.d.mts.map +1 -0
- package/dist/services/definitions/twenty-worker.mjs +72 -0
- package/dist/services/definitions/twenty-worker.mjs.map +1 -0
- package/dist/services/definitions/twenty.cjs +24 -2
- package/dist/services/definitions/twenty.cjs.map +1 -1
- package/dist/services/definitions/twenty.d.cts +1 -1
- package/dist/services/definitions/twenty.d.mts +1 -1
- package/dist/services/definitions/twenty.mjs +24 -2
- package/dist/services/definitions/twenty.mjs.map +1 -1
- package/dist/services/definitions/umami.d.cts +1 -1
- package/dist/services/definitions/umami.d.mts +1 -1
- package/dist/services/definitions/uptime-kuma.d.cts +1 -1
- package/dist/services/definitions/uptime-kuma.d.mts +1 -1
- package/dist/services/definitions/usesend.d.cts +1 -1
- package/dist/services/definitions/usesend.d.mts +1 -1
- package/dist/services/definitions/valkey.d.cts +1 -1
- package/dist/services/definitions/valkey.d.mts +1 -1
- package/dist/services/definitions/vault.d.cts +1 -1
- package/dist/services/definitions/vault.d.mts +1 -1
- package/dist/services/definitions/vaultwarden.d.cts +1 -1
- package/dist/services/definitions/vaultwarden.d.mts +1 -1
- package/dist/services/definitions/vector-log.d.cts +1 -1
- package/dist/services/definitions/vector-log.d.mts +1 -1
- package/dist/services/definitions/vikunja.d.cts +1 -1
- package/dist/services/definitions/vikunja.d.mts +1 -1
- package/dist/services/definitions/watchtower.d.cts +1 -1
- package/dist/services/definitions/watchtower.d.mts +1 -1
- package/dist/services/definitions/weaviate.cjs +4 -1
- package/dist/services/definitions/weaviate.cjs.map +1 -1
- package/dist/services/definitions/weaviate.d.cts +1 -1
- package/dist/services/definitions/weaviate.d.mts +1 -1
- package/dist/services/definitions/weaviate.mjs +4 -1
- package/dist/services/definitions/weaviate.mjs.map +1 -1
- package/dist/services/definitions/whisper.d.cts +1 -1
- package/dist/services/definitions/whisper.d.mts +1 -1
- package/dist/services/definitions/wireguard.d.cts +1 -1
- package/dist/services/definitions/wireguard.d.mts +1 -1
- package/dist/services/definitions/woodpecker-ci.d.cts +1 -1
- package/dist/services/definitions/woodpecker-ci.d.mts +1 -1
- package/dist/services/definitions/xyops.d.cts +1 -1
- package/dist/services/definitions/xyops.d.mts +1 -1
- package/dist/services/definitions/zeroclaw.cjs +103 -0
- package/dist/services/definitions/zeroclaw.cjs.map +1 -0
- package/dist/services/definitions/zeroclaw.d.cts +7 -0
- package/dist/services/definitions/zeroclaw.d.cts.map +1 -0
- package/dist/services/definitions/zeroclaw.d.mts +7 -0
- package/dist/services/definitions/zeroclaw.d.mts.map +1 -0
- package/dist/services/definitions/zeroclaw.mjs +102 -0
- package/dist/services/definitions/zeroclaw.mjs.map +1 -0
- package/dist/services/definitions/zulip.d.cts +1 -1
- package/dist/services/definitions/zulip.d.mts +1 -1
- package/dist/services/registry.d.cts +1 -1
- package/dist/services/registry.d.mts +1 -1
- package/dist/services/registry.test.cjs +8 -8
- package/dist/services/registry.test.cjs.map +1 -1
- package/dist/services/registry.test.mjs +8 -8
- package/dist/services/registry.test.mjs.map +1 -1
- package/dist/skills/registry.cjs +19 -0
- package/dist/skills/registry.cjs.map +1 -1
- package/dist/skills/registry.d.cts +1 -1
- package/dist/skills/registry.d.cts.map +1 -1
- package/dist/skills/registry.d.mts +1 -1
- package/dist/skills/registry.d.mts.map +1 -1
- package/dist/skills/registry.mjs +19 -0
- package/dist/skills/registry.mjs.map +1 -1
- package/dist/{skills-BSF7iNa4.cjs → skills-uPxJVmKk.cjs} +311 -1
- package/dist/skills-uPxJVmKk.cjs.map +1 -0
- package/dist/{test.CTcmp4Su-ClCHJ3FA.mjs → test.CTcmp4Su-BRa7-bTj.mjs} +2 -2
- package/dist/{test.CTcmp4Su-ClCHJ3FA.mjs.map → test.CTcmp4Su-BRa7-bTj.mjs.map} +1 -1
- package/dist/{test.CTcmp4Su-DlzTarwH.cjs → test.CTcmp4Su-BWSPM8ZQ.cjs} +19 -1
- package/dist/{test.CTcmp4Su-DlzTarwH.cjs.map → test.CTcmp4Su-BWSPM8ZQ.cjs.map} +1 -1
- package/dist/track-analytics.d.cts +1 -1
- package/dist/track-analytics.d.mts +1 -1
- package/dist/track-analytics.test.cjs +1 -1
- package/dist/track-analytics.test.mjs +1 -1
- package/dist/types-BREUfzzq.d.mts +77 -0
- package/dist/types-BREUfzzq.d.mts.map +1 -0
- package/dist/types-Bsn0XzSP.d.cts +95 -0
- package/dist/types-Bsn0XzSP.d.cts.map +1 -0
- package/dist/types-CyZ5mn6w.d.cts +77 -0
- package/dist/types-CyZ5mn6w.d.cts.map +1 -0
- package/dist/types-DIsPc-hb.d.cts +100 -0
- package/dist/types-DIsPc-hb.d.cts.map +1 -0
- package/dist/types-DbXajvYq.d.mts +100 -0
- package/dist/types-DbXajvYq.d.mts.map +1 -0
- package/dist/types-DwTKyCZ9.d.mts +95 -0
- package/dist/types-DwTKyCZ9.d.mts.map +1 -0
- package/dist/{types-CR83OJiq.d.cts → types-dyBnrHm9.d.cts} +5 -1
- package/dist/types-dyBnrHm9.d.cts.map +1 -0
- package/dist/{types-zYjGTuyn.d.mts → types-fRSnaZTX.d.mts} +5 -1
- package/dist/types-fRSnaZTX.d.mts.map +1 -0
- package/dist/types.cjs +7 -0
- package/dist/types.cjs.map +1 -1
- package/dist/types.d.cts +2 -93
- package/dist/types.d.mts +2 -93
- package/dist/types.mjs +7 -0
- package/dist/types.mjs.map +1 -1
- package/dist/validator.cjs +1 -1
- package/dist/validator.d.cts +1 -1
- package/dist/validator.d.mts +1 -1
- package/dist/validator.test.cjs +1 -1
- package/dist/validator.test.mjs +1 -1
- package/dist/version-manager.d.cts +1 -1
- package/dist/version-manager.d.mts +1 -1
- package/dist/version-manager.test.cjs +3 -3
- package/dist/version-manager.test.cjs.map +1 -1
- package/dist/version-manager.test.mjs +3 -3
- package/dist/version-manager.test.mjs.map +1 -1
- package/dist/zeroclaw-B-0TuOfZ.d.mts +7 -0
- package/dist/zeroclaw-B-0TuOfZ.d.mts.map +1 -0
- package/dist/zeroclaw-BvKpDHKe.d.cts +7 -0
- package/dist/zeroclaw-BvKpDHKe.d.cts.map +1 -0
- package/package.json +6 -2
- package/src/addon-stack.test.ts +19 -23
- package/src/addon-stack.ts +67 -44
- package/src/composer.test.ts +59 -0
- package/src/composer.ts +135 -194
- package/src/deployers/coolify.test.ts +180 -0
- package/src/deployers/coolify.ts +38 -0
- package/src/deployers/dokploy.test.ts +120 -0
- package/src/deployers/dokploy.ts +38 -0
- package/src/deployers/types.ts +2 -0
- package/src/frameworks/claude-code-fw.ts +118 -0
- package/src/frameworks/codex-fw.ts +102 -0
- package/src/frameworks/copaw.ts +154 -0
- package/src/frameworks/frameworks.test.ts +119 -0
- package/src/frameworks/index.ts +46 -0
- package/src/frameworks/memu.ts +149 -0
- package/src/frameworks/nanobot.ts +156 -0
- package/src/frameworks/nanoclaw.ts +126 -0
- package/src/frameworks/openclaw.ts +325 -0
- package/src/frameworks/registry.test.ts +131 -0
- package/src/frameworks/registry.ts +28 -0
- package/src/frameworks/types.ts +146 -0
- package/src/frameworks/zeroclaw.ts +148 -0
- package/src/generate.test.ts +55 -4
- package/src/generate.ts +67 -14
- package/src/generators/caddy.test.ts +41 -1
- package/src/generators/caddy.ts +16 -2
- package/src/generators/clone-repos.test.ts +1 -1
- package/src/generators/clone-repos.ts +7 -2
- package/src/generators/cloud-init.test.ts +70 -0
- package/src/generators/env.test.ts +2 -2
- package/src/generators/env.ts +30 -180
- package/src/generators/get-shit-done.test.ts +54 -0
- package/src/generators/grafana.test.ts +90 -0
- package/src/generators/health-check.ts +4 -4
- package/src/generators/n8n-workflows.test.ts +80 -0
- package/src/generators/openclaw-install-script.test.ts +42 -0
- package/src/generators/openclaw-json.ts +57 -5
- package/src/generators/postgres-init.test.ts +116 -0
- package/src/generators/postgres-init.ts +9 -0
- package/src/generators/prometheus.test.ts +108 -0
- package/src/generators/readme.ts +75 -9
- package/src/generators/scripts.test.ts +1 -1
- package/src/generators/skills.ts +316 -0
- package/src/generators/stack-manifest.test.ts +104 -0
- package/src/generators/traefik.test.ts +13 -13
- package/src/index.ts +47 -7
- package/src/logger/__tests__/logger.test.ts +388 -0
- package/src/logger/index.ts +15 -0
- package/src/logger/logger.ts +326 -0
- package/src/logger/sinks/callback-sink.ts +13 -0
- package/src/logger/sinks/console-sink.ts +51 -0
- package/src/logger/sinks/file-sink.ts +121 -0
- package/src/logger/types.ts +90 -0
- package/src/migrations.ts +8 -1
- package/src/port-scanner.test.ts +167 -0
- package/src/presets/presets.test.ts +4 -4
- package/src/presets/registry.test.ts +6 -6
- package/src/resolver.test.ts +31 -3
- package/src/resolver.ts +19 -3
- package/src/schema.test.ts +2 -2
- package/src/schema.ts +58 -17
- package/src/services/definitions/agent-browser.ts +177 -0
- package/src/services/definitions/apptension-saas.ts +2 -1
- package/src/services/definitions/chromadb.ts +1 -1
- package/src/services/definitions/claude-code.ts +1 -1
- package/src/services/definitions/clawrouter.ts +141 -0
- package/src/services/definitions/codex.ts +1 -1
- package/src/services/definitions/convex.ts +1 -2
- package/src/services/definitions/copaw.ts +101 -0
- package/src/services/definitions/desktop-environment.ts +1 -0
- package/src/services/definitions/hindsight.ts +3 -2
- package/src/services/definitions/index.ts +53 -16
- package/src/services/definitions/mem0.ts +132 -0
- package/src/services/definitions/memu.ts +96 -0
- package/src/services/definitions/milvus.ts +1 -1
- package/src/services/definitions/nanobot.ts +89 -0
- package/src/services/definitions/nanoclaw.ts +78 -0
- package/src/services/definitions/opensandbox.ts +6 -15
- package/src/services/definitions/relaticle-horizon.ts +48 -0
- package/src/services/definitions/relaticle-scheduler.ts +42 -0
- package/src/services/definitions/relaticle.ts +142 -0
- package/src/services/definitions/twenty-worker.ts +70 -0
- package/src/services/definitions/twenty.ts +16 -2
- package/src/services/definitions/weaviate.ts +1 -1
- package/src/services/definitions/zeroclaw.ts +102 -0
- package/src/services/registry.test.ts +7 -7
- package/src/skills/registry.ts +10 -0
- package/src/types.ts +11 -1
- package/src/version-manager.test.ts +2 -2
- package/dist/schema-BQnZrcw8.d.cts.map +0 -1
- package/dist/schema-SBpL0bdI.d.mts.map +0 -1
- package/dist/skills-BSF7iNa4.cjs.map +0 -1
- package/dist/types-CR83OJiq.d.cts.map +0 -1
- package/dist/types-zYjGTuyn.d.mts.map +0 -1
- package/dist/types.d.cts.map +0 -1
- package/dist/types.d.mts.map +0 -1
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
2
|
+
//#region src/logger/sinks/console-sink.ts
|
|
3
|
+
/**
|
|
4
|
+
* Human-readable console output sink.
|
|
5
|
+
* Formats log entries as single-line summaries with optional step details.
|
|
6
|
+
*/
|
|
7
|
+
var ConsoleSink = class {
|
|
8
|
+
write(entry) {
|
|
9
|
+
const time = entry.timestamp.slice(11, 19);
|
|
10
|
+
const lvl = entry.level.toUpperCase().padEnd(5);
|
|
11
|
+
const src = entry.source;
|
|
12
|
+
const outcome = entry.outcome ? ` (${entry.outcome})` : "";
|
|
13
|
+
const duration = entry.durationMs != null ? ` [${entry.durationMs}ms]` : "";
|
|
14
|
+
const line = `[${time}] [${lvl}] [${src}] ${entry.category}: ${entry.message}${outcome}${duration}`;
|
|
15
|
+
switch (entry.level) {
|
|
16
|
+
case "error":
|
|
17
|
+
console.error(line);
|
|
18
|
+
break;
|
|
19
|
+
case "warn":
|
|
20
|
+
console.warn(line);
|
|
21
|
+
break;
|
|
22
|
+
default: console.log(line);
|
|
23
|
+
}
|
|
24
|
+
if (entry.steps) for (const step of entry.steps) {
|
|
25
|
+
const icon = step.status === "success" ? "+" : step.status === "failure" ? "x" : step.status === "skipped" ? "-" : "~";
|
|
26
|
+
const stepDuration = step.durationMs != null ? ` [${step.durationMs}ms]` : "";
|
|
27
|
+
const detail = step.detail ? ` (${step.detail})` : "";
|
|
28
|
+
console.log(` ${icon} ${step.name}${detail}${stepDuration}`);
|
|
29
|
+
}
|
|
30
|
+
if (entry.error) {
|
|
31
|
+
console.error(` Error: ${entry.error.message}`);
|
|
32
|
+
if (entry.error.stack) console.error(` ${entry.error.stack}`);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
//#endregion
|
|
37
|
+
exports.ConsoleSink = ConsoleSink;
|
|
38
|
+
|
|
39
|
+
//# sourceMappingURL=console-sink.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"console-sink.cjs","names":[],"sources":["../../../src/logger/sinks/console-sink.ts"],"sourcesContent":["import type { LogSink, OperationsLogEntry } from \"../types.js\";\n\n/**\n * Human-readable console output sink.\n * Formats log entries as single-line summaries with optional step details.\n */\nexport class ConsoleSink implements LogSink {\n\twrite(entry: OperationsLogEntry): void {\n\t\tconst time = entry.timestamp.slice(11, 19);\n\t\tconst lvl = entry.level.toUpperCase().padEnd(5);\n\t\tconst src = entry.source;\n\t\tconst outcome = entry.outcome ? ` (${entry.outcome})` : \"\";\n\t\tconst duration = entry.durationMs != null ? ` [${entry.durationMs}ms]` : \"\";\n\n\t\tconst line = `[${time}] [${lvl}] [${src}] ${entry.category}: ${entry.message}${outcome}${duration}`;\n\n\t\tswitch (entry.level) {\n\t\t\tcase \"error\":\n\t\t\t\tconsole.error(line);\n\t\t\t\tbreak;\n\t\t\tcase \"warn\":\n\t\t\t\tconsole.warn(line);\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\tconsole.log(line);\n\t\t}\n\n\t\tif (entry.steps) {\n\t\t\tfor (const step of entry.steps) {\n\t\t\t\tconst icon =\n\t\t\t\t\tstep.status === \"success\"\n\t\t\t\t\t\t? \"+\"\n\t\t\t\t\t\t: step.status === \"failure\"\n\t\t\t\t\t\t\t? \"x\"\n\t\t\t\t\t\t\t: step.status === \"skipped\"\n\t\t\t\t\t\t\t\t? \"-\"\n\t\t\t\t\t\t\t\t: \"~\";\n\t\t\t\tconst stepDuration = step.durationMs != null ? ` [${step.durationMs}ms]` : \"\";\n\t\t\t\tconst detail = step.detail ? ` (${step.detail})` : \"\";\n\t\t\t\tconsole.log(` ${icon} ${step.name}${detail}${stepDuration}`);\n\t\t\t}\n\t\t}\n\n\t\tif (entry.error) {\n\t\t\tconsole.error(` Error: ${entry.error.message}`);\n\t\t\tif (entry.error.stack) {\n\t\t\t\tconsole.error(` ${entry.error.stack}`);\n\t\t\t}\n\t\t}\n\t}\n}\n"],"mappings":";;;;;;AAMA,IAAa,cAAb,MAA4C;CAC3C,MAAM,OAAiC;EACtC,MAAM,OAAO,MAAM,UAAU,MAAM,IAAI,GAAG;EAC1C,MAAM,MAAM,MAAM,MAAM,aAAa,CAAC,OAAO,EAAE;EAC/C,MAAM,MAAM,MAAM;EAClB,MAAM,UAAU,MAAM,UAAU,KAAK,MAAM,QAAQ,KAAK;EACxD,MAAM,WAAW,MAAM,cAAc,OAAO,KAAK,MAAM,WAAW,OAAO;EAEzE,MAAM,OAAO,IAAI,KAAK,KAAK,IAAI,KAAK,IAAI,IAAI,MAAM,SAAS,IAAI,MAAM,UAAU,UAAU;AAEzF,UAAQ,MAAM,OAAd;GACC,KAAK;AACJ,YAAQ,MAAM,KAAK;AACnB;GACD,KAAK;AACJ,YAAQ,KAAK,KAAK;AAClB;GACD,QACC,SAAQ,IAAI,KAAK;;AAGnB,MAAI,MAAM,MACT,MAAK,MAAM,QAAQ,MAAM,OAAO;GAC/B,MAAM,OACL,KAAK,WAAW,YACb,MACA,KAAK,WAAW,YACf,MACA,KAAK,WAAW,YACf,MACA;GACN,MAAM,eAAe,KAAK,cAAc,OAAO,KAAK,KAAK,WAAW,OAAO;GAC3E,MAAM,SAAS,KAAK,SAAS,KAAK,KAAK,OAAO,KAAK;AACnD,WAAQ,IAAI,KAAK,KAAK,GAAG,KAAK,OAAO,SAAS,eAAe;;AAI/D,MAAI,MAAM,OAAO;AAChB,WAAQ,MAAM,YAAY,MAAM,MAAM,UAAU;AAChD,OAAI,MAAM,MAAM,MACf,SAAQ,MAAM,KAAK,MAAM,MAAM,QAAQ"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
//#region src/logger/sinks/console-sink.ts
|
|
2
|
+
/**
|
|
3
|
+
* Human-readable console output sink.
|
|
4
|
+
* Formats log entries as single-line summaries with optional step details.
|
|
5
|
+
*/
|
|
6
|
+
var ConsoleSink = class {
|
|
7
|
+
write(entry) {
|
|
8
|
+
const time = entry.timestamp.slice(11, 19);
|
|
9
|
+
const lvl = entry.level.toUpperCase().padEnd(5);
|
|
10
|
+
const src = entry.source;
|
|
11
|
+
const outcome = entry.outcome ? ` (${entry.outcome})` : "";
|
|
12
|
+
const duration = entry.durationMs != null ? ` [${entry.durationMs}ms]` : "";
|
|
13
|
+
const line = `[${time}] [${lvl}] [${src}] ${entry.category}: ${entry.message}${outcome}${duration}`;
|
|
14
|
+
switch (entry.level) {
|
|
15
|
+
case "error":
|
|
16
|
+
console.error(line);
|
|
17
|
+
break;
|
|
18
|
+
case "warn":
|
|
19
|
+
console.warn(line);
|
|
20
|
+
break;
|
|
21
|
+
default: console.log(line);
|
|
22
|
+
}
|
|
23
|
+
if (entry.steps) for (const step of entry.steps) {
|
|
24
|
+
const icon = step.status === "success" ? "+" : step.status === "failure" ? "x" : step.status === "skipped" ? "-" : "~";
|
|
25
|
+
const stepDuration = step.durationMs != null ? ` [${step.durationMs}ms]` : "";
|
|
26
|
+
const detail = step.detail ? ` (${step.detail})` : "";
|
|
27
|
+
console.log(` ${icon} ${step.name}${detail}${stepDuration}`);
|
|
28
|
+
}
|
|
29
|
+
if (entry.error) {
|
|
30
|
+
console.error(` Error: ${entry.error.message}`);
|
|
31
|
+
if (entry.error.stack) console.error(` ${entry.error.stack}`);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
//#endregion
|
|
36
|
+
export { ConsoleSink };
|
|
37
|
+
|
|
38
|
+
//# sourceMappingURL=console-sink.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"console-sink.mjs","names":[],"sources":["../../../src/logger/sinks/console-sink.ts"],"sourcesContent":["import type { LogSink, OperationsLogEntry } from \"../types.js\";\n\n/**\n * Human-readable console output sink.\n * Formats log entries as single-line summaries with optional step details.\n */\nexport class ConsoleSink implements LogSink {\n\twrite(entry: OperationsLogEntry): void {\n\t\tconst time = entry.timestamp.slice(11, 19);\n\t\tconst lvl = entry.level.toUpperCase().padEnd(5);\n\t\tconst src = entry.source;\n\t\tconst outcome = entry.outcome ? ` (${entry.outcome})` : \"\";\n\t\tconst duration = entry.durationMs != null ? ` [${entry.durationMs}ms]` : \"\";\n\n\t\tconst line = `[${time}] [${lvl}] [${src}] ${entry.category}: ${entry.message}${outcome}${duration}`;\n\n\t\tswitch (entry.level) {\n\t\t\tcase \"error\":\n\t\t\t\tconsole.error(line);\n\t\t\t\tbreak;\n\t\t\tcase \"warn\":\n\t\t\t\tconsole.warn(line);\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\tconsole.log(line);\n\t\t}\n\n\t\tif (entry.steps) {\n\t\t\tfor (const step of entry.steps) {\n\t\t\t\tconst icon =\n\t\t\t\t\tstep.status === \"success\"\n\t\t\t\t\t\t? \"+\"\n\t\t\t\t\t\t: step.status === \"failure\"\n\t\t\t\t\t\t\t? \"x\"\n\t\t\t\t\t\t\t: step.status === \"skipped\"\n\t\t\t\t\t\t\t\t? \"-\"\n\t\t\t\t\t\t\t\t: \"~\";\n\t\t\t\tconst stepDuration = step.durationMs != null ? ` [${step.durationMs}ms]` : \"\";\n\t\t\t\tconst detail = step.detail ? ` (${step.detail})` : \"\";\n\t\t\t\tconsole.log(` ${icon} ${step.name}${detail}${stepDuration}`);\n\t\t\t}\n\t\t}\n\n\t\tif (entry.error) {\n\t\t\tconsole.error(` Error: ${entry.error.message}`);\n\t\t\tif (entry.error.stack) {\n\t\t\t\tconsole.error(` ${entry.error.stack}`);\n\t\t\t}\n\t\t}\n\t}\n}\n"],"mappings":";;;;;AAMA,IAAa,cAAb,MAA4C;CAC3C,MAAM,OAAiC;EACtC,MAAM,OAAO,MAAM,UAAU,MAAM,IAAI,GAAG;EAC1C,MAAM,MAAM,MAAM,MAAM,aAAa,CAAC,OAAO,EAAE;EAC/C,MAAM,MAAM,MAAM;EAClB,MAAM,UAAU,MAAM,UAAU,KAAK,MAAM,QAAQ,KAAK;EACxD,MAAM,WAAW,MAAM,cAAc,OAAO,KAAK,MAAM,WAAW,OAAO;EAEzE,MAAM,OAAO,IAAI,KAAK,KAAK,IAAI,KAAK,IAAI,IAAI,MAAM,SAAS,IAAI,MAAM,UAAU,UAAU;AAEzF,UAAQ,MAAM,OAAd;GACC,KAAK;AACJ,YAAQ,MAAM,KAAK;AACnB;GACD,KAAK;AACJ,YAAQ,KAAK,KAAK;AAClB;GACD,QACC,SAAQ,IAAI,KAAK;;AAGnB,MAAI,MAAM,MACT,MAAK,MAAM,QAAQ,MAAM,OAAO;GAC/B,MAAM,OACL,KAAK,WAAW,YACb,MACA,KAAK,WAAW,YACf,MACA,KAAK,WAAW,YACf,MACA;GACN,MAAM,eAAe,KAAK,cAAc,OAAO,KAAK,KAAK,WAAW,OAAO;GAC3E,MAAM,SAAS,KAAK,SAAS,KAAK,KAAK,OAAO,KAAK;AACnD,WAAQ,IAAI,KAAK,KAAK,GAAG,KAAK,OAAO,SAAS,eAAe;;AAI/D,MAAI,MAAM,OAAO;AAChB,WAAQ,MAAM,YAAY,MAAM,MAAM,UAAU;AAChD,OAAI,MAAM,MAAM,MACf,SAAQ,MAAM,KAAK,MAAM,MAAM,QAAQ"}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
2
|
+
require("../../skills-uPxJVmKk.cjs");
|
|
3
|
+
let node_fs = require("node:fs");
|
|
4
|
+
let node_os = require("node:os");
|
|
5
|
+
let node_path = require("node:path");
|
|
6
|
+
//#region src/logger/sinks/file-sink.ts
|
|
7
|
+
const DEFAULT_MAX_SIZE = 10 * 1024 * 1024;
|
|
8
|
+
const DEFAULT_MAX_FILES = 5;
|
|
9
|
+
function defaultLogDir() {
|
|
10
|
+
return process.env.OPENCLAW_LOG_DIR ?? (0, node_path.join)((0, node_os.homedir)(), ".better-openclaw", "logs");
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* NDJSON file sink with size-based rotation.
|
|
14
|
+
*
|
|
15
|
+
* Writes one JSON object per line (newline-delimited JSON).
|
|
16
|
+
* Rotates files when they exceed maxFileSize:
|
|
17
|
+
* operations.log → operations.1.log → operations.2.log → ...
|
|
18
|
+
*/
|
|
19
|
+
var FileSink = class {
|
|
20
|
+
currentSize = 0;
|
|
21
|
+
initialized = false;
|
|
22
|
+
logDir;
|
|
23
|
+
maxFileSize;
|
|
24
|
+
maxFiles;
|
|
25
|
+
filename;
|
|
26
|
+
logPath;
|
|
27
|
+
constructor(options) {
|
|
28
|
+
this.logDir = options?.logDir ?? defaultLogDir();
|
|
29
|
+
this.maxFileSize = options?.maxFileSize ?? (process.env.OPENCLAW_LOG_MAX_SIZE ? Number.parseInt(process.env.OPENCLAW_LOG_MAX_SIZE, 10) : DEFAULT_MAX_SIZE);
|
|
30
|
+
this.maxFiles = options?.maxFiles ?? (process.env.OPENCLAW_LOG_MAX_FILES ? Number.parseInt(process.env.OPENCLAW_LOG_MAX_FILES, 10) : DEFAULT_MAX_FILES);
|
|
31
|
+
this.filename = options?.filename ?? "operations";
|
|
32
|
+
this.logPath = (0, node_path.join)(this.logDir, `${this.filename}.log`);
|
|
33
|
+
}
|
|
34
|
+
write(entry) {
|
|
35
|
+
this.ensureDir();
|
|
36
|
+
const line = `${JSON.stringify(entry)}\n`;
|
|
37
|
+
(0, node_fs.appendFileSync)(this.logPath, line, "utf-8");
|
|
38
|
+
this.currentSize += Buffer.byteLength(line, "utf-8");
|
|
39
|
+
if (this.currentSize >= this.maxFileSize) this.rotate();
|
|
40
|
+
}
|
|
41
|
+
ensureDir() {
|
|
42
|
+
if (this.initialized) return;
|
|
43
|
+
if (!(0, node_fs.existsSync)(this.logDir)) (0, node_fs.mkdirSync)(this.logDir, { recursive: true });
|
|
44
|
+
if ((0, node_fs.existsSync)(this.logPath)) try {
|
|
45
|
+
this.currentSize = (0, node_fs.statSync)(this.logPath).size;
|
|
46
|
+
} catch {
|
|
47
|
+
this.currentSize = 0;
|
|
48
|
+
}
|
|
49
|
+
this.initialized = true;
|
|
50
|
+
}
|
|
51
|
+
rotate() {
|
|
52
|
+
const oldest = (0, node_path.join)(this.logDir, `${this.filename}.${this.maxFiles}.log`);
|
|
53
|
+
if ((0, node_fs.existsSync)(oldest)) try {
|
|
54
|
+
(0, node_fs.unlinkSync)(oldest);
|
|
55
|
+
} catch {}
|
|
56
|
+
for (let i = this.maxFiles - 1; i >= 1; i--) {
|
|
57
|
+
const from = (0, node_path.join)(this.logDir, `${this.filename}.${i}.log`);
|
|
58
|
+
const to = (0, node_path.join)(this.logDir, `${this.filename}.${i + 1}.log`);
|
|
59
|
+
if ((0, node_fs.existsSync)(from)) try {
|
|
60
|
+
(0, node_fs.renameSync)(from, to);
|
|
61
|
+
} catch {}
|
|
62
|
+
}
|
|
63
|
+
if ((0, node_fs.existsSync)(this.logPath)) try {
|
|
64
|
+
(0, node_fs.renameSync)(this.logPath, (0, node_path.join)(this.logDir, `${this.filename}.1.log`));
|
|
65
|
+
} catch {}
|
|
66
|
+
this.currentSize = 0;
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
//#endregion
|
|
70
|
+
exports.FileSink = FileSink;
|
|
71
|
+
|
|
72
|
+
//# sourceMappingURL=file-sink.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"file-sink.cjs","names":[],"sources":["../../../src/logger/sinks/file-sink.ts"],"sourcesContent":["import { appendFileSync, existsSync, mkdirSync, renameSync, statSync, unlinkSync } from \"node:fs\";\nimport { homedir } from \"node:os\";\nimport { join } from \"node:path\";\nimport type { LogSink, OperationsLogEntry } from \"../types.js\";\n\nexport interface FileSinkOptions {\n\t/** Log directory. Default: ~/.better-openclaw/logs */\n\tlogDir?: string;\n\t/** Max file size in bytes before rotation. Default: 10 MB */\n\tmaxFileSize?: number;\n\t/** Max number of rotated files to keep. Default: 5 */\n\tmaxFiles?: number;\n\t/** Base filename (without extension). Default: \"operations\" */\n\tfilename?: string;\n}\n\nconst DEFAULT_MAX_SIZE = 10 * 1024 * 1024; // 10 MB\nconst DEFAULT_MAX_FILES = 5;\n\nfunction defaultLogDir(): string {\n\treturn process.env.OPENCLAW_LOG_DIR ?? join(homedir(), \".better-openclaw\", \"logs\");\n}\n\n/**\n * NDJSON file sink with size-based rotation.\n *\n * Writes one JSON object per line (newline-delimited JSON).\n * Rotates files when they exceed maxFileSize:\n * operations.log → operations.1.log → operations.2.log → ...\n */\nexport class FileSink implements LogSink {\n\tprivate currentSize = 0;\n\tprivate initialized = false;\n\tprivate readonly logDir: string;\n\tprivate readonly maxFileSize: number;\n\tprivate readonly maxFiles: number;\n\tprivate readonly filename: string;\n\tprivate readonly logPath: string;\n\n\tconstructor(options?: FileSinkOptions) {\n\t\tthis.logDir = options?.logDir ?? defaultLogDir();\n\t\tthis.maxFileSize =\n\t\t\toptions?.maxFileSize ??\n\t\t\t(process.env.OPENCLAW_LOG_MAX_SIZE\n\t\t\t\t? Number.parseInt(process.env.OPENCLAW_LOG_MAX_SIZE, 10)\n\t\t\t\t: DEFAULT_MAX_SIZE);\n\t\tthis.maxFiles =\n\t\t\toptions?.maxFiles ??\n\t\t\t(process.env.OPENCLAW_LOG_MAX_FILES\n\t\t\t\t? Number.parseInt(process.env.OPENCLAW_LOG_MAX_FILES, 10)\n\t\t\t\t: DEFAULT_MAX_FILES);\n\t\tthis.filename = options?.filename ?? \"operations\";\n\t\tthis.logPath = join(this.logDir, `${this.filename}.log`);\n\t}\n\n\twrite(entry: OperationsLogEntry): void {\n\t\tthis.ensureDir();\n\t\tconst line = `${JSON.stringify(entry)}\\n`;\n\t\tappendFileSync(this.logPath, line, \"utf-8\");\n\t\tthis.currentSize += Buffer.byteLength(line, \"utf-8\");\n\n\t\tif (this.currentSize >= this.maxFileSize) {\n\t\t\tthis.rotate();\n\t\t}\n\t}\n\n\tprivate ensureDir(): void {\n\t\tif (this.initialized) return;\n\n\t\tif (!existsSync(this.logDir)) {\n\t\t\tmkdirSync(this.logDir, { recursive: true });\n\t\t}\n\n\t\t// Seed current size from existing file\n\t\tif (existsSync(this.logPath)) {\n\t\t\ttry {\n\t\t\t\tthis.currentSize = statSync(this.logPath).size;\n\t\t\t} catch {\n\t\t\t\tthis.currentSize = 0;\n\t\t\t}\n\t\t}\n\n\t\tthis.initialized = true;\n\t}\n\n\tprivate rotate(): void {\n\t\t// Delete the oldest file if it exists\n\t\tconst oldest = join(this.logDir, `${this.filename}.${this.maxFiles}.log`);\n\t\tif (existsSync(oldest)) {\n\t\t\ttry {\n\t\t\t\tunlinkSync(oldest);\n\t\t\t} catch {\n\t\t\t\t// Ignore\n\t\t\t}\n\t\t}\n\n\t\t// Shift existing rotated files: N-1 → N, N-2 → N-1, ..., 1 → 2\n\t\tfor (let i = this.maxFiles - 1; i >= 1; i--) {\n\t\t\tconst from = join(this.logDir, `${this.filename}.${i}.log`);\n\t\t\tconst to = join(this.logDir, `${this.filename}.${i + 1}.log`);\n\t\t\tif (existsSync(from)) {\n\t\t\t\ttry {\n\t\t\t\t\trenameSync(from, to);\n\t\t\t\t} catch {\n\t\t\t\t\t// Ignore\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// Rename current log to .1.log\n\t\tif (existsSync(this.logPath)) {\n\t\t\ttry {\n\t\t\t\trenameSync(this.logPath, join(this.logDir, `${this.filename}.1.log`));\n\t\t\t} catch {\n\t\t\t\t// Ignore\n\t\t\t}\n\t\t}\n\n\t\tthis.currentSize = 0;\n\t}\n}\n"],"mappings":";;;;;;AAgBA,MAAM,mBAAmB,KAAK,OAAO;AACrC,MAAM,oBAAoB;AAE1B,SAAS,gBAAwB;AAChC,QAAO,QAAQ,IAAI,qBAAA,GAAA,UAAA,OAAA,GAAA,QAAA,UAAkC,EAAE,oBAAoB,OAAO;;;;;;;;;AAUnF,IAAa,WAAb,MAAyC;CACxC,cAAsB;CACtB,cAAsB;CACtB;CACA;CACA;CACA;CACA;CAEA,YAAY,SAA2B;AACtC,OAAK,SAAS,SAAS,UAAU,eAAe;AAChD,OAAK,cACJ,SAAS,gBACR,QAAQ,IAAI,wBACV,OAAO,SAAS,QAAQ,IAAI,uBAAuB,GAAG,GACtD;AACJ,OAAK,WACJ,SAAS,aACR,QAAQ,IAAI,yBACV,OAAO,SAAS,QAAQ,IAAI,wBAAwB,GAAG,GACvD;AACJ,OAAK,WAAW,SAAS,YAAY;AACrC,OAAK,WAAA,GAAA,UAAA,MAAe,KAAK,QAAQ,GAAG,KAAK,SAAS,MAAM;;CAGzD,MAAM,OAAiC;AACtC,OAAK,WAAW;EAChB,MAAM,OAAO,GAAG,KAAK,UAAU,MAAM,CAAC;AACtC,GAAA,GAAA,QAAA,gBAAe,KAAK,SAAS,MAAM,QAAQ;AAC3C,OAAK,eAAe,OAAO,WAAW,MAAM,QAAQ;AAEpD,MAAI,KAAK,eAAe,KAAK,YAC5B,MAAK,QAAQ;;CAIf,YAA0B;AACzB,MAAI,KAAK,YAAa;AAEtB,MAAI,EAAA,GAAA,QAAA,YAAY,KAAK,OAAO,CAC3B,EAAA,GAAA,QAAA,WAAU,KAAK,QAAQ,EAAE,WAAW,MAAM,CAAC;AAI5C,OAAA,GAAA,QAAA,YAAe,KAAK,QAAQ,CAC3B,KAAI;AACH,QAAK,eAAA,GAAA,QAAA,UAAuB,KAAK,QAAQ,CAAC;UACnC;AACP,QAAK,cAAc;;AAIrB,OAAK,cAAc;;CAGpB,SAAuB;EAEtB,MAAM,UAAA,GAAA,UAAA,MAAc,KAAK,QAAQ,GAAG,KAAK,SAAS,GAAG,KAAK,SAAS,MAAM;AACzE,OAAA,GAAA,QAAA,YAAe,OAAO,CACrB,KAAI;AACH,IAAA,GAAA,QAAA,YAAW,OAAO;UACX;AAMT,OAAK,IAAI,IAAI,KAAK,WAAW,GAAG,KAAK,GAAG,KAAK;GAC5C,MAAM,QAAA,GAAA,UAAA,MAAY,KAAK,QAAQ,GAAG,KAAK,SAAS,GAAG,EAAE,MAAM;GAC3D,MAAM,MAAA,GAAA,UAAA,MAAU,KAAK,QAAQ,GAAG,KAAK,SAAS,GAAG,IAAI,EAAE,MAAM;AAC7D,QAAA,GAAA,QAAA,YAAe,KAAK,CACnB,KAAI;AACH,KAAA,GAAA,QAAA,YAAW,MAAM,GAAG;WACb;;AAOV,OAAA,GAAA,QAAA,YAAe,KAAK,QAAQ,CAC3B,KAAI;AACH,IAAA,GAAA,QAAA,YAAW,KAAK,UAAA,GAAA,UAAA,MAAc,KAAK,QAAQ,GAAG,KAAK,SAAS,QAAQ,CAAC;UAC9D;AAKT,OAAK,cAAc"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { n as LogSink, s as OperationsLogEntry } from "../../types-CyZ5mn6w.cjs";
|
|
2
|
+
|
|
3
|
+
//#region src/logger/sinks/file-sink.d.ts
|
|
4
|
+
interface FileSinkOptions {
|
|
5
|
+
/** Log directory. Default: ~/.better-openclaw/logs */
|
|
6
|
+
logDir?: string;
|
|
7
|
+
/** Max file size in bytes before rotation. Default: 10 MB */
|
|
8
|
+
maxFileSize?: number;
|
|
9
|
+
/** Max number of rotated files to keep. Default: 5 */
|
|
10
|
+
maxFiles?: number;
|
|
11
|
+
/** Base filename (without extension). Default: "operations" */
|
|
12
|
+
filename?: string;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* NDJSON file sink with size-based rotation.
|
|
16
|
+
*
|
|
17
|
+
* Writes one JSON object per line (newline-delimited JSON).
|
|
18
|
+
* Rotates files when they exceed maxFileSize:
|
|
19
|
+
* operations.log → operations.1.log → operations.2.log → ...
|
|
20
|
+
*/
|
|
21
|
+
declare class FileSink implements LogSink {
|
|
22
|
+
private currentSize;
|
|
23
|
+
private initialized;
|
|
24
|
+
private readonly logDir;
|
|
25
|
+
private readonly maxFileSize;
|
|
26
|
+
private readonly maxFiles;
|
|
27
|
+
private readonly filename;
|
|
28
|
+
private readonly logPath;
|
|
29
|
+
constructor(options?: FileSinkOptions);
|
|
30
|
+
write(entry: OperationsLogEntry): void;
|
|
31
|
+
private ensureDir;
|
|
32
|
+
private rotate;
|
|
33
|
+
}
|
|
34
|
+
//#endregion
|
|
35
|
+
export { FileSink, FileSinkOptions };
|
|
36
|
+
//# sourceMappingURL=file-sink.d.cts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"file-sink.d.cts","names":[],"sources":["../../../src/logger/sinks/file-sink.ts"],"mappings":";;;UAKiB,eAAA;;EAEhB,MAAA;EAF+B;EAI/B,WAAA;EAJ+B;EAM/B,QAAA;EAFA;EAIA,QAAA;AAAA;;;AAiBD;;;;;cAAa,QAAA,YAAoB,OAAA;EAAA,QACxB,WAAA;EAAA,QACA,WAAA;EAAA,iBACS,MAAA;EAAA,iBACA,WAAA;EAAA,iBACA,QAAA;EAAA,iBACA,QAAA;EAAA,iBACA,OAAA;cAEL,OAAA,GAAU,eAAA;EAgBtB,KAAA,CAAM,KAAA,EAAO,kBAAA;EAAA,QAWL,SAAA;EAAA,QAmBA,MAAA;AAAA"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { n as LogSink, s as OperationsLogEntry } from "../../types-BREUfzzq.mjs";
|
|
2
|
+
|
|
3
|
+
//#region src/logger/sinks/file-sink.d.ts
|
|
4
|
+
interface FileSinkOptions {
|
|
5
|
+
/** Log directory. Default: ~/.better-openclaw/logs */
|
|
6
|
+
logDir?: string;
|
|
7
|
+
/** Max file size in bytes before rotation. Default: 10 MB */
|
|
8
|
+
maxFileSize?: number;
|
|
9
|
+
/** Max number of rotated files to keep. Default: 5 */
|
|
10
|
+
maxFiles?: number;
|
|
11
|
+
/** Base filename (without extension). Default: "operations" */
|
|
12
|
+
filename?: string;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* NDJSON file sink with size-based rotation.
|
|
16
|
+
*
|
|
17
|
+
* Writes one JSON object per line (newline-delimited JSON).
|
|
18
|
+
* Rotates files when they exceed maxFileSize:
|
|
19
|
+
* operations.log → operations.1.log → operations.2.log → ...
|
|
20
|
+
*/
|
|
21
|
+
declare class FileSink implements LogSink {
|
|
22
|
+
private currentSize;
|
|
23
|
+
private initialized;
|
|
24
|
+
private readonly logDir;
|
|
25
|
+
private readonly maxFileSize;
|
|
26
|
+
private readonly maxFiles;
|
|
27
|
+
private readonly filename;
|
|
28
|
+
private readonly logPath;
|
|
29
|
+
constructor(options?: FileSinkOptions);
|
|
30
|
+
write(entry: OperationsLogEntry): void;
|
|
31
|
+
private ensureDir;
|
|
32
|
+
private rotate;
|
|
33
|
+
}
|
|
34
|
+
//#endregion
|
|
35
|
+
export { FileSink, FileSinkOptions };
|
|
36
|
+
//# sourceMappingURL=file-sink.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"file-sink.d.mts","names":[],"sources":["../../../src/logger/sinks/file-sink.ts"],"mappings":";;;UAKiB,eAAA;;EAEhB,MAAA;EAF+B;EAI/B,WAAA;EAJ+B;EAM/B,QAAA;EAFA;EAIA,QAAA;AAAA;;;AAiBD;;;;;cAAa,QAAA,YAAoB,OAAA;EAAA,QACxB,WAAA;EAAA,QACA,WAAA;EAAA,iBACS,MAAA;EAAA,iBACA,WAAA;EAAA,iBACA,QAAA;EAAA,iBACA,QAAA;EAAA,iBACA,OAAA;cAEL,OAAA,GAAU,eAAA;EAgBtB,KAAA,CAAM,KAAA,EAAO,kBAAA;EAAA,QAWL,SAAA;EAAA,QAmBA,MAAA;AAAA"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { appendFileSync, existsSync, mkdirSync, renameSync, statSync, unlinkSync } from "node:fs";
|
|
2
|
+
import { homedir } from "node:os";
|
|
3
|
+
import { join } from "node:path";
|
|
4
|
+
//#region src/logger/sinks/file-sink.ts
|
|
5
|
+
const DEFAULT_MAX_SIZE = 10 * 1024 * 1024;
|
|
6
|
+
const DEFAULT_MAX_FILES = 5;
|
|
7
|
+
function defaultLogDir() {
|
|
8
|
+
return process.env.OPENCLAW_LOG_DIR ?? join(homedir(), ".better-openclaw", "logs");
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* NDJSON file sink with size-based rotation.
|
|
12
|
+
*
|
|
13
|
+
* Writes one JSON object per line (newline-delimited JSON).
|
|
14
|
+
* Rotates files when they exceed maxFileSize:
|
|
15
|
+
* operations.log → operations.1.log → operations.2.log → ...
|
|
16
|
+
*/
|
|
17
|
+
var FileSink = class {
|
|
18
|
+
currentSize = 0;
|
|
19
|
+
initialized = false;
|
|
20
|
+
logDir;
|
|
21
|
+
maxFileSize;
|
|
22
|
+
maxFiles;
|
|
23
|
+
filename;
|
|
24
|
+
logPath;
|
|
25
|
+
constructor(options) {
|
|
26
|
+
this.logDir = options?.logDir ?? defaultLogDir();
|
|
27
|
+
this.maxFileSize = options?.maxFileSize ?? (process.env.OPENCLAW_LOG_MAX_SIZE ? Number.parseInt(process.env.OPENCLAW_LOG_MAX_SIZE, 10) : DEFAULT_MAX_SIZE);
|
|
28
|
+
this.maxFiles = options?.maxFiles ?? (process.env.OPENCLAW_LOG_MAX_FILES ? Number.parseInt(process.env.OPENCLAW_LOG_MAX_FILES, 10) : DEFAULT_MAX_FILES);
|
|
29
|
+
this.filename = options?.filename ?? "operations";
|
|
30
|
+
this.logPath = join(this.logDir, `${this.filename}.log`);
|
|
31
|
+
}
|
|
32
|
+
write(entry) {
|
|
33
|
+
this.ensureDir();
|
|
34
|
+
const line = `${JSON.stringify(entry)}\n`;
|
|
35
|
+
appendFileSync(this.logPath, line, "utf-8");
|
|
36
|
+
this.currentSize += Buffer.byteLength(line, "utf-8");
|
|
37
|
+
if (this.currentSize >= this.maxFileSize) this.rotate();
|
|
38
|
+
}
|
|
39
|
+
ensureDir() {
|
|
40
|
+
if (this.initialized) return;
|
|
41
|
+
if (!existsSync(this.logDir)) mkdirSync(this.logDir, { recursive: true });
|
|
42
|
+
if (existsSync(this.logPath)) try {
|
|
43
|
+
this.currentSize = statSync(this.logPath).size;
|
|
44
|
+
} catch {
|
|
45
|
+
this.currentSize = 0;
|
|
46
|
+
}
|
|
47
|
+
this.initialized = true;
|
|
48
|
+
}
|
|
49
|
+
rotate() {
|
|
50
|
+
const oldest = join(this.logDir, `${this.filename}.${this.maxFiles}.log`);
|
|
51
|
+
if (existsSync(oldest)) try {
|
|
52
|
+
unlinkSync(oldest);
|
|
53
|
+
} catch {}
|
|
54
|
+
for (let i = this.maxFiles - 1; i >= 1; i--) {
|
|
55
|
+
const from = join(this.logDir, `${this.filename}.${i}.log`);
|
|
56
|
+
const to = join(this.logDir, `${this.filename}.${i + 1}.log`);
|
|
57
|
+
if (existsSync(from)) try {
|
|
58
|
+
renameSync(from, to);
|
|
59
|
+
} catch {}
|
|
60
|
+
}
|
|
61
|
+
if (existsSync(this.logPath)) try {
|
|
62
|
+
renameSync(this.logPath, join(this.logDir, `${this.filename}.1.log`));
|
|
63
|
+
} catch {}
|
|
64
|
+
this.currentSize = 0;
|
|
65
|
+
}
|
|
66
|
+
};
|
|
67
|
+
//#endregion
|
|
68
|
+
export { FileSink };
|
|
69
|
+
|
|
70
|
+
//# sourceMappingURL=file-sink.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"file-sink.mjs","names":[],"sources":["../../../src/logger/sinks/file-sink.ts"],"sourcesContent":["import { appendFileSync, existsSync, mkdirSync, renameSync, statSync, unlinkSync } from \"node:fs\";\nimport { homedir } from \"node:os\";\nimport { join } from \"node:path\";\nimport type { LogSink, OperationsLogEntry } from \"../types.js\";\n\nexport interface FileSinkOptions {\n\t/** Log directory. Default: ~/.better-openclaw/logs */\n\tlogDir?: string;\n\t/** Max file size in bytes before rotation. Default: 10 MB */\n\tmaxFileSize?: number;\n\t/** Max number of rotated files to keep. Default: 5 */\n\tmaxFiles?: number;\n\t/** Base filename (without extension). Default: \"operations\" */\n\tfilename?: string;\n}\n\nconst DEFAULT_MAX_SIZE = 10 * 1024 * 1024; // 10 MB\nconst DEFAULT_MAX_FILES = 5;\n\nfunction defaultLogDir(): string {\n\treturn process.env.OPENCLAW_LOG_DIR ?? join(homedir(), \".better-openclaw\", \"logs\");\n}\n\n/**\n * NDJSON file sink with size-based rotation.\n *\n * Writes one JSON object per line (newline-delimited JSON).\n * Rotates files when they exceed maxFileSize:\n * operations.log → operations.1.log → operations.2.log → ...\n */\nexport class FileSink implements LogSink {\n\tprivate currentSize = 0;\n\tprivate initialized = false;\n\tprivate readonly logDir: string;\n\tprivate readonly maxFileSize: number;\n\tprivate readonly maxFiles: number;\n\tprivate readonly filename: string;\n\tprivate readonly logPath: string;\n\n\tconstructor(options?: FileSinkOptions) {\n\t\tthis.logDir = options?.logDir ?? defaultLogDir();\n\t\tthis.maxFileSize =\n\t\t\toptions?.maxFileSize ??\n\t\t\t(process.env.OPENCLAW_LOG_MAX_SIZE\n\t\t\t\t? Number.parseInt(process.env.OPENCLAW_LOG_MAX_SIZE, 10)\n\t\t\t\t: DEFAULT_MAX_SIZE);\n\t\tthis.maxFiles =\n\t\t\toptions?.maxFiles ??\n\t\t\t(process.env.OPENCLAW_LOG_MAX_FILES\n\t\t\t\t? Number.parseInt(process.env.OPENCLAW_LOG_MAX_FILES, 10)\n\t\t\t\t: DEFAULT_MAX_FILES);\n\t\tthis.filename = options?.filename ?? \"operations\";\n\t\tthis.logPath = join(this.logDir, `${this.filename}.log`);\n\t}\n\n\twrite(entry: OperationsLogEntry): void {\n\t\tthis.ensureDir();\n\t\tconst line = `${JSON.stringify(entry)}\\n`;\n\t\tappendFileSync(this.logPath, line, \"utf-8\");\n\t\tthis.currentSize += Buffer.byteLength(line, \"utf-8\");\n\n\t\tif (this.currentSize >= this.maxFileSize) {\n\t\t\tthis.rotate();\n\t\t}\n\t}\n\n\tprivate ensureDir(): void {\n\t\tif (this.initialized) return;\n\n\t\tif (!existsSync(this.logDir)) {\n\t\t\tmkdirSync(this.logDir, { recursive: true });\n\t\t}\n\n\t\t// Seed current size from existing file\n\t\tif (existsSync(this.logPath)) {\n\t\t\ttry {\n\t\t\t\tthis.currentSize = statSync(this.logPath).size;\n\t\t\t} catch {\n\t\t\t\tthis.currentSize = 0;\n\t\t\t}\n\t\t}\n\n\t\tthis.initialized = true;\n\t}\n\n\tprivate rotate(): void {\n\t\t// Delete the oldest file if it exists\n\t\tconst oldest = join(this.logDir, `${this.filename}.${this.maxFiles}.log`);\n\t\tif (existsSync(oldest)) {\n\t\t\ttry {\n\t\t\t\tunlinkSync(oldest);\n\t\t\t} catch {\n\t\t\t\t// Ignore\n\t\t\t}\n\t\t}\n\n\t\t// Shift existing rotated files: N-1 → N, N-2 → N-1, ..., 1 → 2\n\t\tfor (let i = this.maxFiles - 1; i >= 1; i--) {\n\t\t\tconst from = join(this.logDir, `${this.filename}.${i}.log`);\n\t\t\tconst to = join(this.logDir, `${this.filename}.${i + 1}.log`);\n\t\t\tif (existsSync(from)) {\n\t\t\t\ttry {\n\t\t\t\t\trenameSync(from, to);\n\t\t\t\t} catch {\n\t\t\t\t\t// Ignore\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// Rename current log to .1.log\n\t\tif (existsSync(this.logPath)) {\n\t\t\ttry {\n\t\t\t\trenameSync(this.logPath, join(this.logDir, `${this.filename}.1.log`));\n\t\t\t} catch {\n\t\t\t\t// Ignore\n\t\t\t}\n\t\t}\n\n\t\tthis.currentSize = 0;\n\t}\n}\n"],"mappings":";;;;AAgBA,MAAM,mBAAmB,KAAK,OAAO;AACrC,MAAM,oBAAoB;AAE1B,SAAS,gBAAwB;AAChC,QAAO,QAAQ,IAAI,oBAAoB,KAAK,SAAS,EAAE,oBAAoB,OAAO;;;;;;;;;AAUnF,IAAa,WAAb,MAAyC;CACxC,cAAsB;CACtB,cAAsB;CACtB;CACA;CACA;CACA;CACA;CAEA,YAAY,SAA2B;AACtC,OAAK,SAAS,SAAS,UAAU,eAAe;AAChD,OAAK,cACJ,SAAS,gBACR,QAAQ,IAAI,wBACV,OAAO,SAAS,QAAQ,IAAI,uBAAuB,GAAG,GACtD;AACJ,OAAK,WACJ,SAAS,aACR,QAAQ,IAAI,yBACV,OAAO,SAAS,QAAQ,IAAI,wBAAwB,GAAG,GACvD;AACJ,OAAK,WAAW,SAAS,YAAY;AACrC,OAAK,UAAU,KAAK,KAAK,QAAQ,GAAG,KAAK,SAAS,MAAM;;CAGzD,MAAM,OAAiC;AACtC,OAAK,WAAW;EAChB,MAAM,OAAO,GAAG,KAAK,UAAU,MAAM,CAAC;AACtC,iBAAe,KAAK,SAAS,MAAM,QAAQ;AAC3C,OAAK,eAAe,OAAO,WAAW,MAAM,QAAQ;AAEpD,MAAI,KAAK,eAAe,KAAK,YAC5B,MAAK,QAAQ;;CAIf,YAA0B;AACzB,MAAI,KAAK,YAAa;AAEtB,MAAI,CAAC,WAAW,KAAK,OAAO,CAC3B,WAAU,KAAK,QAAQ,EAAE,WAAW,MAAM,CAAC;AAI5C,MAAI,WAAW,KAAK,QAAQ,CAC3B,KAAI;AACH,QAAK,cAAc,SAAS,KAAK,QAAQ,CAAC;UACnC;AACP,QAAK,cAAc;;AAIrB,OAAK,cAAc;;CAGpB,SAAuB;EAEtB,MAAM,SAAS,KAAK,KAAK,QAAQ,GAAG,KAAK,SAAS,GAAG,KAAK,SAAS,MAAM;AACzE,MAAI,WAAW,OAAO,CACrB,KAAI;AACH,cAAW,OAAO;UACX;AAMT,OAAK,IAAI,IAAI,KAAK,WAAW,GAAG,KAAK,GAAG,KAAK;GAC5C,MAAM,OAAO,KAAK,KAAK,QAAQ,GAAG,KAAK,SAAS,GAAG,EAAE,MAAM;GAC3D,MAAM,KAAK,KAAK,KAAK,QAAQ,GAAG,KAAK,SAAS,GAAG,IAAI,EAAE,MAAM;AAC7D,OAAI,WAAW,KAAK,CACnB,KAAI;AACH,eAAW,MAAM,GAAG;WACb;;AAOV,MAAI,WAAW,KAAK,QAAQ,CAC3B,KAAI;AACH,cAAW,KAAK,SAAS,KAAK,KAAK,QAAQ,GAAG,KAAK,SAAS,QAAQ,CAAC;UAC9D;AAKT,OAAK,cAAc"}
|
|
File without changes
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import { a as OperationOutcome, c as OperationsLoggerOptions, i as OperationCategory, n as LogSink, o as OperationStep, r as LogSource, s as OperationsLogEntry, t as LogLevel } from "../types-CyZ5mn6w.cjs";
|
|
2
|
+
export { LogLevel, LogSink, LogSource, OperationCategory, OperationOutcome, OperationStep, OperationsLogEntry, OperationsLoggerOptions };
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import { a as OperationOutcome, c as OperationsLoggerOptions, i as OperationCategory, n as LogSink, o as OperationStep, r as LogSource, s as OperationsLogEntry, t as LogLevel } from "../types-BREUfzzq.mjs";
|
|
2
|
+
export { LogLevel, LogSink, LogSource, OperationCategory, OperationOutcome, OperationStep, OperationsLogEntry, OperationsLoggerOptions };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { a as OperationOutcome, c as OperationsLoggerOptions, i as OperationCategory, o as OperationStep, s as OperationsLogEntry } from "./types-BREUfzzq.mjs";
|
|
2
|
+
|
|
3
|
+
//#region src/logger/logger.d.ts
|
|
4
|
+
/**
|
|
5
|
+
* Tracks individual steps within a multi-step operation (e.g. deploy, generate).
|
|
6
|
+
*/
|
|
7
|
+
declare class StepTracker {
|
|
8
|
+
private readonly logger;
|
|
9
|
+
private readonly category;
|
|
10
|
+
private readonly operationName;
|
|
11
|
+
private steps;
|
|
12
|
+
private currentStep;
|
|
13
|
+
private readonly operationStart;
|
|
14
|
+
constructor(logger: OperationsLogger, category: OperationCategory, operationName: string);
|
|
15
|
+
/** Start a new step. Automatically completes the previous step if still open. */
|
|
16
|
+
begin(name: string, detail?: string): void;
|
|
17
|
+
/** Mark the current step as completed. */
|
|
18
|
+
complete(detail?: string): void;
|
|
19
|
+
/** Mark the current step as failed. */
|
|
20
|
+
fail(error: string): void;
|
|
21
|
+
/** Record a skipped step. */
|
|
22
|
+
skip(name: string, reason?: string): void;
|
|
23
|
+
/** Finalize and log the full operation summary. Returns all steps. */
|
|
24
|
+
finalize(outcome: OperationOutcome): OperationStep[];
|
|
25
|
+
/** Get the current list of steps (snapshot). */
|
|
26
|
+
getSteps(): OperationStep[];
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Centralized operations logger.
|
|
30
|
+
*
|
|
31
|
+
* Follows fire-and-forget semantics — sink errors are silently caught and
|
|
32
|
+
* logging never blocks or crashes the main flow.
|
|
33
|
+
*/
|
|
34
|
+
declare class OperationsLogger {
|
|
35
|
+
private readonly source;
|
|
36
|
+
private readonly sinks;
|
|
37
|
+
private readonly correlationId;
|
|
38
|
+
private readonly sessionId;
|
|
39
|
+
private readonly minLevel;
|
|
40
|
+
constructor(options: OperationsLoggerOptions);
|
|
41
|
+
/** Create a child logger that inherits correlation/session but can override source or sinks. */
|
|
42
|
+
child(overrides: Partial<OperationsLoggerOptions>): OperationsLogger;
|
|
43
|
+
/** Log an operation with full context. Fire-and-forget to all sinks. */
|
|
44
|
+
log(entry: Omit<OperationsLogEntry, "id" | "timestamp" | "source" | "correlationId" | "sessionId">): void;
|
|
45
|
+
info(category: OperationCategory, message: string, context?: Record<string, unknown>): void;
|
|
46
|
+
warn(category: OperationCategory, message: string, context?: Record<string, unknown>): void;
|
|
47
|
+
error(category: OperationCategory, message: string, err?: Error | null, context?: Record<string, unknown>): void;
|
|
48
|
+
debug(category: OperationCategory, message: string, context?: Record<string, unknown>): void;
|
|
49
|
+
/**
|
|
50
|
+
* Log a timed operation. Wraps an async/sync function with start/end/duration logging.
|
|
51
|
+
* Re-throws the original error on failure.
|
|
52
|
+
*/
|
|
53
|
+
timed<T>(category: OperationCategory, message: string, fn: () => T | Promise<T>, context?: Record<string, unknown>): Promise<T>;
|
|
54
|
+
/** Create a step tracker for multi-step operations (deploy, generate pipeline). */
|
|
55
|
+
createStepTracker(category: OperationCategory, operationName: string): StepTracker;
|
|
56
|
+
/** Flush all sinks. */
|
|
57
|
+
flush(): Promise<void>;
|
|
58
|
+
/** Destroy all sinks (cleanup timers, close streams). */
|
|
59
|
+
destroy(): Promise<void>;
|
|
60
|
+
getCorrelationId(): string;
|
|
61
|
+
getSessionId(): string;
|
|
62
|
+
private shouldLog;
|
|
63
|
+
}
|
|
64
|
+
//#endregion
|
|
65
|
+
export { StepTracker as n, OperationsLogger as t };
|
|
66
|
+
//# sourceMappingURL=logger-CZ0Qnyiu.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger-CZ0Qnyiu.d.mts","names":[],"sources":["../src/logger/logger.ts"],"mappings":";;;;;AAmDA;cAAa,WAAA;EAAA,iBAMM,MAAA;EAAA,iBACA,QAAA;EAAA,iBACA,aAAA;EAAA,QAPV,KAAA;EAAA,QACA,WAAA;EAAA,iBACS,cAAA;cAGC,MAAA,EAAQ,gBAAA,EACR,QAAA,EAAU,iBAAA,EACV,aAAA;EA0EO;EAtEzB,KAAA,CAAM,IAAA,UAAc,MAAA;EALF;EAyBlB,QAAA,CAAS,MAAA;EA/BD;EAwCR,IAAA,CAAK,KAAA;EAtCY;EA+CjB,IAAA,CAAK,IAAA,UAAc,MAAA;EA5CO;EAwD1B,QAAA,CAAS,OAAA,EAAS,gBAAA,GAAmB,aAAA;EAvDT;EA2E5B,QAAA,CAAA,GAAY,aAAA;AAAA;;;;;;;cAWA,gBAAA;EAAA,iBACK,MAAA;EAAA,iBACA,KAAA;EAAA,iBACA,aAAA;EAAA,iBACA,SAAA;EAAA,iBACA,QAAA;cAEL,OAAA,EAAS,uBAAA;EAtCgB;EA+CrC,KAAA,CAAM,SAAA,EAAW,OAAA,CAAQ,uBAAA,IAA2B,gBAAA;EA3BxC;EAsCZ,GAAA,CACC,KAAA,EAAO,IAAA,CAAK,kBAAA;EA0Bb,IAAA,CAAK,QAAA,EAAU,iBAAA,EAAmB,OAAA,UAAiB,OAAA,GAAU,MAAA;EAI7D,IAAA,CAAK,QAAA,EAAU,iBAAA,EAAmB,OAAA,UAAiB,OAAA,GAAU,MAAA;EAI7D,KAAA,CACC,QAAA,EAAU,iBAAA,EACV,OAAA,UACA,GAAA,GAAM,KAAA,SACN,OAAA,GAAU,MAAA;EAkBX,KAAA,CAAM,QAAA,EAAU,iBAAA,EAAmB,OAAA,UAAiB,OAAA,GAAU,MAAA;EA7EzC;;;;EAqFf,KAAA,GAAA,CACL,QAAA,EAAU,iBAAA,EACV,OAAA,UACA,EAAA,QAAU,CAAA,GAAI,OAAA,CAAQ,CAAA,GACtB,OAAA,GAAU,MAAA,oBACR,OAAA,CAAQ,CAAA;EArEH;EAgHR,iBAAA,CAAkB,QAAA,EAAU,iBAAA,EAAmB,aAAA,WAAwB,WAAA;EAtFV;EA2FvD,KAAA,CAAA,GAAS,OAAA;EAvF8C;EAoGvD,OAAA,CAAA,GAAW,OAAA;EAYjB,gBAAA,CAAA;EAIA,YAAA,CAAA;EAAA,QAIQ,SAAA;AAAA"}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { a as OperationOutcome, c as OperationsLoggerOptions, i as OperationCategory, o as OperationStep, s as OperationsLogEntry } from "./types-CyZ5mn6w.cjs";
|
|
2
|
+
|
|
3
|
+
//#region src/logger/logger.d.ts
|
|
4
|
+
/**
|
|
5
|
+
* Tracks individual steps within a multi-step operation (e.g. deploy, generate).
|
|
6
|
+
*/
|
|
7
|
+
declare class StepTracker {
|
|
8
|
+
private readonly logger;
|
|
9
|
+
private readonly category;
|
|
10
|
+
private readonly operationName;
|
|
11
|
+
private steps;
|
|
12
|
+
private currentStep;
|
|
13
|
+
private readonly operationStart;
|
|
14
|
+
constructor(logger: OperationsLogger, category: OperationCategory, operationName: string);
|
|
15
|
+
/** Start a new step. Automatically completes the previous step if still open. */
|
|
16
|
+
begin(name: string, detail?: string): void;
|
|
17
|
+
/** Mark the current step as completed. */
|
|
18
|
+
complete(detail?: string): void;
|
|
19
|
+
/** Mark the current step as failed. */
|
|
20
|
+
fail(error: string): void;
|
|
21
|
+
/** Record a skipped step. */
|
|
22
|
+
skip(name: string, reason?: string): void;
|
|
23
|
+
/** Finalize and log the full operation summary. Returns all steps. */
|
|
24
|
+
finalize(outcome: OperationOutcome): OperationStep[];
|
|
25
|
+
/** Get the current list of steps (snapshot). */
|
|
26
|
+
getSteps(): OperationStep[];
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Centralized operations logger.
|
|
30
|
+
*
|
|
31
|
+
* Follows fire-and-forget semantics — sink errors are silently caught and
|
|
32
|
+
* logging never blocks or crashes the main flow.
|
|
33
|
+
*/
|
|
34
|
+
declare class OperationsLogger {
|
|
35
|
+
private readonly source;
|
|
36
|
+
private readonly sinks;
|
|
37
|
+
private readonly correlationId;
|
|
38
|
+
private readonly sessionId;
|
|
39
|
+
private readonly minLevel;
|
|
40
|
+
constructor(options: OperationsLoggerOptions);
|
|
41
|
+
/** Create a child logger that inherits correlation/session but can override source or sinks. */
|
|
42
|
+
child(overrides: Partial<OperationsLoggerOptions>): OperationsLogger;
|
|
43
|
+
/** Log an operation with full context. Fire-and-forget to all sinks. */
|
|
44
|
+
log(entry: Omit<OperationsLogEntry, "id" | "timestamp" | "source" | "correlationId" | "sessionId">): void;
|
|
45
|
+
info(category: OperationCategory, message: string, context?: Record<string, unknown>): void;
|
|
46
|
+
warn(category: OperationCategory, message: string, context?: Record<string, unknown>): void;
|
|
47
|
+
error(category: OperationCategory, message: string, err?: Error | null, context?: Record<string, unknown>): void;
|
|
48
|
+
debug(category: OperationCategory, message: string, context?: Record<string, unknown>): void;
|
|
49
|
+
/**
|
|
50
|
+
* Log a timed operation. Wraps an async/sync function with start/end/duration logging.
|
|
51
|
+
* Re-throws the original error on failure.
|
|
52
|
+
*/
|
|
53
|
+
timed<T>(category: OperationCategory, message: string, fn: () => T | Promise<T>, context?: Record<string, unknown>): Promise<T>;
|
|
54
|
+
/** Create a step tracker for multi-step operations (deploy, generate pipeline). */
|
|
55
|
+
createStepTracker(category: OperationCategory, operationName: string): StepTracker;
|
|
56
|
+
/** Flush all sinks. */
|
|
57
|
+
flush(): Promise<void>;
|
|
58
|
+
/** Destroy all sinks (cleanup timers, close streams). */
|
|
59
|
+
destroy(): Promise<void>;
|
|
60
|
+
getCorrelationId(): string;
|
|
61
|
+
getSessionId(): string;
|
|
62
|
+
private shouldLog;
|
|
63
|
+
}
|
|
64
|
+
//#endregion
|
|
65
|
+
export { StepTracker as n, OperationsLogger as t };
|
|
66
|
+
//# sourceMappingURL=logger-DDfwai-A.d.cts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger-DDfwai-A.d.cts","names":[],"sources":["../src/logger/logger.ts"],"mappings":";;;;;AAmDA;cAAa,WAAA;EAAA,iBAMM,MAAA;EAAA,iBACA,QAAA;EAAA,iBACA,aAAA;EAAA,QAPV,KAAA;EAAA,QACA,WAAA;EAAA,iBACS,cAAA;cAGC,MAAA,EAAQ,gBAAA,EACR,QAAA,EAAU,iBAAA,EACV,aAAA;EA0EO;EAtEzB,KAAA,CAAM,IAAA,UAAc,MAAA;EALF;EAyBlB,QAAA,CAAS,MAAA;EA/BD;EAwCR,IAAA,CAAK,KAAA;EAtCY;EA+CjB,IAAA,CAAK,IAAA,UAAc,MAAA;EA5CO;EAwD1B,QAAA,CAAS,OAAA,EAAS,gBAAA,GAAmB,aAAA;EAvDT;EA2E5B,QAAA,CAAA,GAAY,aAAA;AAAA;;;;;;;cAWA,gBAAA;EAAA,iBACK,MAAA;EAAA,iBACA,KAAA;EAAA,iBACA,aAAA;EAAA,iBACA,SAAA;EAAA,iBACA,QAAA;cAEL,OAAA,EAAS,uBAAA;EAtCgB;EA+CrC,KAAA,CAAM,SAAA,EAAW,OAAA,CAAQ,uBAAA,IAA2B,gBAAA;EA3BxC;EAsCZ,GAAA,CACC,KAAA,EAAO,IAAA,CAAK,kBAAA;EA0Bb,IAAA,CAAK,QAAA,EAAU,iBAAA,EAAmB,OAAA,UAAiB,OAAA,GAAU,MAAA;EAI7D,IAAA,CAAK,QAAA,EAAU,iBAAA,EAAmB,OAAA,UAAiB,OAAA,GAAU,MAAA;EAI7D,KAAA,CACC,QAAA,EAAU,iBAAA,EACV,OAAA,UACA,GAAA,GAAM,KAAA,SACN,OAAA,GAAU,MAAA;EAkBX,KAAA,CAAM,QAAA,EAAU,iBAAA,EAAmB,OAAA,UAAiB,OAAA,GAAU,MAAA;EA7EzC;;;;EAqFf,KAAA,GAAA,CACL,QAAA,EAAU,iBAAA,EACV,OAAA,UACA,EAAA,QAAU,CAAA,GAAI,OAAA,CAAQ,CAAA,GACtB,OAAA,GAAU,MAAA,oBACR,OAAA,CAAQ,CAAA;EArEH;EAgHR,iBAAA,CAAkB,QAAA,EAAU,iBAAA,EAAmB,aAAA,WAAwB,WAAA;EAtFV;EA2FvD,KAAA,CAAA,GAAS,OAAA;EAvF8C;EAoGvD,OAAA,CAAA,GAAW,OAAA;EAYjB,gBAAA,CAAA;EAIA,YAAA,CAAA;EAAA,QAIQ,SAAA;AAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"memu-BfRXtwmL.d.cts","names":[],"sources":["../src/frameworks/memu.ts"],"mappings":";;;cAuBa,aAAA,EAAe,wBAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"memu-C-fXbWr-.d.mts","names":[],"sources":["../src/frameworks/memu.ts"],"mappings":";;;cAuBa,aAAA,EAAe,wBAAA"}
|
package/dist/migrations.cjs
CHANGED
|
@@ -1,20 +1,28 @@
|
|
|
1
1
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
2
2
|
//#region src/migrations.ts
|
|
3
|
-
const CURRENT_CONFIG_VERSION =
|
|
4
|
-
const migrations = {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
3
|
+
const CURRENT_CONFIG_VERSION = 3;
|
|
4
|
+
const migrations = {
|
|
5
|
+
1: (input) => ({
|
|
6
|
+
...input,
|
|
7
|
+
configVersion: 2,
|
|
8
|
+
deploymentType: input.deploymentType ?? "docker"
|
|
9
|
+
}),
|
|
10
|
+
2: (input) => ({
|
|
11
|
+
...input,
|
|
12
|
+
configVersion: 3,
|
|
13
|
+
primaryFramework: input.primaryFramework ?? "openclaw",
|
|
14
|
+
companionFrameworks: input.companionFrameworks ?? []
|
|
15
|
+
})
|
|
16
|
+
};
|
|
9
17
|
/**
|
|
10
18
|
* Applies sequential migrations to bring a config from its current version
|
|
11
19
|
* to CURRENT_CONFIG_VERSION. Returns the config unchanged if already current.
|
|
12
20
|
*/
|
|
13
21
|
function migrateConfig(input) {
|
|
14
22
|
let version = input.configVersion ?? 1;
|
|
15
|
-
if (version >
|
|
23
|
+
if (version > 3) throw new Error(`No migration path from config version ${version}`);
|
|
16
24
|
let current = { ...input };
|
|
17
|
-
while (version <
|
|
25
|
+
while (version < 3) {
|
|
18
26
|
const migrationFn = migrations[version];
|
|
19
27
|
if (!migrationFn) throw new Error(`No migration path from config version ${version}`);
|
|
20
28
|
current = migrationFn(current);
|
|
@@ -26,7 +34,7 @@ function migrateConfig(input) {
|
|
|
26
34
|
* Returns true if the config needs migration to the current version.
|
|
27
35
|
*/
|
|
28
36
|
function needsMigration(input) {
|
|
29
|
-
return (input.configVersion ?? 1) <
|
|
37
|
+
return (input.configVersion ?? 1) < 3;
|
|
30
38
|
}
|
|
31
39
|
//#endregion
|
|
32
40
|
exports.CURRENT_CONFIG_VERSION = CURRENT_CONFIG_VERSION;
|
package/dist/migrations.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"migrations.cjs","names":[],"sources":["../src/migrations.ts"],"sourcesContent":["export const CURRENT_CONFIG_VERSION =
|
|
1
|
+
{"version":3,"file":"migrations.cjs","names":[],"sources":["../src/migrations.ts"],"sourcesContent":["export const CURRENT_CONFIG_VERSION = 3;\n\ntype MigrationFn = (input: Record<string, unknown>) => Record<string, unknown>;\n\nconst migrations: Record<number, MigrationFn> = {\n\t// v1 → v2: ensure deploymentType field exists (defaulting to \"docker\")\n\t1: (input) => ({\n\t\t...input,\n\t\tconfigVersion: 2,\n\t\tdeploymentType: (input.deploymentType as string) ?? \"docker\",\n\t}),\n\t// v2 → v3: add primaryFramework (defaults to \"openclaw\" for existing configs)\n\t2: (input) => ({\n\t\t...input,\n\t\tconfigVersion: 3,\n\t\tprimaryFramework: (input.primaryFramework as string) ?? \"openclaw\",\n\t\tcompanionFrameworks: (input.companionFrameworks as string[]) ?? [],\n\t}),\n};\n\n/**\n * Applies sequential migrations to bring a config from its current version\n * to CURRENT_CONFIG_VERSION. Returns the config unchanged if already current.\n */\nexport function migrateConfig(input: Record<string, unknown>): Record<string, unknown> {\n\tlet version = (input.configVersion as number) ?? 1;\n\n\tif (version > CURRENT_CONFIG_VERSION) {\n\t\tthrow new Error(`No migration path from config version ${version}`);\n\t}\n\n\tlet current = { ...input };\n\n\twhile (version < CURRENT_CONFIG_VERSION) {\n\t\tconst migrationFn = migrations[version];\n\t\tif (!migrationFn) {\n\t\t\tthrow new Error(`No migration path from config version ${version}`);\n\t\t}\n\t\tcurrent = migrationFn(current);\n\t\tversion++;\n\t}\n\n\treturn current;\n}\n\n/**\n * Returns true if the config needs migration to the current version.\n */\nexport function needsMigration(input: Record<string, unknown>): boolean {\n\tconst version = (input.configVersion as number) ?? 1;\n\treturn version < CURRENT_CONFIG_VERSION;\n}\n"],"mappings":";;AAAA,MAAa,yBAAyB;AAItC,MAAM,aAA0C;CAE/C,IAAI,WAAW;EACd,GAAG;EACH,eAAe;EACf,gBAAiB,MAAM,kBAA6B;EACpD;CAED,IAAI,WAAW;EACd,GAAG;EACH,eAAe;EACf,kBAAmB,MAAM,oBAA+B;EACxD,qBAAsB,MAAM,uBAAoC,EAAE;EAClE;CACD;;;;;AAMD,SAAgB,cAAc,OAAyD;CACtF,IAAI,UAAW,MAAM,iBAA4B;AAEjD,KAAI,UAAA,EACH,OAAM,IAAI,MAAM,yCAAyC,UAAU;CAGpE,IAAI,UAAU,EAAE,GAAG,OAAO;AAE1B,QAAO,UAAA,GAAkC;EACxC,MAAM,cAAc,WAAW;AAC/B,MAAI,CAAC,YACJ,OAAM,IAAI,MAAM,yCAAyC,UAAU;AAEpE,YAAU,YAAY,QAAQ;AAC9B;;AAGD,QAAO;;;;;AAMR,SAAgB,eAAe,OAAyC;AAEvE,SADiB,MAAM,iBAA4B,KAAA"}
|
package/dist/migrations.d.cts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
//#region src/migrations.d.ts
|
|
2
|
-
declare const CURRENT_CONFIG_VERSION =
|
|
2
|
+
declare const CURRENT_CONFIG_VERSION = 3;
|
|
3
3
|
/**
|
|
4
4
|
* Applies sequential migrations to bring a config from its current version
|
|
5
5
|
* to CURRENT_CONFIG_VERSION. Returns the config unchanged if already current.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"migrations.d.cts","names":[],"sources":["../src/migrations.ts"],"mappings":";cAAa,sBAAA;AAAb;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"migrations.d.cts","names":[],"sources":["../src/migrations.ts"],"mappings":";cAAa,sBAAA;AAAb;;;;AAAA,iBAwBgB,aAAA,CAAc,KAAA,EAAO,MAAA,oBAA0B,MAAA;AAA/D;;;AAAA,iBAwBgB,cAAA,CAAe,KAAA,EAAO,MAAA"}
|
package/dist/migrations.d.mts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
//#region src/migrations.d.ts
|
|
2
|
-
declare const CURRENT_CONFIG_VERSION =
|
|
2
|
+
declare const CURRENT_CONFIG_VERSION = 3;
|
|
3
3
|
/**
|
|
4
4
|
* Applies sequential migrations to bring a config from its current version
|
|
5
5
|
* to CURRENT_CONFIG_VERSION. Returns the config unchanged if already current.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"migrations.d.mts","names":[],"sources":["../src/migrations.ts"],"mappings":";cAAa,sBAAA;AAAb;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"migrations.d.mts","names":[],"sources":["../src/migrations.ts"],"mappings":";cAAa,sBAAA;AAAb;;;;AAAA,iBAwBgB,aAAA,CAAc,KAAA,EAAO,MAAA,oBAA0B,MAAA;AAA/D;;;AAAA,iBAwBgB,cAAA,CAAe,KAAA,EAAO,MAAA"}
|