@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,270 @@
|
|
|
1
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
2
|
+
require("../skills-uPxJVmKk.cjs");
|
|
3
|
+
let node_crypto = require("node:crypto");
|
|
4
|
+
//#region src/logger/logger.ts
|
|
5
|
+
/** Keys that must never appear in logged context. */
|
|
6
|
+
const SENSITIVE_KEYS = new Set([
|
|
7
|
+
"apikey",
|
|
8
|
+
"api_key",
|
|
9
|
+
"password",
|
|
10
|
+
"token",
|
|
11
|
+
"secret",
|
|
12
|
+
"authorization",
|
|
13
|
+
"credentials",
|
|
14
|
+
"private_key",
|
|
15
|
+
"privatekey"
|
|
16
|
+
]);
|
|
17
|
+
const LEVEL_ORDER = {
|
|
18
|
+
debug: 0,
|
|
19
|
+
info: 1,
|
|
20
|
+
warn: 2,
|
|
21
|
+
error: 3
|
|
22
|
+
};
|
|
23
|
+
/** Strip sensitive keys from a context object (shallow). */
|
|
24
|
+
function sanitizeContext(ctx) {
|
|
25
|
+
if (!ctx) return ctx;
|
|
26
|
+
const clean = {};
|
|
27
|
+
for (const [key, value] of Object.entries(ctx)) if (SENSITIVE_KEYS.has(key.toLowerCase())) clean[key] = "[REDACTED]";
|
|
28
|
+
else clean[key] = value;
|
|
29
|
+
return clean;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Tracks individual steps within a multi-step operation (e.g. deploy, generate).
|
|
33
|
+
*/
|
|
34
|
+
var StepTracker = class {
|
|
35
|
+
steps = [];
|
|
36
|
+
currentStep = null;
|
|
37
|
+
operationStart = Date.now();
|
|
38
|
+
constructor(logger, category, operationName) {
|
|
39
|
+
this.logger = logger;
|
|
40
|
+
this.category = category;
|
|
41
|
+
this.operationName = operationName;
|
|
42
|
+
}
|
|
43
|
+
/** Start a new step. Automatically completes the previous step if still open. */
|
|
44
|
+
begin(name, detail) {
|
|
45
|
+
if (this.currentStep && this.currentStep.status === "in_progress") {
|
|
46
|
+
this.currentStep.status = "success";
|
|
47
|
+
this.currentStep.completedAt = (/* @__PURE__ */ new Date()).toISOString();
|
|
48
|
+
this.currentStep.durationMs = Date.now() - new Date(this.currentStep.startedAt).getTime();
|
|
49
|
+
}
|
|
50
|
+
this.currentStep = {
|
|
51
|
+
name,
|
|
52
|
+
status: "in_progress",
|
|
53
|
+
detail,
|
|
54
|
+
startedAt: (/* @__PURE__ */ new Date()).toISOString()
|
|
55
|
+
};
|
|
56
|
+
this.steps.push(this.currentStep);
|
|
57
|
+
this.logger.debug(this.category, `[${this.operationName}] ${name}`, {
|
|
58
|
+
step: name,
|
|
59
|
+
detail
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
/** Mark the current step as completed. */
|
|
63
|
+
complete(detail) {
|
|
64
|
+
if (!this.currentStep) return;
|
|
65
|
+
this.currentStep.status = "success";
|
|
66
|
+
this.currentStep.completedAt = (/* @__PURE__ */ new Date()).toISOString();
|
|
67
|
+
this.currentStep.durationMs = Date.now() - new Date(this.currentStep.startedAt).getTime();
|
|
68
|
+
if (detail) this.currentStep.detail = detail;
|
|
69
|
+
}
|
|
70
|
+
/** Mark the current step as failed. */
|
|
71
|
+
fail(error) {
|
|
72
|
+
if (!this.currentStep) return;
|
|
73
|
+
this.currentStep.status = "failure";
|
|
74
|
+
this.currentStep.completedAt = (/* @__PURE__ */ new Date()).toISOString();
|
|
75
|
+
this.currentStep.durationMs = Date.now() - new Date(this.currentStep.startedAt).getTime();
|
|
76
|
+
this.currentStep.detail = error;
|
|
77
|
+
}
|
|
78
|
+
/** Record a skipped step. */
|
|
79
|
+
skip(name, reason) {
|
|
80
|
+
this.steps.push({
|
|
81
|
+
name,
|
|
82
|
+
status: "skipped",
|
|
83
|
+
detail: reason,
|
|
84
|
+
startedAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
85
|
+
completedAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
86
|
+
durationMs: 0
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
/** Finalize and log the full operation summary. Returns all steps. */
|
|
90
|
+
finalize(outcome) {
|
|
91
|
+
if (this.currentStep && this.currentStep.status === "in_progress") {
|
|
92
|
+
this.currentStep.status = outcome === "failure" ? "failure" : "success";
|
|
93
|
+
this.currentStep.completedAt = (/* @__PURE__ */ new Date()).toISOString();
|
|
94
|
+
this.currentStep.durationMs = Date.now() - new Date(this.currentStep.startedAt).getTime();
|
|
95
|
+
}
|
|
96
|
+
this.logger.log({
|
|
97
|
+
level: outcome === "failure" ? "error" : "info",
|
|
98
|
+
category: this.category,
|
|
99
|
+
message: `${this.operationName} ${outcome}`,
|
|
100
|
+
outcome,
|
|
101
|
+
durationMs: Date.now() - this.operationStart,
|
|
102
|
+
steps: this.steps
|
|
103
|
+
});
|
|
104
|
+
return this.steps;
|
|
105
|
+
}
|
|
106
|
+
/** Get the current list of steps (snapshot). */
|
|
107
|
+
getSteps() {
|
|
108
|
+
return [...this.steps];
|
|
109
|
+
}
|
|
110
|
+
};
|
|
111
|
+
/**
|
|
112
|
+
* Centralized operations logger.
|
|
113
|
+
*
|
|
114
|
+
* Follows fire-and-forget semantics — sink errors are silently caught and
|
|
115
|
+
* logging never blocks or crashes the main flow.
|
|
116
|
+
*/
|
|
117
|
+
var OperationsLogger = class OperationsLogger {
|
|
118
|
+
source;
|
|
119
|
+
sinks;
|
|
120
|
+
correlationId;
|
|
121
|
+
sessionId;
|
|
122
|
+
minLevel;
|
|
123
|
+
constructor(options) {
|
|
124
|
+
this.source = options.source;
|
|
125
|
+
this.sinks = options.sinks ?? [];
|
|
126
|
+
this.correlationId = options.correlationId ?? (0, node_crypto.randomUUID)();
|
|
127
|
+
this.sessionId = options.sessionId ?? (0, node_crypto.randomUUID)();
|
|
128
|
+
this.minLevel = options.minLevel ?? "info";
|
|
129
|
+
}
|
|
130
|
+
/** Create a child logger that inherits correlation/session but can override source or sinks. */
|
|
131
|
+
child(overrides) {
|
|
132
|
+
return new OperationsLogger({
|
|
133
|
+
source: overrides.source ?? this.source,
|
|
134
|
+
sinks: overrides.sinks ?? this.sinks,
|
|
135
|
+
correlationId: overrides.correlationId ?? this.correlationId,
|
|
136
|
+
sessionId: overrides.sessionId ?? this.sessionId,
|
|
137
|
+
minLevel: overrides.minLevel ?? this.minLevel
|
|
138
|
+
});
|
|
139
|
+
}
|
|
140
|
+
/** Log an operation with full context. Fire-and-forget to all sinks. */
|
|
141
|
+
log(entry) {
|
|
142
|
+
if (!this.shouldLog(entry.level)) return;
|
|
143
|
+
const full = {
|
|
144
|
+
id: (0, node_crypto.randomUUID)(),
|
|
145
|
+
timestamp: (/* @__PURE__ */ new Date()).toISOString(),
|
|
146
|
+
source: this.source,
|
|
147
|
+
correlationId: this.correlationId,
|
|
148
|
+
sessionId: this.sessionId,
|
|
149
|
+
...entry,
|
|
150
|
+
context: sanitizeContext(entry.context)
|
|
151
|
+
};
|
|
152
|
+
for (const sink of this.sinks) try {
|
|
153
|
+
const result = sink.write(full);
|
|
154
|
+
if (result instanceof Promise) result.catch(() => {});
|
|
155
|
+
} catch {}
|
|
156
|
+
}
|
|
157
|
+
info(category, message, context) {
|
|
158
|
+
this.log({
|
|
159
|
+
level: "info",
|
|
160
|
+
category,
|
|
161
|
+
message,
|
|
162
|
+
context
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
warn(category, message, context) {
|
|
166
|
+
this.log({
|
|
167
|
+
level: "warn",
|
|
168
|
+
category,
|
|
169
|
+
message,
|
|
170
|
+
context
|
|
171
|
+
});
|
|
172
|
+
}
|
|
173
|
+
error(category, message, err, context) {
|
|
174
|
+
this.log({
|
|
175
|
+
level: "error",
|
|
176
|
+
category,
|
|
177
|
+
message,
|
|
178
|
+
context,
|
|
179
|
+
error: err ? {
|
|
180
|
+
name: err.name,
|
|
181
|
+
message: err.message,
|
|
182
|
+
stack: err.stack,
|
|
183
|
+
code: err.code
|
|
184
|
+
} : void 0
|
|
185
|
+
});
|
|
186
|
+
}
|
|
187
|
+
debug(category, message, context) {
|
|
188
|
+
this.log({
|
|
189
|
+
level: "debug",
|
|
190
|
+
category,
|
|
191
|
+
message,
|
|
192
|
+
context
|
|
193
|
+
});
|
|
194
|
+
}
|
|
195
|
+
/**
|
|
196
|
+
* Log a timed operation. Wraps an async/sync function with start/end/duration logging.
|
|
197
|
+
* Re-throws the original error on failure.
|
|
198
|
+
*/
|
|
199
|
+
async timed(category, message, fn, context) {
|
|
200
|
+
const start = Date.now();
|
|
201
|
+
this.log({
|
|
202
|
+
level: "info",
|
|
203
|
+
category,
|
|
204
|
+
message,
|
|
205
|
+
outcome: "in_progress",
|
|
206
|
+
context
|
|
207
|
+
});
|
|
208
|
+
try {
|
|
209
|
+
const result = await fn();
|
|
210
|
+
this.log({
|
|
211
|
+
level: "info",
|
|
212
|
+
category,
|
|
213
|
+
message,
|
|
214
|
+
outcome: "success",
|
|
215
|
+
durationMs: Date.now() - start,
|
|
216
|
+
context
|
|
217
|
+
});
|
|
218
|
+
return result;
|
|
219
|
+
} catch (err) {
|
|
220
|
+
this.log({
|
|
221
|
+
level: "error",
|
|
222
|
+
category,
|
|
223
|
+
message,
|
|
224
|
+
outcome: "failure",
|
|
225
|
+
durationMs: Date.now() - start,
|
|
226
|
+
error: err instanceof Error ? {
|
|
227
|
+
name: err.name,
|
|
228
|
+
message: err.message,
|
|
229
|
+
stack: err.stack,
|
|
230
|
+
code: err.code
|
|
231
|
+
} : {
|
|
232
|
+
name: "UnknownError",
|
|
233
|
+
message: String(err)
|
|
234
|
+
},
|
|
235
|
+
context
|
|
236
|
+
});
|
|
237
|
+
throw err;
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
/** Create a step tracker for multi-step operations (deploy, generate pipeline). */
|
|
241
|
+
createStepTracker(category, operationName) {
|
|
242
|
+
return new StepTracker(this, category, operationName);
|
|
243
|
+
}
|
|
244
|
+
/** Flush all sinks. */
|
|
245
|
+
async flush() {
|
|
246
|
+
for (const sink of this.sinks) if (sink.flush) try {
|
|
247
|
+
await sink.flush();
|
|
248
|
+
} catch {}
|
|
249
|
+
}
|
|
250
|
+
/** Destroy all sinks (cleanup timers, close streams). */
|
|
251
|
+
async destroy() {
|
|
252
|
+
for (const sink of this.sinks) if (sink.destroy) try {
|
|
253
|
+
await sink.destroy();
|
|
254
|
+
} catch {}
|
|
255
|
+
}
|
|
256
|
+
getCorrelationId() {
|
|
257
|
+
return this.correlationId;
|
|
258
|
+
}
|
|
259
|
+
getSessionId() {
|
|
260
|
+
return this.sessionId;
|
|
261
|
+
}
|
|
262
|
+
shouldLog(level) {
|
|
263
|
+
return LEVEL_ORDER[level] >= LEVEL_ORDER[this.minLevel];
|
|
264
|
+
}
|
|
265
|
+
};
|
|
266
|
+
//#endregion
|
|
267
|
+
exports.OperationsLogger = OperationsLogger;
|
|
268
|
+
exports.StepTracker = StepTracker;
|
|
269
|
+
|
|
270
|
+
//# sourceMappingURL=logger.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.cjs","names":[],"sources":["../../src/logger/logger.ts"],"sourcesContent":["import { randomUUID } from \"node:crypto\";\nimport type {\n\tLogLevel,\n\tLogSink,\n\tLogSource,\n\tOperationCategory,\n\tOperationOutcome,\n\tOperationStep,\n\tOperationsLogEntry,\n\tOperationsLoggerOptions,\n} from \"./types.js\";\n\n/** Keys that must never appear in logged context. */\nconst SENSITIVE_KEYS = new Set([\n\t\"apikey\",\n\t\"api_key\",\n\t\"password\",\n\t\"token\",\n\t\"secret\",\n\t\"authorization\",\n\t\"credentials\",\n\t\"private_key\",\n\t\"privatekey\",\n]);\n\nconst LEVEL_ORDER: Record<LogLevel, number> = {\n\tdebug: 0,\n\tinfo: 1,\n\twarn: 2,\n\terror: 3,\n};\n\n/** Strip sensitive keys from a context object (shallow). */\nfunction sanitizeContext(\n\tctx: Record<string, unknown> | undefined,\n): Record<string, unknown> | undefined {\n\tif (!ctx) return ctx;\n\tconst clean: Record<string, unknown> = {};\n\tfor (const [key, value] of Object.entries(ctx)) {\n\t\tif (SENSITIVE_KEYS.has(key.toLowerCase())) {\n\t\t\tclean[key] = \"[REDACTED]\";\n\t\t} else {\n\t\t\tclean[key] = value;\n\t\t}\n\t}\n\treturn clean;\n}\n\n/**\n * Tracks individual steps within a multi-step operation (e.g. deploy, generate).\n */\nexport class StepTracker {\n\tprivate steps: OperationStep[] = [];\n\tprivate currentStep: OperationStep | null = null;\n\tprivate readonly operationStart = Date.now();\n\n\tconstructor(\n\t\tprivate readonly logger: OperationsLogger,\n\t\tprivate readonly category: OperationCategory,\n\t\tprivate readonly operationName: string,\n\t) {}\n\n\t/** Start a new step. Automatically completes the previous step if still open. */\n\tbegin(name: string, detail?: string): void {\n\t\tif (this.currentStep && this.currentStep.status === \"in_progress\") {\n\t\t\tthis.currentStep.status = \"success\";\n\t\t\tthis.currentStep.completedAt = new Date().toISOString();\n\t\t\tthis.currentStep.durationMs = Date.now() - new Date(this.currentStep.startedAt).getTime();\n\t\t}\n\t\tthis.currentStep = {\n\t\t\tname,\n\t\t\tstatus: \"in_progress\",\n\t\t\tdetail,\n\t\t\tstartedAt: new Date().toISOString(),\n\t\t};\n\t\tthis.steps.push(this.currentStep);\n\t\tthis.logger.debug(this.category, `[${this.operationName}] ${name}`, {\n\t\t\tstep: name,\n\t\t\tdetail,\n\t\t});\n\t}\n\n\t/** Mark the current step as completed. */\n\tcomplete(detail?: string): void {\n\t\tif (!this.currentStep) return;\n\t\tthis.currentStep.status = \"success\";\n\t\tthis.currentStep.completedAt = new Date().toISOString();\n\t\tthis.currentStep.durationMs = Date.now() - new Date(this.currentStep.startedAt).getTime();\n\t\tif (detail) this.currentStep.detail = detail;\n\t}\n\n\t/** Mark the current step as failed. */\n\tfail(error: string): void {\n\t\tif (!this.currentStep) return;\n\t\tthis.currentStep.status = \"failure\";\n\t\tthis.currentStep.completedAt = new Date().toISOString();\n\t\tthis.currentStep.durationMs = Date.now() - new Date(this.currentStep.startedAt).getTime();\n\t\tthis.currentStep.detail = error;\n\t}\n\n\t/** Record a skipped step. */\n\tskip(name: string, reason?: string): void {\n\t\tthis.steps.push({\n\t\t\tname,\n\t\t\tstatus: \"skipped\",\n\t\t\tdetail: reason,\n\t\t\tstartedAt: new Date().toISOString(),\n\t\t\tcompletedAt: new Date().toISOString(),\n\t\t\tdurationMs: 0,\n\t\t});\n\t}\n\n\t/** Finalize and log the full operation summary. Returns all steps. */\n\tfinalize(outcome: OperationOutcome): OperationStep[] {\n\t\t// Close any open step\n\t\tif (this.currentStep && this.currentStep.status === \"in_progress\") {\n\t\t\tthis.currentStep.status = outcome === \"failure\" ? \"failure\" : \"success\";\n\t\t\tthis.currentStep.completedAt = new Date().toISOString();\n\t\t\tthis.currentStep.durationMs = Date.now() - new Date(this.currentStep.startedAt).getTime();\n\t\t}\n\n\t\tthis.logger.log({\n\t\t\tlevel: outcome === \"failure\" ? \"error\" : \"info\",\n\t\t\tcategory: this.category,\n\t\t\tmessage: `${this.operationName} ${outcome}`,\n\t\t\toutcome,\n\t\t\tdurationMs: Date.now() - this.operationStart,\n\t\t\tsteps: this.steps,\n\t\t});\n\t\treturn this.steps;\n\t}\n\n\t/** Get the current list of steps (snapshot). */\n\tgetSteps(): OperationStep[] {\n\t\treturn [...this.steps];\n\t}\n}\n\n/**\n * Centralized operations logger.\n *\n * Follows fire-and-forget semantics — sink errors are silently caught and\n * logging never blocks or crashes the main flow.\n */\nexport class OperationsLogger {\n\tprivate readonly source: LogSource;\n\tprivate readonly sinks: LogSink[];\n\tprivate readonly correlationId: string;\n\tprivate readonly sessionId: string;\n\tprivate readonly minLevel: LogLevel;\n\n\tconstructor(options: OperationsLoggerOptions) {\n\t\tthis.source = options.source;\n\t\tthis.sinks = options.sinks ?? [];\n\t\tthis.correlationId = options.correlationId ?? randomUUID();\n\t\tthis.sessionId = options.sessionId ?? randomUUID();\n\t\tthis.minLevel = options.minLevel ?? \"info\";\n\t}\n\n\t/** Create a child logger that inherits correlation/session but can override source or sinks. */\n\tchild(overrides: Partial<OperationsLoggerOptions>): OperationsLogger {\n\t\treturn new OperationsLogger({\n\t\t\tsource: overrides.source ?? this.source,\n\t\t\tsinks: overrides.sinks ?? this.sinks,\n\t\t\tcorrelationId: overrides.correlationId ?? this.correlationId,\n\t\t\tsessionId: overrides.sessionId ?? this.sessionId,\n\t\t\tminLevel: overrides.minLevel ?? this.minLevel,\n\t\t});\n\t}\n\n\t/** Log an operation with full context. Fire-and-forget to all sinks. */\n\tlog(\n\t\tentry: Omit<OperationsLogEntry, \"id\" | \"timestamp\" | \"source\" | \"correlationId\" | \"sessionId\">,\n\t): void {\n\t\tif (!this.shouldLog(entry.level)) return;\n\n\t\tconst full: OperationsLogEntry = {\n\t\t\tid: randomUUID(),\n\t\t\ttimestamp: new Date().toISOString(),\n\t\t\tsource: this.source,\n\t\t\tcorrelationId: this.correlationId,\n\t\t\tsessionId: this.sessionId,\n\t\t\t...entry,\n\t\t\tcontext: sanitizeContext(entry.context),\n\t\t};\n\n\t\tfor (const sink of this.sinks) {\n\t\t\ttry {\n\t\t\t\tconst result = sink.write(full);\n\t\t\t\tif (result instanceof Promise) {\n\t\t\t\t\tresult.catch(() => {});\n\t\t\t\t}\n\t\t\t} catch {\n\t\t\t\t// Sink failures must never crash the main flow\n\t\t\t}\n\t\t}\n\t}\n\n\tinfo(category: OperationCategory, message: string, context?: Record<string, unknown>): void {\n\t\tthis.log({ level: \"info\", category, message, context });\n\t}\n\n\twarn(category: OperationCategory, message: string, context?: Record<string, unknown>): void {\n\t\tthis.log({ level: \"warn\", category, message, context });\n\t}\n\n\terror(\n\t\tcategory: OperationCategory,\n\t\tmessage: string,\n\t\terr?: Error | null,\n\t\tcontext?: Record<string, unknown>,\n\t): void {\n\t\tthis.log({\n\t\t\tlevel: \"error\",\n\t\t\tcategory,\n\t\t\tmessage,\n\t\t\tcontext,\n\t\t\terror: err\n\t\t\t\t? {\n\t\t\t\t\t\tname: err.name,\n\t\t\t\t\t\tmessage: err.message,\n\t\t\t\t\t\tstack: err.stack,\n\t\t\t\t\t\tcode: (err as { code?: string }).code,\n\t\t\t\t\t}\n\t\t\t\t: undefined,\n\t\t});\n\t}\n\n\tdebug(category: OperationCategory, message: string, context?: Record<string, unknown>): void {\n\t\tthis.log({ level: \"debug\", category, message, context });\n\t}\n\n\t/**\n\t * Log a timed operation. Wraps an async/sync function with start/end/duration logging.\n\t * Re-throws the original error on failure.\n\t */\n\tasync timed<T>(\n\t\tcategory: OperationCategory,\n\t\tmessage: string,\n\t\tfn: () => T | Promise<T>,\n\t\tcontext?: Record<string, unknown>,\n\t): Promise<T> {\n\t\tconst start = Date.now();\n\t\tthis.log({\n\t\t\tlevel: \"info\",\n\t\t\tcategory,\n\t\t\tmessage,\n\t\t\toutcome: \"in_progress\",\n\t\t\tcontext,\n\t\t});\n\t\ttry {\n\t\t\tconst result = await fn();\n\t\t\tthis.log({\n\t\t\t\tlevel: \"info\",\n\t\t\t\tcategory,\n\t\t\t\tmessage,\n\t\t\t\toutcome: \"success\",\n\t\t\t\tdurationMs: Date.now() - start,\n\t\t\t\tcontext,\n\t\t\t});\n\t\t\treturn result;\n\t\t} catch (err) {\n\t\t\tthis.log({\n\t\t\t\tlevel: \"error\",\n\t\t\t\tcategory,\n\t\t\t\tmessage,\n\t\t\t\toutcome: \"failure\",\n\t\t\t\tdurationMs: Date.now() - start,\n\t\t\t\terror:\n\t\t\t\t\terr instanceof Error\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tname: err.name,\n\t\t\t\t\t\t\t\tmessage: err.message,\n\t\t\t\t\t\t\t\tstack: err.stack,\n\t\t\t\t\t\t\t\tcode: (err as { code?: string }).code,\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: { name: \"UnknownError\", message: String(err) },\n\t\t\t\tcontext,\n\t\t\t});\n\t\t\tthrow err;\n\t\t}\n\t}\n\n\t/** Create a step tracker for multi-step operations (deploy, generate pipeline). */\n\tcreateStepTracker(category: OperationCategory, operationName: string): StepTracker {\n\t\treturn new StepTracker(this, category, operationName);\n\t}\n\n\t/** Flush all sinks. */\n\tasync flush(): Promise<void> {\n\t\tfor (const sink of this.sinks) {\n\t\t\tif (sink.flush) {\n\t\t\t\ttry {\n\t\t\t\t\tawait sink.flush();\n\t\t\t\t} catch {\n\t\t\t\t\t// Silent\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t/** Destroy all sinks (cleanup timers, close streams). */\n\tasync destroy(): Promise<void> {\n\t\tfor (const sink of this.sinks) {\n\t\t\tif (sink.destroy) {\n\t\t\t\ttry {\n\t\t\t\t\tawait sink.destroy();\n\t\t\t\t} catch {\n\t\t\t\t\t// Silent\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\tgetCorrelationId(): string {\n\t\treturn this.correlationId;\n\t}\n\n\tgetSessionId(): string {\n\t\treturn this.sessionId;\n\t}\n\n\tprivate shouldLog(level: LogLevel): boolean {\n\t\treturn LEVEL_ORDER[level] >= LEVEL_ORDER[this.minLevel];\n\t}\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,267 @@
|
|
|
1
|
+
import { randomUUID } from "node:crypto";
|
|
2
|
+
//#region src/logger/logger.ts
|
|
3
|
+
/** Keys that must never appear in logged context. */
|
|
4
|
+
const SENSITIVE_KEYS = new Set([
|
|
5
|
+
"apikey",
|
|
6
|
+
"api_key",
|
|
7
|
+
"password",
|
|
8
|
+
"token",
|
|
9
|
+
"secret",
|
|
10
|
+
"authorization",
|
|
11
|
+
"credentials",
|
|
12
|
+
"private_key",
|
|
13
|
+
"privatekey"
|
|
14
|
+
]);
|
|
15
|
+
const LEVEL_ORDER = {
|
|
16
|
+
debug: 0,
|
|
17
|
+
info: 1,
|
|
18
|
+
warn: 2,
|
|
19
|
+
error: 3
|
|
20
|
+
};
|
|
21
|
+
/** Strip sensitive keys from a context object (shallow). */
|
|
22
|
+
function sanitizeContext(ctx) {
|
|
23
|
+
if (!ctx) return ctx;
|
|
24
|
+
const clean = {};
|
|
25
|
+
for (const [key, value] of Object.entries(ctx)) if (SENSITIVE_KEYS.has(key.toLowerCase())) clean[key] = "[REDACTED]";
|
|
26
|
+
else clean[key] = value;
|
|
27
|
+
return clean;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Tracks individual steps within a multi-step operation (e.g. deploy, generate).
|
|
31
|
+
*/
|
|
32
|
+
var StepTracker = class {
|
|
33
|
+
steps = [];
|
|
34
|
+
currentStep = null;
|
|
35
|
+
operationStart = Date.now();
|
|
36
|
+
constructor(logger, category, operationName) {
|
|
37
|
+
this.logger = logger;
|
|
38
|
+
this.category = category;
|
|
39
|
+
this.operationName = operationName;
|
|
40
|
+
}
|
|
41
|
+
/** Start a new step. Automatically completes the previous step if still open. */
|
|
42
|
+
begin(name, detail) {
|
|
43
|
+
if (this.currentStep && this.currentStep.status === "in_progress") {
|
|
44
|
+
this.currentStep.status = "success";
|
|
45
|
+
this.currentStep.completedAt = (/* @__PURE__ */ new Date()).toISOString();
|
|
46
|
+
this.currentStep.durationMs = Date.now() - new Date(this.currentStep.startedAt).getTime();
|
|
47
|
+
}
|
|
48
|
+
this.currentStep = {
|
|
49
|
+
name,
|
|
50
|
+
status: "in_progress",
|
|
51
|
+
detail,
|
|
52
|
+
startedAt: (/* @__PURE__ */ new Date()).toISOString()
|
|
53
|
+
};
|
|
54
|
+
this.steps.push(this.currentStep);
|
|
55
|
+
this.logger.debug(this.category, `[${this.operationName}] ${name}`, {
|
|
56
|
+
step: name,
|
|
57
|
+
detail
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
/** Mark the current step as completed. */
|
|
61
|
+
complete(detail) {
|
|
62
|
+
if (!this.currentStep) return;
|
|
63
|
+
this.currentStep.status = "success";
|
|
64
|
+
this.currentStep.completedAt = (/* @__PURE__ */ new Date()).toISOString();
|
|
65
|
+
this.currentStep.durationMs = Date.now() - new Date(this.currentStep.startedAt).getTime();
|
|
66
|
+
if (detail) this.currentStep.detail = detail;
|
|
67
|
+
}
|
|
68
|
+
/** Mark the current step as failed. */
|
|
69
|
+
fail(error) {
|
|
70
|
+
if (!this.currentStep) return;
|
|
71
|
+
this.currentStep.status = "failure";
|
|
72
|
+
this.currentStep.completedAt = (/* @__PURE__ */ new Date()).toISOString();
|
|
73
|
+
this.currentStep.durationMs = Date.now() - new Date(this.currentStep.startedAt).getTime();
|
|
74
|
+
this.currentStep.detail = error;
|
|
75
|
+
}
|
|
76
|
+
/** Record a skipped step. */
|
|
77
|
+
skip(name, reason) {
|
|
78
|
+
this.steps.push({
|
|
79
|
+
name,
|
|
80
|
+
status: "skipped",
|
|
81
|
+
detail: reason,
|
|
82
|
+
startedAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
83
|
+
completedAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
84
|
+
durationMs: 0
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
/** Finalize and log the full operation summary. Returns all steps. */
|
|
88
|
+
finalize(outcome) {
|
|
89
|
+
if (this.currentStep && this.currentStep.status === "in_progress") {
|
|
90
|
+
this.currentStep.status = outcome === "failure" ? "failure" : "success";
|
|
91
|
+
this.currentStep.completedAt = (/* @__PURE__ */ new Date()).toISOString();
|
|
92
|
+
this.currentStep.durationMs = Date.now() - new Date(this.currentStep.startedAt).getTime();
|
|
93
|
+
}
|
|
94
|
+
this.logger.log({
|
|
95
|
+
level: outcome === "failure" ? "error" : "info",
|
|
96
|
+
category: this.category,
|
|
97
|
+
message: `${this.operationName} ${outcome}`,
|
|
98
|
+
outcome,
|
|
99
|
+
durationMs: Date.now() - this.operationStart,
|
|
100
|
+
steps: this.steps
|
|
101
|
+
});
|
|
102
|
+
return this.steps;
|
|
103
|
+
}
|
|
104
|
+
/** Get the current list of steps (snapshot). */
|
|
105
|
+
getSteps() {
|
|
106
|
+
return [...this.steps];
|
|
107
|
+
}
|
|
108
|
+
};
|
|
109
|
+
/**
|
|
110
|
+
* Centralized operations logger.
|
|
111
|
+
*
|
|
112
|
+
* Follows fire-and-forget semantics — sink errors are silently caught and
|
|
113
|
+
* logging never blocks or crashes the main flow.
|
|
114
|
+
*/
|
|
115
|
+
var OperationsLogger = class OperationsLogger {
|
|
116
|
+
source;
|
|
117
|
+
sinks;
|
|
118
|
+
correlationId;
|
|
119
|
+
sessionId;
|
|
120
|
+
minLevel;
|
|
121
|
+
constructor(options) {
|
|
122
|
+
this.source = options.source;
|
|
123
|
+
this.sinks = options.sinks ?? [];
|
|
124
|
+
this.correlationId = options.correlationId ?? randomUUID();
|
|
125
|
+
this.sessionId = options.sessionId ?? randomUUID();
|
|
126
|
+
this.minLevel = options.minLevel ?? "info";
|
|
127
|
+
}
|
|
128
|
+
/** Create a child logger that inherits correlation/session but can override source or sinks. */
|
|
129
|
+
child(overrides) {
|
|
130
|
+
return new OperationsLogger({
|
|
131
|
+
source: overrides.source ?? this.source,
|
|
132
|
+
sinks: overrides.sinks ?? this.sinks,
|
|
133
|
+
correlationId: overrides.correlationId ?? this.correlationId,
|
|
134
|
+
sessionId: overrides.sessionId ?? this.sessionId,
|
|
135
|
+
minLevel: overrides.minLevel ?? this.minLevel
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
/** Log an operation with full context. Fire-and-forget to all sinks. */
|
|
139
|
+
log(entry) {
|
|
140
|
+
if (!this.shouldLog(entry.level)) return;
|
|
141
|
+
const full = {
|
|
142
|
+
id: randomUUID(),
|
|
143
|
+
timestamp: (/* @__PURE__ */ new Date()).toISOString(),
|
|
144
|
+
source: this.source,
|
|
145
|
+
correlationId: this.correlationId,
|
|
146
|
+
sessionId: this.sessionId,
|
|
147
|
+
...entry,
|
|
148
|
+
context: sanitizeContext(entry.context)
|
|
149
|
+
};
|
|
150
|
+
for (const sink of this.sinks) try {
|
|
151
|
+
const result = sink.write(full);
|
|
152
|
+
if (result instanceof Promise) result.catch(() => {});
|
|
153
|
+
} catch {}
|
|
154
|
+
}
|
|
155
|
+
info(category, message, context) {
|
|
156
|
+
this.log({
|
|
157
|
+
level: "info",
|
|
158
|
+
category,
|
|
159
|
+
message,
|
|
160
|
+
context
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
warn(category, message, context) {
|
|
164
|
+
this.log({
|
|
165
|
+
level: "warn",
|
|
166
|
+
category,
|
|
167
|
+
message,
|
|
168
|
+
context
|
|
169
|
+
});
|
|
170
|
+
}
|
|
171
|
+
error(category, message, err, context) {
|
|
172
|
+
this.log({
|
|
173
|
+
level: "error",
|
|
174
|
+
category,
|
|
175
|
+
message,
|
|
176
|
+
context,
|
|
177
|
+
error: err ? {
|
|
178
|
+
name: err.name,
|
|
179
|
+
message: err.message,
|
|
180
|
+
stack: err.stack,
|
|
181
|
+
code: err.code
|
|
182
|
+
} : void 0
|
|
183
|
+
});
|
|
184
|
+
}
|
|
185
|
+
debug(category, message, context) {
|
|
186
|
+
this.log({
|
|
187
|
+
level: "debug",
|
|
188
|
+
category,
|
|
189
|
+
message,
|
|
190
|
+
context
|
|
191
|
+
});
|
|
192
|
+
}
|
|
193
|
+
/**
|
|
194
|
+
* Log a timed operation. Wraps an async/sync function with start/end/duration logging.
|
|
195
|
+
* Re-throws the original error on failure.
|
|
196
|
+
*/
|
|
197
|
+
async timed(category, message, fn, context) {
|
|
198
|
+
const start = Date.now();
|
|
199
|
+
this.log({
|
|
200
|
+
level: "info",
|
|
201
|
+
category,
|
|
202
|
+
message,
|
|
203
|
+
outcome: "in_progress",
|
|
204
|
+
context
|
|
205
|
+
});
|
|
206
|
+
try {
|
|
207
|
+
const result = await fn();
|
|
208
|
+
this.log({
|
|
209
|
+
level: "info",
|
|
210
|
+
category,
|
|
211
|
+
message,
|
|
212
|
+
outcome: "success",
|
|
213
|
+
durationMs: Date.now() - start,
|
|
214
|
+
context
|
|
215
|
+
});
|
|
216
|
+
return result;
|
|
217
|
+
} catch (err) {
|
|
218
|
+
this.log({
|
|
219
|
+
level: "error",
|
|
220
|
+
category,
|
|
221
|
+
message,
|
|
222
|
+
outcome: "failure",
|
|
223
|
+
durationMs: Date.now() - start,
|
|
224
|
+
error: err instanceof Error ? {
|
|
225
|
+
name: err.name,
|
|
226
|
+
message: err.message,
|
|
227
|
+
stack: err.stack,
|
|
228
|
+
code: err.code
|
|
229
|
+
} : {
|
|
230
|
+
name: "UnknownError",
|
|
231
|
+
message: String(err)
|
|
232
|
+
},
|
|
233
|
+
context
|
|
234
|
+
});
|
|
235
|
+
throw err;
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
/** Create a step tracker for multi-step operations (deploy, generate pipeline). */
|
|
239
|
+
createStepTracker(category, operationName) {
|
|
240
|
+
return new StepTracker(this, category, operationName);
|
|
241
|
+
}
|
|
242
|
+
/** Flush all sinks. */
|
|
243
|
+
async flush() {
|
|
244
|
+
for (const sink of this.sinks) if (sink.flush) try {
|
|
245
|
+
await sink.flush();
|
|
246
|
+
} catch {}
|
|
247
|
+
}
|
|
248
|
+
/** Destroy all sinks (cleanup timers, close streams). */
|
|
249
|
+
async destroy() {
|
|
250
|
+
for (const sink of this.sinks) if (sink.destroy) try {
|
|
251
|
+
await sink.destroy();
|
|
252
|
+
} catch {}
|
|
253
|
+
}
|
|
254
|
+
getCorrelationId() {
|
|
255
|
+
return this.correlationId;
|
|
256
|
+
}
|
|
257
|
+
getSessionId() {
|
|
258
|
+
return this.sessionId;
|
|
259
|
+
}
|
|
260
|
+
shouldLog(level) {
|
|
261
|
+
return LEVEL_ORDER[level] >= LEVEL_ORDER[this.minLevel];
|
|
262
|
+
}
|
|
263
|
+
};
|
|
264
|
+
//#endregion
|
|
265
|
+
export { OperationsLogger, StepTracker };
|
|
266
|
+
|
|
267
|
+
//# sourceMappingURL=logger.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.mjs","names":[],"sources":["../../src/logger/logger.ts"],"sourcesContent":["import { randomUUID } from \"node:crypto\";\nimport type {\n\tLogLevel,\n\tLogSink,\n\tLogSource,\n\tOperationCategory,\n\tOperationOutcome,\n\tOperationStep,\n\tOperationsLogEntry,\n\tOperationsLoggerOptions,\n} from \"./types.js\";\n\n/** Keys that must never appear in logged context. */\nconst SENSITIVE_KEYS = new Set([\n\t\"apikey\",\n\t\"api_key\",\n\t\"password\",\n\t\"token\",\n\t\"secret\",\n\t\"authorization\",\n\t\"credentials\",\n\t\"private_key\",\n\t\"privatekey\",\n]);\n\nconst LEVEL_ORDER: Record<LogLevel, number> = {\n\tdebug: 0,\n\tinfo: 1,\n\twarn: 2,\n\terror: 3,\n};\n\n/** Strip sensitive keys from a context object (shallow). */\nfunction sanitizeContext(\n\tctx: Record<string, unknown> | undefined,\n): Record<string, unknown> | undefined {\n\tif (!ctx) return ctx;\n\tconst clean: Record<string, unknown> = {};\n\tfor (const [key, value] of Object.entries(ctx)) {\n\t\tif (SENSITIVE_KEYS.has(key.toLowerCase())) {\n\t\t\tclean[key] = \"[REDACTED]\";\n\t\t} else {\n\t\t\tclean[key] = value;\n\t\t}\n\t}\n\treturn clean;\n}\n\n/**\n * Tracks individual steps within a multi-step operation (e.g. deploy, generate).\n */\nexport class StepTracker {\n\tprivate steps: OperationStep[] = [];\n\tprivate currentStep: OperationStep | null = null;\n\tprivate readonly operationStart = Date.now();\n\n\tconstructor(\n\t\tprivate readonly logger: OperationsLogger,\n\t\tprivate readonly category: OperationCategory,\n\t\tprivate readonly operationName: string,\n\t) {}\n\n\t/** Start a new step. Automatically completes the previous step if still open. */\n\tbegin(name: string, detail?: string): void {\n\t\tif (this.currentStep && this.currentStep.status === \"in_progress\") {\n\t\t\tthis.currentStep.status = \"success\";\n\t\t\tthis.currentStep.completedAt = new Date().toISOString();\n\t\t\tthis.currentStep.durationMs = Date.now() - new Date(this.currentStep.startedAt).getTime();\n\t\t}\n\t\tthis.currentStep = {\n\t\t\tname,\n\t\t\tstatus: \"in_progress\",\n\t\t\tdetail,\n\t\t\tstartedAt: new Date().toISOString(),\n\t\t};\n\t\tthis.steps.push(this.currentStep);\n\t\tthis.logger.debug(this.category, `[${this.operationName}] ${name}`, {\n\t\t\tstep: name,\n\t\t\tdetail,\n\t\t});\n\t}\n\n\t/** Mark the current step as completed. */\n\tcomplete(detail?: string): void {\n\t\tif (!this.currentStep) return;\n\t\tthis.currentStep.status = \"success\";\n\t\tthis.currentStep.completedAt = new Date().toISOString();\n\t\tthis.currentStep.durationMs = Date.now() - new Date(this.currentStep.startedAt).getTime();\n\t\tif (detail) this.currentStep.detail = detail;\n\t}\n\n\t/** Mark the current step as failed. */\n\tfail(error: string): void {\n\t\tif (!this.currentStep) return;\n\t\tthis.currentStep.status = \"failure\";\n\t\tthis.currentStep.completedAt = new Date().toISOString();\n\t\tthis.currentStep.durationMs = Date.now() - new Date(this.currentStep.startedAt).getTime();\n\t\tthis.currentStep.detail = error;\n\t}\n\n\t/** Record a skipped step. */\n\tskip(name: string, reason?: string): void {\n\t\tthis.steps.push({\n\t\t\tname,\n\t\t\tstatus: \"skipped\",\n\t\t\tdetail: reason,\n\t\t\tstartedAt: new Date().toISOString(),\n\t\t\tcompletedAt: new Date().toISOString(),\n\t\t\tdurationMs: 0,\n\t\t});\n\t}\n\n\t/** Finalize and log the full operation summary. Returns all steps. */\n\tfinalize(outcome: OperationOutcome): OperationStep[] {\n\t\t// Close any open step\n\t\tif (this.currentStep && this.currentStep.status === \"in_progress\") {\n\t\t\tthis.currentStep.status = outcome === \"failure\" ? \"failure\" : \"success\";\n\t\t\tthis.currentStep.completedAt = new Date().toISOString();\n\t\t\tthis.currentStep.durationMs = Date.now() - new Date(this.currentStep.startedAt).getTime();\n\t\t}\n\n\t\tthis.logger.log({\n\t\t\tlevel: outcome === \"failure\" ? \"error\" : \"info\",\n\t\t\tcategory: this.category,\n\t\t\tmessage: `${this.operationName} ${outcome}`,\n\t\t\toutcome,\n\t\t\tdurationMs: Date.now() - this.operationStart,\n\t\t\tsteps: this.steps,\n\t\t});\n\t\treturn this.steps;\n\t}\n\n\t/** Get the current list of steps (snapshot). */\n\tgetSteps(): OperationStep[] {\n\t\treturn [...this.steps];\n\t}\n}\n\n/**\n * Centralized operations logger.\n *\n * Follows fire-and-forget semantics — sink errors are silently caught and\n * logging never blocks or crashes the main flow.\n */\nexport class OperationsLogger {\n\tprivate readonly source: LogSource;\n\tprivate readonly sinks: LogSink[];\n\tprivate readonly correlationId: string;\n\tprivate readonly sessionId: string;\n\tprivate readonly minLevel: LogLevel;\n\n\tconstructor(options: OperationsLoggerOptions) {\n\t\tthis.source = options.source;\n\t\tthis.sinks = options.sinks ?? [];\n\t\tthis.correlationId = options.correlationId ?? randomUUID();\n\t\tthis.sessionId = options.sessionId ?? randomUUID();\n\t\tthis.minLevel = options.minLevel ?? \"info\";\n\t}\n\n\t/** Create a child logger that inherits correlation/session but can override source or sinks. */\n\tchild(overrides: Partial<OperationsLoggerOptions>): OperationsLogger {\n\t\treturn new OperationsLogger({\n\t\t\tsource: overrides.source ?? this.source,\n\t\t\tsinks: overrides.sinks ?? this.sinks,\n\t\t\tcorrelationId: overrides.correlationId ?? this.correlationId,\n\t\t\tsessionId: overrides.sessionId ?? this.sessionId,\n\t\t\tminLevel: overrides.minLevel ?? this.minLevel,\n\t\t});\n\t}\n\n\t/** Log an operation with full context. Fire-and-forget to all sinks. */\n\tlog(\n\t\tentry: Omit<OperationsLogEntry, \"id\" | \"timestamp\" | \"source\" | \"correlationId\" | \"sessionId\">,\n\t): void {\n\t\tif (!this.shouldLog(entry.level)) return;\n\n\t\tconst full: OperationsLogEntry = {\n\t\t\tid: randomUUID(),\n\t\t\ttimestamp: new Date().toISOString(),\n\t\t\tsource: this.source,\n\t\t\tcorrelationId: this.correlationId,\n\t\t\tsessionId: this.sessionId,\n\t\t\t...entry,\n\t\t\tcontext: sanitizeContext(entry.context),\n\t\t};\n\n\t\tfor (const sink of this.sinks) {\n\t\t\ttry {\n\t\t\t\tconst result = sink.write(full);\n\t\t\t\tif (result instanceof Promise) {\n\t\t\t\t\tresult.catch(() => {});\n\t\t\t\t}\n\t\t\t} catch {\n\t\t\t\t// Sink failures must never crash the main flow\n\t\t\t}\n\t\t}\n\t}\n\n\tinfo(category: OperationCategory, message: string, context?: Record<string, unknown>): void {\n\t\tthis.log({ level: \"info\", category, message, context });\n\t}\n\n\twarn(category: OperationCategory, message: string, context?: Record<string, unknown>): void {\n\t\tthis.log({ level: \"warn\", category, message, context });\n\t}\n\n\terror(\n\t\tcategory: OperationCategory,\n\t\tmessage: string,\n\t\terr?: Error | null,\n\t\tcontext?: Record<string, unknown>,\n\t): void {\n\t\tthis.log({\n\t\t\tlevel: \"error\",\n\t\t\tcategory,\n\t\t\tmessage,\n\t\t\tcontext,\n\t\t\terror: err\n\t\t\t\t? {\n\t\t\t\t\t\tname: err.name,\n\t\t\t\t\t\tmessage: err.message,\n\t\t\t\t\t\tstack: err.stack,\n\t\t\t\t\t\tcode: (err as { code?: string }).code,\n\t\t\t\t\t}\n\t\t\t\t: undefined,\n\t\t});\n\t}\n\n\tdebug(category: OperationCategory, message: string, context?: Record<string, unknown>): void {\n\t\tthis.log({ level: \"debug\", category, message, context });\n\t}\n\n\t/**\n\t * Log a timed operation. Wraps an async/sync function with start/end/duration logging.\n\t * Re-throws the original error on failure.\n\t */\n\tasync timed<T>(\n\t\tcategory: OperationCategory,\n\t\tmessage: string,\n\t\tfn: () => T | Promise<T>,\n\t\tcontext?: Record<string, unknown>,\n\t): Promise<T> {\n\t\tconst start = Date.now();\n\t\tthis.log({\n\t\t\tlevel: \"info\",\n\t\t\tcategory,\n\t\t\tmessage,\n\t\t\toutcome: \"in_progress\",\n\t\t\tcontext,\n\t\t});\n\t\ttry {\n\t\t\tconst result = await fn();\n\t\t\tthis.log({\n\t\t\t\tlevel: \"info\",\n\t\t\t\tcategory,\n\t\t\t\tmessage,\n\t\t\t\toutcome: \"success\",\n\t\t\t\tdurationMs: Date.now() - start,\n\t\t\t\tcontext,\n\t\t\t});\n\t\t\treturn result;\n\t\t} catch (err) {\n\t\t\tthis.log({\n\t\t\t\tlevel: \"error\",\n\t\t\t\tcategory,\n\t\t\t\tmessage,\n\t\t\t\toutcome: \"failure\",\n\t\t\t\tdurationMs: Date.now() - start,\n\t\t\t\terror:\n\t\t\t\t\terr instanceof Error\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tname: err.name,\n\t\t\t\t\t\t\t\tmessage: err.message,\n\t\t\t\t\t\t\t\tstack: err.stack,\n\t\t\t\t\t\t\t\tcode: (err as { code?: string }).code,\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: { name: \"UnknownError\", message: String(err) },\n\t\t\t\tcontext,\n\t\t\t});\n\t\t\tthrow err;\n\t\t}\n\t}\n\n\t/** Create a step tracker for multi-step operations (deploy, generate pipeline). */\n\tcreateStepTracker(category: OperationCategory, operationName: string): StepTracker {\n\t\treturn new StepTracker(this, category, operationName);\n\t}\n\n\t/** Flush all sinks. */\n\tasync flush(): Promise<void> {\n\t\tfor (const sink of this.sinks) {\n\t\t\tif (sink.flush) {\n\t\t\t\ttry {\n\t\t\t\t\tawait sink.flush();\n\t\t\t\t} catch {\n\t\t\t\t\t// Silent\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t/** Destroy all sinks (cleanup timers, close streams). */\n\tasync destroy(): Promise<void> {\n\t\tfor (const sink of this.sinks) {\n\t\t\tif (sink.destroy) {\n\t\t\t\ttry {\n\t\t\t\t\tawait sink.destroy();\n\t\t\t\t} catch {\n\t\t\t\t\t// Silent\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\tgetCorrelationId(): string {\n\t\treturn this.correlationId;\n\t}\n\n\tgetSessionId(): string {\n\t\treturn this.sessionId;\n\t}\n\n\tprivate shouldLog(level: LogLevel): boolean {\n\t\treturn LEVEL_ORDER[level] >= LEVEL_ORDER[this.minLevel];\n\t}\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
2
|
+
//#region src/logger/sinks/callback-sink.ts
|
|
3
|
+
/**
|
|
4
|
+
* Callback sink — delegates to a user-provided function.
|
|
5
|
+
* Useful for tests, Sentry breadcrumbs, WebSocket streaming, etc.
|
|
6
|
+
*/
|
|
7
|
+
var CallbackSink = class {
|
|
8
|
+
constructor(onEntry) {
|
|
9
|
+
this.onEntry = onEntry;
|
|
10
|
+
}
|
|
11
|
+
write(entry) {
|
|
12
|
+
return this.onEntry(entry);
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
//#endregion
|
|
16
|
+
exports.CallbackSink = CallbackSink;
|
|
17
|
+
|
|
18
|
+
//# sourceMappingURL=callback-sink.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"callback-sink.cjs","names":[],"sources":["../../../src/logger/sinks/callback-sink.ts"],"sourcesContent":["import type { LogSink, OperationsLogEntry } from \"../types.js\";\n\n/**\n * Callback sink — delegates to a user-provided function.\n * Useful for tests, Sentry breadcrumbs, WebSocket streaming, etc.\n */\nexport class CallbackSink implements LogSink {\n\tconstructor(private readonly onEntry: (entry: OperationsLogEntry) => void | Promise<void>) {}\n\n\twrite(entry: OperationsLogEntry): void | Promise<void> {\n\t\treturn this.onEntry(entry);\n\t}\n}\n"],"mappings":";;;;;;AAMA,IAAa,eAAb,MAA6C;CAC5C,YAAY,SAA+E;AAA9D,OAAA,UAAA;;CAE7B,MAAM,OAAiD;AACtD,SAAO,KAAK,QAAQ,MAAM"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
//#region src/logger/sinks/callback-sink.ts
|
|
2
|
+
/**
|
|
3
|
+
* Callback sink — delegates to a user-provided function.
|
|
4
|
+
* Useful for tests, Sentry breadcrumbs, WebSocket streaming, etc.
|
|
5
|
+
*/
|
|
6
|
+
var CallbackSink = class {
|
|
7
|
+
constructor(onEntry) {
|
|
8
|
+
this.onEntry = onEntry;
|
|
9
|
+
}
|
|
10
|
+
write(entry) {
|
|
11
|
+
return this.onEntry(entry);
|
|
12
|
+
}
|
|
13
|
+
};
|
|
14
|
+
//#endregion
|
|
15
|
+
export { CallbackSink };
|
|
16
|
+
|
|
17
|
+
//# sourceMappingURL=callback-sink.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"callback-sink.mjs","names":[],"sources":["../../../src/logger/sinks/callback-sink.ts"],"sourcesContent":["import type { LogSink, OperationsLogEntry } from \"../types.js\";\n\n/**\n * Callback sink — delegates to a user-provided function.\n * Useful for tests, Sentry breadcrumbs, WebSocket streaming, etc.\n */\nexport class CallbackSink implements LogSink {\n\tconstructor(private readonly onEntry: (entry: OperationsLogEntry) => void | Promise<void>) {}\n\n\twrite(entry: OperationsLogEntry): void | Promise<void> {\n\t\treturn this.onEntry(entry);\n\t}\n}\n"],"mappings":";;;;;AAMA,IAAa,eAAb,MAA6C;CAC5C,YAAY,SAA+E;AAA9D,OAAA,UAAA;;CAE7B,MAAM,OAAiD;AACtD,SAAO,KAAK,QAAQ,MAAM"}
|