@better-openclaw/core 1.0.6 → 1.0.7
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/.github/workflows/publish-core.yml +1 -1
- package/dist/bare-metal-partition.d.mts +0 -1
- package/dist/bare-metal-partition.d.mts.map +1 -1
- package/dist/bare-metal-partition.mjs +47 -2
- package/dist/bare-metal-partition.mjs.map +1 -0
- package/dist/bare-metal-partition.test.mjs +3 -3
- package/dist/composer.d.mts +0 -1
- package/dist/composer.d.mts.map +1 -1
- package/dist/composer.mjs +286 -2
- package/dist/composer.mjs.map +1 -0
- package/dist/composer.snapshot.test.mjs +3 -3
- package/dist/composer.test.mjs +3 -3
- package/dist/generate.d.mts +0 -2
- package/dist/generate.d.mts.map +1 -1
- package/dist/generate.mjs +15 -15
- package/dist/generate.test.mjs +1 -1
- package/dist/generators/bare-metal-install.d.mts +0 -2
- package/dist/generators/bare-metal-install.d.mts.map +1 -1
- package/dist/generators/bare-metal-install.mjs +223 -2
- package/dist/generators/bare-metal-install.mjs.map +1 -0
- package/dist/generators/bare-metal-install.test.mjs +2 -2
- package/dist/generators/caddy.d.mts +0 -2
- package/dist/generators/caddy.d.mts.map +1 -1
- package/dist/generators/caddy.mjs +76 -2
- package/dist/generators/caddy.mjs.map +1 -0
- package/dist/generators/env.d.mts +0 -1
- package/dist/generators/env.d.mts.map +1 -1
- package/dist/generators/env.mjs +249 -2
- package/dist/generators/env.mjs.map +1 -0
- package/dist/generators/grafana.d.mts.map +1 -1
- package/dist/generators/grafana.mjs +292 -2
- package/dist/generators/grafana.mjs.map +1 -0
- package/dist/generators/n8n-workflows.d.mts +0 -2
- package/dist/generators/n8n-workflows.d.mts.map +1 -1
- package/dist/generators/n8n-workflows.mjs +74 -2
- package/dist/generators/n8n-workflows.mjs.map +1 -0
- package/dist/generators/native-services.d.mts +0 -1
- package/dist/generators/native-services.d.mts.map +1 -1
- package/dist/generators/native-services.mjs +77 -2
- package/dist/generators/native-services.mjs.map +1 -0
- package/dist/generators/postgres-init.d.mts +0 -1
- package/dist/generators/postgres-init.d.mts.map +1 -1
- package/dist/generators/postgres-init.mjs +150 -2
- package/dist/generators/postgres-init.mjs.map +1 -0
- package/dist/generators/prometheus.d.mts +0 -2
- package/dist/generators/prometheus.d.mts.map +1 -1
- package/dist/generators/prometheus.mjs +106 -2
- package/dist/generators/prometheus.mjs.map +1 -0
- package/dist/generators/readme.d.mts +0 -1
- package/dist/generators/readme.d.mts.map +1 -1
- package/dist/generators/readme.mjs +198 -2
- package/dist/generators/readme.mjs.map +1 -0
- package/dist/generators/scripts.d.mts.map +1 -1
- package/dist/generators/scripts.mjs +350 -2
- package/dist/generators/scripts.mjs.map +1 -0
- package/dist/generators/skills.d.mts +0 -2
- package/dist/generators/skills.d.mts.map +1 -1
- package/dist/generators/skills.mjs +586 -2
- package/dist/generators/skills.mjs.map +1 -0
- package/dist/index.d.mts +1 -1
- package/dist/index.mjs +15 -15
- package/dist/{magic-string.es-Dew0Rnsa.mjs → magic-string.es-1uTtupLe.mjs} +14 -14
- package/dist/magic-string.es-1uTtupLe.mjs.map +1 -0
- package/dist/presets/registry.d.mts +0 -1
- package/dist/presets/registry.d.mts.map +1 -1
- package/dist/presets/registry.test.mjs +1 -1
- package/dist/resolver.d.mts +0 -2
- package/dist/resolver.d.mts.map +1 -1
- package/dist/resolver.mjs +193 -2
- package/dist/resolver.mjs.map +1 -0
- package/dist/resolver.test.mjs +2 -2
- package/dist/schema.d.mts +706 -2
- package/dist/schema.d.mts.map +1 -0
- package/dist/schema.mjs +3 -1
- package/dist/schema.mjs.map +1 -1
- package/dist/schema.test.mjs +1 -1
- package/dist/services/definitions/anything-llm.d.mts +0 -1
- package/dist/services/definitions/anything-llm.d.mts.map +1 -1
- package/dist/services/definitions/anything-llm.mjs +43 -2
- package/dist/services/definitions/anything-llm.mjs.map +1 -0
- package/dist/services/definitions/appflowy.d.mts +0 -1
- package/dist/services/definitions/appflowy.d.mts.map +1 -1
- package/dist/services/definitions/appflowy.mjs +44 -2
- package/dist/services/definitions/appflowy.mjs.map +1 -0
- package/dist/services/definitions/beszel.d.mts +0 -1
- package/dist/services/definitions/beszel.d.mts.map +1 -1
- package/dist/services/definitions/beszel.mjs +44 -2
- package/dist/services/definitions/beszel.mjs.map +1 -0
- package/dist/services/definitions/browserless.d.mts +0 -1
- package/dist/services/definitions/browserless.d.mts.map +1 -1
- package/dist/services/definitions/browserless.mjs +84 -2
- package/dist/services/definitions/browserless.mjs.map +1 -0
- package/dist/services/definitions/caddy.d.mts +0 -1
- package/dist/services/definitions/caddy.d.mts.map +1 -1
- package/dist/services/definitions/caddy.mjs +51 -2
- package/dist/services/definitions/caddy.mjs.map +1 -0
- package/dist/services/definitions/chromadb.d.mts +0 -1
- package/dist/services/definitions/chromadb.d.mts.map +1 -1
- package/dist/services/definitions/chromadb.mjs +62 -2
- package/dist/services/definitions/chromadb.mjs.map +1 -0
- package/dist/services/definitions/claude-code.d.mts +0 -1
- package/dist/services/definitions/claude-code.d.mts.map +1 -1
- package/dist/services/definitions/claude-code.mjs +51 -2
- package/dist/services/definitions/claude-code.mjs.map +1 -0
- package/dist/services/definitions/code-server.d.mts +0 -1
- package/dist/services/definitions/code-server.d.mts.map +1 -1
- package/dist/services/definitions/code-server.mjs +65 -2
- package/dist/services/definitions/code-server.mjs.map +1 -0
- package/dist/services/definitions/codex.d.mts +0 -1
- package/dist/services/definitions/codex.d.mts.map +1 -1
- package/dist/services/definitions/codex.mjs +44 -2
- package/dist/services/definitions/codex.mjs.map +1 -0
- package/dist/services/definitions/convex-dashboard.d.mts +7 -0
- package/dist/services/definitions/convex-dashboard.d.mts.map +1 -0
- package/dist/services/definitions/convex-dashboard.mjs +46 -0
- package/dist/services/definitions/convex-dashboard.mjs.map +1 -0
- package/dist/services/definitions/convex.d.mts +7 -0
- package/dist/services/definitions/convex.d.mts.map +1 -0
- package/dist/services/definitions/convex.mjs +118 -0
- package/dist/services/definitions/convex.mjs.map +1 -0
- package/dist/services/definitions/coolify.d.mts +0 -1
- package/dist/services/definitions/coolify.d.mts.map +1 -1
- package/dist/services/definitions/coolify.mjs +48 -2
- package/dist/services/definitions/coolify.mjs.map +1 -0
- package/dist/services/definitions/dify.d.mts +0 -1
- package/dist/services/definitions/dify.d.mts.map +1 -1
- package/dist/services/definitions/dify.mjs +80 -2
- package/dist/services/definitions/dify.mjs.map +1 -0
- package/dist/services/definitions/docsgpt.d.mts +0 -1
- package/dist/services/definitions/docsgpt.d.mts.map +1 -1
- package/dist/services/definitions/docsgpt.mjs +44 -2
- package/dist/services/definitions/docsgpt.mjs.map +1 -0
- package/dist/services/definitions/dokploy.d.mts +0 -1
- package/dist/services/definitions/dokploy.d.mts.map +1 -1
- package/dist/services/definitions/dokploy.mjs +48 -2
- package/dist/services/definitions/dokploy.mjs.map +1 -0
- package/dist/services/definitions/dozzle.d.mts +0 -1
- package/dist/services/definitions/dozzle.d.mts.map +1 -1
- package/dist/services/definitions/dozzle.mjs +40 -2
- package/dist/services/definitions/dozzle.mjs.map +1 -0
- package/dist/services/definitions/ffmpeg.d.mts +0 -1
- package/dist/services/definitions/ffmpeg.d.mts.map +1 -1
- package/dist/services/definitions/ffmpeg.mjs +65 -2
- package/dist/services/definitions/ffmpeg.mjs.map +1 -0
- package/dist/services/definitions/flowise.d.mts +0 -1
- package/dist/services/definitions/flowise.d.mts.map +1 -1
- package/dist/services/definitions/flowise.mjs +44 -2
- package/dist/services/definitions/flowise.mjs.map +1 -0
- package/dist/services/definitions/gemini-cli.d.mts +0 -1
- package/dist/services/definitions/gemini-cli.d.mts.map +1 -1
- package/dist/services/definitions/gemini-cli.mjs +45 -2
- package/dist/services/definitions/gemini-cli.mjs.map +1 -0
- package/dist/services/definitions/gitea.d.mts +0 -1
- package/dist/services/definitions/gitea.d.mts.map +1 -1
- package/dist/services/definitions/gitea.mjs +48 -2
- package/dist/services/definitions/gitea.mjs.map +1 -0
- package/dist/services/definitions/gotify.d.mts +0 -1
- package/dist/services/definitions/gotify.d.mts.map +1 -1
- package/dist/services/definitions/gotify.mjs +61 -2
- package/dist/services/definitions/gotify.mjs.map +1 -0
- package/dist/services/definitions/grafana.d.mts +0 -1
- package/dist/services/definitions/grafana.d.mts.map +1 -1
- package/dist/services/definitions/grafana.mjs +62 -2
- package/dist/services/definitions/grafana.mjs.map +1 -0
- package/dist/services/definitions/index.d.mts +5 -2
- package/dist/services/definitions/index.d.mts.map +1 -1
- package/dist/services/definitions/index.mjs +145 -67
- package/dist/services/definitions/index.mjs.map +1 -0
- package/dist/services/definitions/kimi.d.mts +0 -1
- package/dist/services/definitions/kimi.d.mts.map +1 -1
- package/dist/services/definitions/kimi.mjs +45 -2
- package/dist/services/definitions/kimi.mjs.map +1 -0
- package/dist/services/definitions/lasuite-meet-agents.d.mts +0 -1
- package/dist/services/definitions/lasuite-meet-agents.d.mts.map +1 -1
- package/dist/services/definitions/lasuite-meet-agents.mjs +35 -2
- package/dist/services/definitions/lasuite-meet-agents.mjs.map +1 -0
- package/dist/services/definitions/lasuite-meet-backend.d.mts +0 -1
- package/dist/services/definitions/lasuite-meet-backend.d.mts.map +1 -1
- package/dist/services/definitions/lasuite-meet-backend.mjs +133 -2
- package/dist/services/definitions/lasuite-meet-backend.mjs.map +1 -0
- package/dist/services/definitions/lasuite-meet-frontend.d.mts +0 -1
- package/dist/services/definitions/lasuite-meet-frontend.d.mts.map +1 -1
- package/dist/services/definitions/lasuite-meet-frontend.mjs +47 -2
- package/dist/services/definitions/lasuite-meet-frontend.mjs.map +1 -0
- package/dist/services/definitions/librechat.d.mts +0 -1
- package/dist/services/definitions/librechat.d.mts.map +1 -1
- package/dist/services/definitions/librechat.mjs +49 -2
- package/dist/services/definitions/librechat.mjs.map +1 -0
- package/dist/services/definitions/lightpanda.d.mts +0 -1
- package/dist/services/definitions/lightpanda.d.mts.map +1 -1
- package/dist/services/definitions/lightpanda.mjs +58 -2
- package/dist/services/definitions/lightpanda.mjs.map +1 -0
- package/dist/services/definitions/litellm.d.mts +0 -1
- package/dist/services/definitions/litellm.d.mts.map +1 -1
- package/dist/services/definitions/litellm.mjs +46 -2
- package/dist/services/definitions/litellm.mjs.map +1 -0
- package/dist/services/definitions/livekit.d.mts +0 -1
- package/dist/services/definitions/livekit.d.mts.map +1 -1
- package/dist/services/definitions/livekit.mjs +55 -2
- package/dist/services/definitions/livekit.mjs.map +1 -0
- package/dist/services/definitions/matomo.d.mts +0 -1
- package/dist/services/definitions/matomo.d.mts.map +1 -1
- package/dist/services/definitions/matomo.mjs +79 -2
- package/dist/services/definitions/matomo.mjs.map +1 -0
- package/dist/services/definitions/matrix-synapse.d.mts +0 -1
- package/dist/services/definitions/matrix-synapse.d.mts.map +1 -1
- package/dist/services/definitions/matrix-synapse.mjs +87 -2
- package/dist/services/definitions/matrix-synapse.mjs.map +1 -0
- package/dist/services/definitions/mattermost.d.mts +0 -1
- package/dist/services/definitions/mattermost.d.mts.map +1 -1
- package/dist/services/definitions/mattermost.mjs +60 -2
- package/dist/services/definitions/mattermost.mjs.map +1 -0
- package/dist/services/definitions/meilisearch.d.mts +0 -1
- package/dist/services/definitions/meilisearch.d.mts.map +1 -1
- package/dist/services/definitions/meilisearch.mjs +77 -2
- package/dist/services/definitions/meilisearch.mjs.map +1 -0
- package/dist/services/definitions/minio.d.mts +0 -1
- package/dist/services/definitions/minio.d.mts.map +1 -1
- package/dist/services/definitions/minio.mjs +101 -2
- package/dist/services/definitions/minio.mjs.map +1 -0
- package/dist/services/definitions/mission-control.d.mts +7 -0
- package/dist/services/definitions/mission-control.d.mts.map +1 -0
- package/dist/services/definitions/mission-control.mjs +67 -0
- package/dist/services/definitions/mission-control.mjs.map +1 -0
- package/dist/services/definitions/mixpost.d.mts +0 -1
- package/dist/services/definitions/mixpost.d.mts.map +1 -1
- package/dist/services/definitions/mixpost.mjs +86 -2
- package/dist/services/definitions/mixpost.mjs.map +1 -0
- package/dist/services/definitions/motion-canvas.d.mts +0 -1
- package/dist/services/definitions/motion-canvas.d.mts.map +1 -1
- package/dist/services/definitions/motion-canvas.mjs +51 -2
- package/dist/services/definitions/motion-canvas.mjs.map +1 -0
- package/dist/services/definitions/n8n.d.mts +0 -1
- package/dist/services/definitions/n8n.d.mts.map +1 -1
- package/dist/services/definitions/n8n.mjs +153 -2
- package/dist/services/definitions/n8n.mjs.map +1 -0
- package/dist/services/definitions/nocodb.d.mts +0 -1
- package/dist/services/definitions/nocodb.d.mts.map +1 -1
- package/dist/services/definitions/nocodb.mjs +44 -2
- package/dist/services/definitions/nocodb.mjs.map +1 -0
- package/dist/services/definitions/ntfy.d.mts +0 -1
- package/dist/services/definitions/ntfy.d.mts.map +1 -1
- package/dist/services/definitions/ntfy.mjs +62 -2
- package/dist/services/definitions/ntfy.mjs.map +1 -0
- package/dist/services/definitions/ollama.d.mts +0 -1
- package/dist/services/definitions/ollama.d.mts.map +1 -1
- package/dist/services/definitions/ollama.mjs +65 -2
- package/dist/services/definitions/ollama.mjs.map +1 -0
- package/dist/services/definitions/open-webui.d.mts +0 -1
- package/dist/services/definitions/open-webui.d.mts.map +1 -1
- package/dist/services/definitions/open-webui.mjs +49 -2
- package/dist/services/definitions/open-webui.mjs.map +1 -0
- package/dist/services/definitions/opencode.d.mts +0 -1
- package/dist/services/definitions/opencode.d.mts.map +1 -1
- package/dist/services/definitions/opencode.mjs +49 -2
- package/dist/services/definitions/opencode.mjs.map +1 -0
- package/dist/services/definitions/openpanel.d.mts +0 -1
- package/dist/services/definitions/openpanel.d.mts.map +1 -1
- package/dist/services/definitions/openpanel.mjs +45 -2
- package/dist/services/definitions/openpanel.mjs.map +1 -0
- package/dist/services/definitions/outline.d.mts +0 -1
- package/dist/services/definitions/outline.d.mts.map +1 -1
- package/dist/services/definitions/outline.mjs +73 -2
- package/dist/services/definitions/outline.mjs.map +1 -0
- package/dist/services/definitions/paperless-ngx.d.mts +0 -1
- package/dist/services/definitions/paperless-ngx.d.mts.map +1 -1
- package/dist/services/definitions/paperless-ngx.mjs +92 -2
- package/dist/services/definitions/paperless-ngx.mjs.map +1 -0
- package/dist/services/definitions/playwright-server.d.mts +0 -1
- package/dist/services/definitions/playwright-server.d.mts.map +1 -1
- package/dist/services/definitions/playwright-server.mjs +41 -2
- package/dist/services/definitions/playwright-server.mjs.map +1 -0
- package/dist/services/definitions/portainer.d.mts +0 -1
- package/dist/services/definitions/portainer.d.mts.map +1 -1
- package/dist/services/definitions/portainer.mjs +48 -2
- package/dist/services/definitions/portainer.mjs.map +1 -0
- package/dist/services/definitions/postgresql.d.mts +0 -1
- package/dist/services/definitions/postgresql.d.mts.map +1 -1
- package/dist/services/definitions/postgresql.mjs +83 -2
- package/dist/services/definitions/postgresql.mjs.map +1 -0
- package/dist/services/definitions/postiz.d.mts +0 -1
- package/dist/services/definitions/postiz.d.mts.map +1 -1
- package/dist/services/definitions/postiz.mjs +82 -2
- package/dist/services/definitions/postiz.mjs.map +1 -0
- package/dist/services/definitions/prometheus.d.mts +0 -1
- package/dist/services/definitions/prometheus.d.mts.map +1 -1
- package/dist/services/definitions/prometheus.mjs +51 -2
- package/dist/services/definitions/prometheus.mjs.map +1 -0
- package/dist/services/definitions/qdrant.d.mts +0 -1
- package/dist/services/definitions/qdrant.d.mts.map +1 -1
- package/dist/services/definitions/qdrant.mjs +76 -2
- package/dist/services/definitions/qdrant.mjs.map +1 -0
- package/dist/services/definitions/redis.d.mts +0 -1
- package/dist/services/definitions/redis.d.mts.map +1 -1
- package/dist/services/definitions/redis.mjs +90 -2
- package/dist/services/definitions/redis.mjs.map +1 -0
- package/dist/services/definitions/remotion.d.mts +0 -1
- package/dist/services/definitions/remotion.d.mts.map +1 -1
- package/dist/services/definitions/remotion.mjs +54 -2
- package/dist/services/definitions/remotion.mjs.map +1 -0
- package/dist/services/definitions/rocketchat.d.mts +0 -1
- package/dist/services/definitions/rocketchat.d.mts.map +1 -1
- package/dist/services/definitions/rocketchat.mjs +56 -2
- package/dist/services/definitions/rocketchat.mjs.map +1 -0
- package/dist/services/definitions/searxng.d.mts +0 -1
- package/dist/services/definitions/searxng.d.mts.map +1 -1
- package/dist/services/definitions/searxng.mjs +64 -2
- package/dist/services/definitions/searxng.mjs.map +1 -0
- package/dist/services/definitions/stable-diffusion.d.mts +0 -1
- package/dist/services/definitions/stable-diffusion.d.mts.map +1 -1
- package/dist/services/definitions/stable-diffusion.mjs +47 -2
- package/dist/services/definitions/stable-diffusion.mjs.map +1 -0
- package/dist/services/definitions/steel-browser.d.mts +0 -1
- package/dist/services/definitions/steel-browser.d.mts.map +1 -1
- package/dist/services/definitions/steel-browser.mjs +76 -2
- package/dist/services/definitions/steel-browser.mjs.map +1 -0
- package/dist/services/definitions/tailscale.d.mts +0 -1
- package/dist/services/definitions/tailscale.d.mts.map +1 -1
- package/dist/services/definitions/tailscale.mjs +69 -2
- package/dist/services/definitions/tailscale.mjs.map +1 -0
- package/dist/services/definitions/temporal.d.mts +0 -1
- package/dist/services/definitions/temporal.d.mts.map +1 -1
- package/dist/services/definitions/temporal.mjs +99 -2
- package/dist/services/definitions/temporal.mjs.map +1 -0
- package/dist/services/definitions/traefik.d.mts +0 -1
- package/dist/services/definitions/traefik.d.mts.map +1 -1
- package/dist/services/definitions/traefik.mjs +57 -2
- package/dist/services/definitions/traefik.mjs.map +1 -0
- package/dist/services/definitions/umami.d.mts +0 -1
- package/dist/services/definitions/umami.d.mts.map +1 -1
- package/dist/services/definitions/umami.mjs +45 -2
- package/dist/services/definitions/umami.mjs.map +1 -0
- package/dist/services/definitions/uptime-kuma.d.mts +0 -1
- package/dist/services/definitions/uptime-kuma.d.mts.map +1 -1
- package/dist/services/definitions/uptime-kuma.mjs +50 -2
- package/dist/services/definitions/uptime-kuma.mjs.map +1 -0
- package/dist/services/definitions/usesend.d.mts +7 -0
- package/dist/services/definitions/usesend.d.mts.map +1 -0
- package/dist/services/definitions/usesend.mjs +99 -0
- package/dist/services/definitions/usesend.mjs.map +1 -0
- package/dist/services/definitions/valkey.d.mts +0 -1
- package/dist/services/definitions/valkey.d.mts.map +1 -1
- package/dist/services/definitions/valkey.mjs +60 -2
- package/dist/services/definitions/valkey.mjs.map +1 -0
- package/dist/services/definitions/watchtower.d.mts +0 -1
- package/dist/services/definitions/watchtower.d.mts.map +1 -1
- package/dist/services/definitions/watchtower.mjs +46 -2
- package/dist/services/definitions/watchtower.mjs.map +1 -0
- package/dist/services/definitions/weaviate.d.mts +0 -1
- package/dist/services/definitions/weaviate.d.mts.map +1 -1
- package/dist/services/definitions/weaviate.mjs +89 -2
- package/dist/services/definitions/weaviate.mjs.map +1 -0
- package/dist/services/definitions/whisper.d.mts +0 -1
- package/dist/services/definitions/whisper.d.mts.map +1 -1
- package/dist/services/definitions/whisper.mjs +61 -2
- package/dist/services/definitions/whisper.mjs.map +1 -0
- package/dist/services/registry.d.mts +0 -1
- package/dist/services/registry.d.mts.map +1 -1
- package/dist/services/registry.mjs +29 -2
- package/dist/services/registry.mjs.map +1 -0
- package/dist/services/registry.test.mjs +2 -2
- package/dist/skills/registry.d.mts +0 -1
- package/dist/skills/registry.d.mts.map +1 -1
- package/dist/skills/registry.mjs +214 -2
- package/dist/skills/registry.mjs.map +1 -0
- package/dist/types.d.mts +1 -1
- package/dist/types.d.mts.map +1 -1
- package/dist/validator.d.mts +0 -1
- package/dist/validator.d.mts.map +1 -1
- package/dist/validator.mjs +110 -2
- package/dist/validator.mjs.map +1 -0
- package/dist/validator.test.mjs +4 -4
- package/dist/version-manager.d.mts +0 -1
- package/dist/version-manager.d.mts.map +1 -1
- package/dist/version-manager.mjs +1 -1
- package/dist/{vi.2VT5v0um-Cs3Z_fCB.mjs → vi.2VT5v0um-Qk6MgAnK.mjs} +1183 -1183
- package/dist/vi.2VT5v0um-Qk6MgAnK.mjs.map +1 -0
- package/package.json +14 -13
- package/src/schema.ts +2 -1
- package/src/services/definitions/convex-dashboard.ts +48 -0
- package/src/services/definitions/convex.ts +123 -0
- package/src/services/definitions/index.ts +12 -0
- package/src/services/definitions/mission-control.ts +71 -0
- package/src/services/definitions/tailscale.ts +2 -0
- package/src/services/definitions/usesend.ts +98 -0
- package/tsdown.config.ts +1 -0
- package/dist/anything-llm-DIIPhz6K.mjs +0 -44
- package/dist/anything-llm-DIIPhz6K.mjs.map +0 -1
- package/dist/appflowy-DdoE-dKg.mjs +0 -45
- package/dist/appflowy-DdoE-dKg.mjs.map +0 -1
- package/dist/bare-metal-install-DpYZDoGq.mjs +0 -224
- package/dist/bare-metal-install-DpYZDoGq.mjs.map +0 -1
- package/dist/bare-metal-partition-CYlOxf9B.mjs +0 -48
- package/dist/bare-metal-partition-CYlOxf9B.mjs.map +0 -1
- package/dist/beszel-DHAG1zl0.mjs +0 -45
- package/dist/beszel-DHAG1zl0.mjs.map +0 -1
- package/dist/browserless-gUuvGmMD.mjs +0 -85
- package/dist/browserless-gUuvGmMD.mjs.map +0 -1
- package/dist/caddy-BJDrqnmw.mjs +0 -77
- package/dist/caddy-BJDrqnmw.mjs.map +0 -1
- package/dist/caddy-_NIdWKrf.mjs +0 -52
- package/dist/caddy-_NIdWKrf.mjs.map +0 -1
- package/dist/chromadb-g4rIsfAl.mjs +0 -63
- package/dist/chromadb-g4rIsfAl.mjs.map +0 -1
- package/dist/claude-code-DPRA1fy_.mjs +0 -52
- package/dist/claude-code-DPRA1fy_.mjs.map +0 -1
- package/dist/code-server-BdZZxxm5.mjs +0 -66
- package/dist/code-server-BdZZxxm5.mjs.map +0 -1
- package/dist/codex-DFVzfrfX.mjs +0 -45
- package/dist/codex-DFVzfrfX.mjs.map +0 -1
- package/dist/composer-CSM5YycB.mjs +0 -287
- package/dist/composer-CSM5YycB.mjs.map +0 -1
- package/dist/coolify-Z5_zDgM3.mjs +0 -49
- package/dist/coolify-Z5_zDgM3.mjs.map +0 -1
- package/dist/definitions-BXpb1kzs.mjs +0 -138
- package/dist/definitions-BXpb1kzs.mjs.map +0 -1
- package/dist/dify-jDc9U6Ku.mjs +0 -81
- package/dist/dify-jDc9U6Ku.mjs.map +0 -1
- package/dist/docsgpt-BXM1c2JC.mjs +0 -45
- package/dist/docsgpt-BXM1c2JC.mjs.map +0 -1
- package/dist/dokploy-Ci8_fb0_.mjs +0 -49
- package/dist/dokploy-Ci8_fb0_.mjs.map +0 -1
- package/dist/dozzle-fAt2sLRL.mjs +0 -41
- package/dist/dozzle-fAt2sLRL.mjs.map +0 -1
- package/dist/env-D2h46lHT.mjs +0 -250
- package/dist/env-D2h46lHT.mjs.map +0 -1
- package/dist/ffmpeg-BCtnA8m_.mjs +0 -66
- package/dist/ffmpeg-BCtnA8m_.mjs.map +0 -1
- package/dist/flowise-CJTTBa7J.mjs +0 -45
- package/dist/flowise-CJTTBa7J.mjs.map +0 -1
- package/dist/gemini-cli-Bfwv6hYe.mjs +0 -46
- package/dist/gemini-cli-Bfwv6hYe.mjs.map +0 -1
- package/dist/gitea-BGkqa-sD.mjs +0 -49
- package/dist/gitea-BGkqa-sD.mjs.map +0 -1
- package/dist/gotify-D7p8oNM3.mjs +0 -62
- package/dist/gotify-D7p8oNM3.mjs.map +0 -1
- package/dist/grafana-BlnWc6js.mjs +0 -63
- package/dist/grafana-BlnWc6js.mjs.map +0 -1
- package/dist/grafana-D3kIm8RX.mjs +0 -293
- package/dist/grafana-D3kIm8RX.mjs.map +0 -1
- package/dist/kimi-BFu1v1sU.mjs +0 -46
- package/dist/kimi-BFu1v1sU.mjs.map +0 -1
- package/dist/lasuite-meet-agents-nlPhMEaN.mjs +0 -36
- package/dist/lasuite-meet-agents-nlPhMEaN.mjs.map +0 -1
- package/dist/lasuite-meet-backend-9H7rZ8Pc.mjs +0 -134
- package/dist/lasuite-meet-backend-9H7rZ8Pc.mjs.map +0 -1
- package/dist/lasuite-meet-frontend-B4xNbnBa.mjs +0 -48
- package/dist/lasuite-meet-frontend-B4xNbnBa.mjs.map +0 -1
- package/dist/librechat-CoPIHXKK.mjs +0 -50
- package/dist/librechat-CoPIHXKK.mjs.map +0 -1
- package/dist/lightpanda-QchAPgNX.mjs +0 -59
- package/dist/lightpanda-QchAPgNX.mjs.map +0 -1
- package/dist/litellm-Dgl6iTry.mjs +0 -47
- package/dist/litellm-Dgl6iTry.mjs.map +0 -1
- package/dist/livekit-C13SxlVB.mjs +0 -56
- package/dist/livekit-C13SxlVB.mjs.map +0 -1
- package/dist/magic-string.es-Dew0Rnsa.mjs.map +0 -1
- package/dist/matomo-CiOoggYl.mjs +0 -80
- package/dist/matomo-CiOoggYl.mjs.map +0 -1
- package/dist/matrix-synapse-CP20A7NN.mjs +0 -88
- package/dist/matrix-synapse-CP20A7NN.mjs.map +0 -1
- package/dist/mattermost-CeFVuhIr.mjs +0 -61
- package/dist/mattermost-CeFVuhIr.mjs.map +0 -1
- package/dist/meilisearch-CLiQiTdN.mjs +0 -78
- package/dist/meilisearch-CLiQiTdN.mjs.map +0 -1
- package/dist/minio-_QuguAeo.mjs +0 -102
- package/dist/minio-_QuguAeo.mjs.map +0 -1
- package/dist/mixpost-eSFPM9XK.mjs +0 -87
- package/dist/mixpost-eSFPM9XK.mjs.map +0 -1
- package/dist/motion-canvas-Bk1ruvuX.mjs +0 -52
- package/dist/motion-canvas-Bk1ruvuX.mjs.map +0 -1
- package/dist/n8n-W5qeU34C.mjs +0 -154
- package/dist/n8n-W5qeU34C.mjs.map +0 -1
- package/dist/n8n-workflows-BPmKVx8z.mjs +0 -75
- package/dist/n8n-workflows-BPmKVx8z.mjs.map +0 -1
- package/dist/native-services-CwOCM-Xz.mjs +0 -78
- package/dist/native-services-CwOCM-Xz.mjs.map +0 -1
- package/dist/nocodb-DQNbSYh_.mjs +0 -45
- package/dist/nocodb-DQNbSYh_.mjs.map +0 -1
- package/dist/ntfy-B8_cZAx2.mjs +0 -63
- package/dist/ntfy-B8_cZAx2.mjs.map +0 -1
- package/dist/ollama-BiKAypcO.mjs +0 -66
- package/dist/ollama-BiKAypcO.mjs.map +0 -1
- package/dist/open-webui-DZOG4_xL.mjs +0 -50
- package/dist/open-webui-DZOG4_xL.mjs.map +0 -1
- package/dist/opencode-Dvfh5KvA.mjs +0 -50
- package/dist/opencode-Dvfh5KvA.mjs.map +0 -1
- package/dist/openpanel-BuWHhDze.mjs +0 -46
- package/dist/openpanel-BuWHhDze.mjs.map +0 -1
- package/dist/outline-Dy-YzdYS.mjs +0 -74
- package/dist/outline-Dy-YzdYS.mjs.map +0 -1
- package/dist/paperless-ngx-DVtWWpKg.mjs +0 -93
- package/dist/paperless-ngx-DVtWWpKg.mjs.map +0 -1
- package/dist/playwright-server-Boiz8--G.mjs +0 -42
- package/dist/playwright-server-Boiz8--G.mjs.map +0 -1
- package/dist/portainer-D9MU96UI.mjs +0 -49
- package/dist/portainer-D9MU96UI.mjs.map +0 -1
- package/dist/postgres-init-BiM-xZtq.mjs +0 -151
- package/dist/postgres-init-BiM-xZtq.mjs.map +0 -1
- package/dist/postgresql-s65Z9RqR.mjs +0 -84
- package/dist/postgresql-s65Z9RqR.mjs.map +0 -1
- package/dist/postiz-U6EK23EY.mjs +0 -83
- package/dist/postiz-U6EK23EY.mjs.map +0 -1
- package/dist/prometheus-WOlk-a1G.mjs +0 -107
- package/dist/prometheus-WOlk-a1G.mjs.map +0 -1
- package/dist/prometheus-x901F67p.mjs +0 -52
- package/dist/prometheus-x901F67p.mjs.map +0 -1
- package/dist/qdrant-DZW9uW4e.mjs +0 -77
- package/dist/qdrant-DZW9uW4e.mjs.map +0 -1
- package/dist/readme-C7M3QE9a.mjs +0 -199
- package/dist/readme-C7M3QE9a.mjs.map +0 -1
- package/dist/redis-DPMOf237.mjs +0 -91
- package/dist/redis-DPMOf237.mjs.map +0 -1
- package/dist/registry-CqLarEm5.mjs +0 -30
- package/dist/registry-CqLarEm5.mjs.map +0 -1
- package/dist/registry-DLX9Q4VQ.mjs +0 -215
- package/dist/registry-DLX9Q4VQ.mjs.map +0 -1
- package/dist/remotion-COkr0wpr.mjs +0 -55
- package/dist/remotion-COkr0wpr.mjs.map +0 -1
- package/dist/resolver-Dl5clk-d.mjs +0 -194
- package/dist/resolver-Dl5clk-d.mjs.map +0 -1
- package/dist/rocketchat-BebQT1MZ.mjs +0 -57
- package/dist/rocketchat-BebQT1MZ.mjs.map +0 -1
- package/dist/schema-PSUY6yJU.d.mts +0 -700
- package/dist/schema-PSUY6yJU.d.mts.map +0 -1
- package/dist/scripts-DsljWbP4.mjs +0 -351
- package/dist/scripts-DsljWbP4.mjs.map +0 -1
- package/dist/searxng-tJpBkchC.mjs +0 -65
- package/dist/searxng-tJpBkchC.mjs.map +0 -1
- package/dist/skills-DWG72Y3X.mjs +0 -587
- package/dist/skills-DWG72Y3X.mjs.map +0 -1
- package/dist/stable-diffusion-BulAzkyT.mjs +0 -48
- package/dist/stable-diffusion-BulAzkyT.mjs.map +0 -1
- package/dist/steel-browser-Cc0bYBjM.mjs +0 -77
- package/dist/steel-browser-Cc0bYBjM.mjs.map +0 -1
- package/dist/tailscale-CrM4EZlF.mjs +0 -69
- package/dist/tailscale-CrM4EZlF.mjs.map +0 -1
- package/dist/temporal-49gA0msh.mjs +0 -100
- package/dist/temporal-49gA0msh.mjs.map +0 -1
- package/dist/traefik-Da-c1f55.mjs +0 -58
- package/dist/traefik-Da-c1f55.mjs.map +0 -1
- package/dist/umami-csBSsHqO.mjs +0 -46
- package/dist/umami-csBSsHqO.mjs.map +0 -1
- package/dist/uptime-kuma-D0NvVuXD.mjs +0 -51
- package/dist/uptime-kuma-D0NvVuXD.mjs.map +0 -1
- package/dist/validator-2FspYNva.mjs +0 -111
- package/dist/validator-2FspYNva.mjs.map +0 -1
- package/dist/valkey-BCZqGJ0L.mjs +0 -61
- package/dist/valkey-BCZqGJ0L.mjs.map +0 -1
- package/dist/vi.2VT5v0um-Cs3Z_fCB.mjs.map +0 -1
- package/dist/watchtower-BWuvFGpA.mjs +0 -47
- package/dist/watchtower-BWuvFGpA.mjs.map +0 -1
- package/dist/weaviate-DttY1Hn7.mjs +0 -90
- package/dist/weaviate-DttY1Hn7.mjs.map +0 -1
- package/dist/whisper-CLu7-Vd8.mjs +0 -62
- package/dist/whisper-CLu7-Vd8.mjs.map +0 -1
|
@@ -1,3 +1,224 @@
|
|
|
1
|
-
|
|
1
|
+
//#region src/generators/bare-metal-install.ts
|
|
2
|
+
const LINUX_SCRIPT_PREFIX_NATIVE = `
|
|
3
|
+
# Native services (install/start on host first)
|
|
4
|
+
if [ -f "native/install-linux.sh" ]; then
|
|
5
|
+
info "Installing and starting native services..."
|
|
6
|
+
bash native/install-linux.sh
|
|
7
|
+
ok "Native services ready."
|
|
8
|
+
fi
|
|
9
|
+
`;
|
|
10
|
+
const LINUX_SCRIPT = `#!/usr/bin/env bash
|
|
11
|
+
set -euo pipefail
|
|
2
12
|
|
|
3
|
-
|
|
13
|
+
# OpenClaw bare-metal installer (Linux)
|
|
14
|
+
# Optionally runs native services script, then Docker + Compose.
|
|
15
|
+
# Idempotent: safe to re-run.
|
|
16
|
+
|
|
17
|
+
SCRIPT_DIR="$(cd "$(dirname "\${BASH_SOURCE[0]}")" && pwd)"
|
|
18
|
+
cd "$SCRIPT_DIR"
|
|
19
|
+
|
|
20
|
+
if [ -t 1 ]; then
|
|
21
|
+
RED='\\033[0;31m'; GREEN='\\033[0;32m'; YELLOW='\\033[1;33m'; CYAN='\\033[0;36m'; NC='\\033[0m'
|
|
22
|
+
else
|
|
23
|
+
RED=''; GREEN=''; YELLOW=''; CYAN=''; NC=''
|
|
24
|
+
fi
|
|
25
|
+
info() { echo -e "\${CYAN}ℹ $*\${NC}"; }
|
|
26
|
+
ok() { echo -e "\${GREEN}✅ $*\${NC}"; }
|
|
27
|
+
warn() { echo -e "\${YELLOW}⚠️ $*\${NC}"; }
|
|
28
|
+
err() { echo -e "\${RED}❌ $*\${NC}" >&2; }
|
|
29
|
+
__NATIVE_BLOCK__
|
|
30
|
+
# Install Docker if missing
|
|
31
|
+
if ! command -v docker &> /dev/null; then
|
|
32
|
+
info "Installing Docker..."
|
|
33
|
+
if command -v apt-get &> /dev/null; then
|
|
34
|
+
sudo apt-get update -qq
|
|
35
|
+
sudo apt-get install -y -qq ca-certificates curl
|
|
36
|
+
curl -fsSL https://get.docker.com | sudo sh
|
|
37
|
+
sudo usermod -aG docker "$USER" 2>/dev/null || true
|
|
38
|
+
ok "Docker installed. You may need to log out and back in for group changes."
|
|
39
|
+
elif command -v dnf &> /dev/null || command -v yum &> /dev/null; then
|
|
40
|
+
sudo dnf install -y dnf-plugins-core 2>/dev/null || sudo yum install -y yum-utils
|
|
41
|
+
sudo dnf config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo 2>/dev/null || sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
|
|
42
|
+
sudo dnf install -y docker-ce docker-ce-cli containerd.io docker-compose-plugin 2>/dev/null || sudo yum install -y docker-ce docker-ce-cli containerd.io docker-compose-plugin
|
|
43
|
+
sudo systemctl enable --now docker
|
|
44
|
+
sudo usermod -aG docker "$USER" 2>/dev/null || true
|
|
45
|
+
ok "Docker installed."
|
|
46
|
+
else
|
|
47
|
+
err "Unsupported package manager. Install Docker manually: https://docs.docker.com/engine/install/"
|
|
48
|
+
exit 1
|
|
49
|
+
fi
|
|
50
|
+
else
|
|
51
|
+
ok "Docker already installed."
|
|
52
|
+
fi
|
|
53
|
+
|
|
54
|
+
if ! docker compose version &> /dev/null; then
|
|
55
|
+
err "Docker Compose (v2) plugin not found. Install it: https://docs.docker.com/compose/install/"
|
|
56
|
+
exit 1
|
|
57
|
+
fi
|
|
58
|
+
|
|
59
|
+
if ! docker info &> /dev/null 2>&1; then
|
|
60
|
+
err "Docker daemon not running. Start it (e.g. sudo systemctl start docker) and re-run this script."
|
|
61
|
+
exit 1
|
|
62
|
+
fi
|
|
63
|
+
|
|
64
|
+
# Use project start script if present, else docker compose up
|
|
65
|
+
if [ -f "scripts/start.sh" ]; then
|
|
66
|
+
info "Starting stack via scripts/start.sh..."
|
|
67
|
+
bash scripts/start.sh
|
|
68
|
+
else
|
|
69
|
+
if [ -f ".env.example" ] && [ ! -f ".env" ]; then cp .env.example .env; fi
|
|
70
|
+
info "Starting stack..."
|
|
71
|
+
docker compose up -d --remove-orphans
|
|
72
|
+
echo ""
|
|
73
|
+
ok "Stack started. Gateway: http://localhost:\${OPENCLAW_GATEWAY_PORT:-18789}"
|
|
74
|
+
fi
|
|
75
|
+
`;
|
|
76
|
+
const MACOS_SCRIPT_PREFIX_NATIVE = `
|
|
77
|
+
if [ -f "native/install-macos.sh" ]; then
|
|
78
|
+
info "Installing and starting native services..."
|
|
79
|
+
bash native/install-macos.sh
|
|
80
|
+
ok "Native services ready."
|
|
81
|
+
fi
|
|
82
|
+
`;
|
|
83
|
+
const MACOS_SCRIPT = `#!/usr/bin/env bash
|
|
84
|
+
set -euo pipefail
|
|
85
|
+
|
|
86
|
+
# OpenClaw bare-metal installer (macOS)
|
|
87
|
+
# Optionally runs native services, then Docker Desktop + compose.
|
|
88
|
+
# Idempotent: safe to re-run.
|
|
89
|
+
|
|
90
|
+
SCRIPT_DIR="$(cd "$(dirname "\${BASH_SOURCE[0]}")" && pwd)"
|
|
91
|
+
cd "$SCRIPT_DIR"
|
|
92
|
+
|
|
93
|
+
if [ -t 1 ]; then
|
|
94
|
+
RED='\\033[0;31m'; GREEN='\\033[0;32m'; YELLOW='\\033[1;33m'; CYAN='\\033[0;36m'; NC='\\033[0m'
|
|
95
|
+
else
|
|
96
|
+
RED=''; GREEN=''; YELLOW=''; CYAN=''; NC=''
|
|
97
|
+
fi
|
|
98
|
+
info() { echo -e "\${CYAN}ℹ $*\${NC}"; }
|
|
99
|
+
ok() { echo -e "\${GREEN}✅ $*\${NC}"; }
|
|
100
|
+
warn() { echo -e "\${YELLOW}⚠️ $*\${NC}"; }
|
|
101
|
+
err() { echo -e "\${RED}❌ $*\${NC}" >&2; }
|
|
102
|
+
__NATIVE_BLOCK__
|
|
103
|
+
if ! command -v docker &> /dev/null; then
|
|
104
|
+
if command -v brew &> /dev/null; then
|
|
105
|
+
info "Installing Docker via Homebrew..."
|
|
106
|
+
brew install --cask docker
|
|
107
|
+
warn "Docker Desktop was installed. Please open Docker from Applications, then re-run this script."
|
|
108
|
+
exit 0
|
|
109
|
+
else
|
|
110
|
+
err "Docker not found. Install Docker Desktop from https://docs.docker.com/desktop/install/mac-install/ or run: brew install --cask docker"
|
|
111
|
+
exit 1
|
|
112
|
+
fi
|
|
113
|
+
fi
|
|
114
|
+
|
|
115
|
+
if ! docker info &> /dev/null 2>&1; then
|
|
116
|
+
err "Docker daemon not running. Open Docker Desktop from Applications, then re-run this script."
|
|
117
|
+
exit 1
|
|
118
|
+
fi
|
|
119
|
+
|
|
120
|
+
if ! docker compose version &> /dev/null; then
|
|
121
|
+
err "Docker Compose (v2) not available. Ensure Docker Desktop is up to date."
|
|
122
|
+
exit 1
|
|
123
|
+
fi
|
|
124
|
+
|
|
125
|
+
if [ -f "scripts/start.sh" ]; then
|
|
126
|
+
info "Starting stack via scripts/start.sh..."
|
|
127
|
+
bash scripts/start.sh
|
|
128
|
+
else
|
|
129
|
+
if [ -f ".env.example" ] && [ ! -f ".env" ]; then cp .env.example .env; fi
|
|
130
|
+
info "Starting stack..."
|
|
131
|
+
docker compose up -d --remove-orphans
|
|
132
|
+
echo ""
|
|
133
|
+
ok "Stack started. Gateway: http://localhost:\${OPENCLAW_GATEWAY_PORT:-18789}"
|
|
134
|
+
fi
|
|
135
|
+
`;
|
|
136
|
+
const WINDOWS_SCRIPT_PREFIX_NATIVE = `
|
|
137
|
+
if (Test-Path "native/install-windows.ps1") {
|
|
138
|
+
Info "Installing and starting native services..."
|
|
139
|
+
& .\\native\\install-windows.ps1
|
|
140
|
+
Ok "Native services ready."
|
|
141
|
+
}
|
|
142
|
+
`;
|
|
143
|
+
const WINDOWS_SCRIPT = `# OpenClaw bare-metal installer (Windows PowerShell)
|
|
144
|
+
# Optionally runs native services, then Docker Desktop + compose.
|
|
145
|
+
# Idempotent: safe to re-run. Run in PowerShell as Administrator if installing Docker.
|
|
146
|
+
|
|
147
|
+
$ErrorActionPreference = "Stop"
|
|
148
|
+
$ProjectDir = $PSScriptRoot
|
|
149
|
+
Set-Location $ProjectDir
|
|
150
|
+
|
|
151
|
+
function Info { Write-Host " $args" -ForegroundColor Cyan }
|
|
152
|
+
function Ok { Write-Host " $args" -ForegroundColor Green }
|
|
153
|
+
function Warn { Write-Host " $args" -ForegroundColor Yellow }
|
|
154
|
+
function Err { Write-Host " $args" -ForegroundColor Red; exit 1 }
|
|
155
|
+
__NATIVE_BLOCK__
|
|
156
|
+
# Check Docker
|
|
157
|
+
$docker = Get-Command docker -ErrorAction SilentlyContinue
|
|
158
|
+
if (-not $docker) {
|
|
159
|
+
Write-Host ""
|
|
160
|
+
Write-Host " Docker not found." -ForegroundColor Red
|
|
161
|
+
Write-Host " Install Docker Desktop from: https://docs.docker.com/desktop/install/windows-install/"
|
|
162
|
+
Write-Host " Then restart PowerShell and run this script again."
|
|
163
|
+
exit 1
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
try { docker info 2>$null | Out-Null } catch {
|
|
167
|
+
Write-Host ""
|
|
168
|
+
Write-Host " Docker daemon is not running." -ForegroundColor Red
|
|
169
|
+
Write-Host " Start Docker Desktop from the Start menu, then run this script again."
|
|
170
|
+
exit 1
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
try { docker compose version 2>$null | Out-Null } catch {
|
|
174
|
+
Write-Host ""
|
|
175
|
+
Write-Host " Docker Compose (v2) not available. Update Docker Desktop." -ForegroundColor Red
|
|
176
|
+
exit 1
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
Ok "Docker is ready."
|
|
180
|
+
|
|
181
|
+
# Prepare .env
|
|
182
|
+
if (-not (Test-Path ".env")) {
|
|
183
|
+
if (Test-Path ".env.example") {
|
|
184
|
+
Copy-Item ".env.example" ".env"
|
|
185
|
+
Info "Created .env from .env.example"
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
# Create dirs
|
|
190
|
+
$configDir = if ($env:OPENCLAW_CONFIG_DIR) { $env:OPENCLAW_CONFIG_DIR } else { "./openclaw/config" }
|
|
191
|
+
$workspaceDir = if ($env:OPENCLAW_WORKSPACE_DIR) { $env:OPENCLAW_WORKSPACE_DIR } else { "./openclaw/workspace" }
|
|
192
|
+
New-Item -ItemType Directory -Force -Path $configDir | Out-Null
|
|
193
|
+
New-Item -ItemType Directory -Force -Path $workspaceDir | Out-Null
|
|
194
|
+
Ok "Directories ready."
|
|
195
|
+
|
|
196
|
+
# Start stack
|
|
197
|
+
Info "Starting stack..."
|
|
198
|
+
docker compose up -d --remove-orphans
|
|
199
|
+
|
|
200
|
+
$port = if ($env:OPENCLAW_GATEWAY_PORT) { $env:OPENCLAW_GATEWAY_PORT } else { "18789" }
|
|
201
|
+
Write-Host ""
|
|
202
|
+
Ok "Stack started. Gateway: http://localhost:$port"
|
|
203
|
+
`;
|
|
204
|
+
/**
|
|
205
|
+
* Returns one file: install.sh (Linux/macOS) or install.ps1 (Windows).
|
|
206
|
+
* When hasNativeServices is true, the script runs the native installer first, then Docker + compose.
|
|
207
|
+
*/
|
|
208
|
+
function generateBareMetalInstall(options) {
|
|
209
|
+
const { platform, hasNativeServices } = options;
|
|
210
|
+
const files = {};
|
|
211
|
+
if (platform === "windows/amd64") {
|
|
212
|
+
files["install.ps1"] = hasNativeServices ? WINDOWS_SCRIPT.replace("__NATIVE_BLOCK__", WINDOWS_SCRIPT_PREFIX_NATIVE) : WINDOWS_SCRIPT.replace("__NATIVE_BLOCK__", "");
|
|
213
|
+
return files;
|
|
214
|
+
}
|
|
215
|
+
const isMac = platform.startsWith("macos/");
|
|
216
|
+
const baseScript = isMac ? MACOS_SCRIPT : LINUX_SCRIPT;
|
|
217
|
+
const prefix = hasNativeServices ? isMac ? MACOS_SCRIPT_PREFIX_NATIVE : LINUX_SCRIPT_PREFIX_NATIVE : "";
|
|
218
|
+
files["install.sh"] = baseScript.replace("__NATIVE_BLOCK__", prefix);
|
|
219
|
+
return files;
|
|
220
|
+
}
|
|
221
|
+
|
|
222
|
+
//#endregion
|
|
223
|
+
export { generateBareMetalInstall };
|
|
224
|
+
//# sourceMappingURL=bare-metal-install.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bare-metal-install.mjs","names":[],"sources":["../../src/generators/bare-metal-install.ts"],"sourcesContent":["/**\n * Generates platform-specific installer scripts for bare-metal (VPS, computer) deployment.\n * Each script ensures Docker and Docker Compose are installed, then runs the stack.\n * Returns a map of one file: install.sh (Linux/macOS) or install.ps1 (Windows).\n */\nimport type { Platform } from \"../types.js\";\n\nconst LINUX_SCRIPT_PREFIX_NATIVE = `\n# Native services (install/start on host first)\nif [ -f \"native/install-linux.sh\" ]; then\n info \"Installing and starting native services...\"\n bash native/install-linux.sh\n ok \"Native services ready.\"\nfi\n`;\n\nconst LINUX_SCRIPT = `#!/usr/bin/env bash\nset -euo pipefail\n\n# OpenClaw bare-metal installer (Linux)\n# Optionally runs native services script, then Docker + Compose.\n# Idempotent: safe to re-run.\n\nSCRIPT_DIR=\"$(cd \"$(dirname \"\\${BASH_SOURCE[0]}\")\" && pwd)\"\ncd \"$SCRIPT_DIR\"\n\nif [ -t 1 ]; then\n RED='\\\\033[0;31m'; GREEN='\\\\033[0;32m'; YELLOW='\\\\033[1;33m'; CYAN='\\\\033[0;36m'; NC='\\\\033[0m'\nelse\n RED=''; GREEN=''; YELLOW=''; CYAN=''; NC=''\nfi\ninfo() { echo -e \"\\${CYAN}ℹ $*\\${NC}\"; }\nok() { echo -e \"\\${GREEN}✅ $*\\${NC}\"; }\nwarn() { echo -e \"\\${YELLOW}⚠️ $*\\${NC}\"; }\nerr() { echo -e \"\\${RED}❌ $*\\${NC}\" >&2; }\n__NATIVE_BLOCK__\n# Install Docker if missing\nif ! command -v docker &> /dev/null; then\n info \"Installing Docker...\"\n if command -v apt-get &> /dev/null; then\n sudo apt-get update -qq\n sudo apt-get install -y -qq ca-certificates curl\n curl -fsSL https://get.docker.com | sudo sh\n sudo usermod -aG docker \"$USER\" 2>/dev/null || true\n ok \"Docker installed. You may need to log out and back in for group changes.\"\n elif command -v dnf &> /dev/null || command -v yum &> /dev/null; then\n sudo dnf install -y dnf-plugins-core 2>/dev/null || sudo yum install -y yum-utils\n sudo dnf config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo 2>/dev/null || sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo\n sudo dnf install -y docker-ce docker-ce-cli containerd.io docker-compose-plugin 2>/dev/null || sudo yum install -y docker-ce docker-ce-cli containerd.io docker-compose-plugin\n sudo systemctl enable --now docker\n sudo usermod -aG docker \"$USER\" 2>/dev/null || true\n ok \"Docker installed.\"\n else\n err \"Unsupported package manager. Install Docker manually: https://docs.docker.com/engine/install/\"\n exit 1\n fi\nelse\n ok \"Docker already installed.\"\nfi\n\nif ! docker compose version &> /dev/null; then\n err \"Docker Compose (v2) plugin not found. Install it: https://docs.docker.com/compose/install/\"\n exit 1\nfi\n\nif ! docker info &> /dev/null 2>&1; then\n err \"Docker daemon not running. Start it (e.g. sudo systemctl start docker) and re-run this script.\"\n exit 1\nfi\n\n# Use project start script if present, else docker compose up\nif [ -f \"scripts/start.sh\" ]; then\n info \"Starting stack via scripts/start.sh...\"\n bash scripts/start.sh\nelse\n if [ -f \".env.example\" ] && [ ! -f \".env\" ]; then cp .env.example .env; fi\n info \"Starting stack...\"\n docker compose up -d --remove-orphans\n echo \"\"\n ok \"Stack started. Gateway: http://localhost:\\${OPENCLAW_GATEWAY_PORT:-18789}\"\nfi\n`;\n\nconst MACOS_SCRIPT_PREFIX_NATIVE = `\nif [ -f \"native/install-macos.sh\" ]; then\n info \"Installing and starting native services...\"\n bash native/install-macos.sh\n ok \"Native services ready.\"\nfi\n`;\n\nconst MACOS_SCRIPT = `#!/usr/bin/env bash\nset -euo pipefail\n\n# OpenClaw bare-metal installer (macOS)\n# Optionally runs native services, then Docker Desktop + compose.\n# Idempotent: safe to re-run.\n\nSCRIPT_DIR=\"$(cd \"$(dirname \"\\${BASH_SOURCE[0]}\")\" && pwd)\"\ncd \"$SCRIPT_DIR\"\n\nif [ -t 1 ]; then\n RED='\\\\033[0;31m'; GREEN='\\\\033[0;32m'; YELLOW='\\\\033[1;33m'; CYAN='\\\\033[0;36m'; NC='\\\\033[0m'\nelse\n RED=''; GREEN=''; YELLOW=''; CYAN=''; NC=''\nfi\ninfo() { echo -e \"\\${CYAN}ℹ $*\\${NC}\"; }\nok() { echo -e \"\\${GREEN}✅ $*\\${NC}\"; }\nwarn() { echo -e \"\\${YELLOW}⚠️ $*\\${NC}\"; }\nerr() { echo -e \"\\${RED}❌ $*\\${NC}\" >&2; }\n__NATIVE_BLOCK__\nif ! command -v docker &> /dev/null; then\n if command -v brew &> /dev/null; then\n info \"Installing Docker via Homebrew...\"\n brew install --cask docker\n warn \"Docker Desktop was installed. Please open Docker from Applications, then re-run this script.\"\n exit 0\n else\n err \"Docker not found. Install Docker Desktop from https://docs.docker.com/desktop/install/mac-install/ or run: brew install --cask docker\"\n exit 1\n fi\nfi\n\nif ! docker info &> /dev/null 2>&1; then\n err \"Docker daemon not running. Open Docker Desktop from Applications, then re-run this script.\"\n exit 1\nfi\n\nif ! docker compose version &> /dev/null; then\n err \"Docker Compose (v2) not available. Ensure Docker Desktop is up to date.\"\n exit 1\nfi\n\nif [ -f \"scripts/start.sh\" ]; then\n info \"Starting stack via scripts/start.sh...\"\n bash scripts/start.sh\nelse\n if [ -f \".env.example\" ] && [ ! -f \".env\" ]; then cp .env.example .env; fi\n info \"Starting stack...\"\n docker compose up -d --remove-orphans\n echo \"\"\n ok \"Stack started. Gateway: http://localhost:\\${OPENCLAW_GATEWAY_PORT:-18789}\"\nfi\n`;\n\nconst WINDOWS_SCRIPT_PREFIX_NATIVE = `\nif (Test-Path \"native/install-windows.ps1\") {\n Info \"Installing and starting native services...\"\n & .\\\\native\\\\install-windows.ps1\n Ok \"Native services ready.\"\n}\n`;\n\nconst WINDOWS_SCRIPT = `# OpenClaw bare-metal installer (Windows PowerShell)\n# Optionally runs native services, then Docker Desktop + compose.\n# Idempotent: safe to re-run. Run in PowerShell as Administrator if installing Docker.\n\n$ErrorActionPreference = \"Stop\"\n$ProjectDir = $PSScriptRoot\nSet-Location $ProjectDir\n\nfunction Info { Write-Host \" $args\" -ForegroundColor Cyan }\nfunction Ok { Write-Host \" $args\" -ForegroundColor Green }\nfunction Warn { Write-Host \" $args\" -ForegroundColor Yellow }\nfunction Err { Write-Host \" $args\" -ForegroundColor Red; exit 1 }\n__NATIVE_BLOCK__\n# Check Docker\n$docker = Get-Command docker -ErrorAction SilentlyContinue\nif (-not $docker) {\n Write-Host \"\"\n Write-Host \" Docker not found.\" -ForegroundColor Red\n Write-Host \" Install Docker Desktop from: https://docs.docker.com/desktop/install/windows-install/\"\n Write-Host \" Then restart PowerShell and run this script again.\"\n exit 1\n}\n\ntry { docker info 2>$null | Out-Null } catch {\n Write-Host \"\"\n Write-Host \" Docker daemon is not running.\" -ForegroundColor Red\n Write-Host \" Start Docker Desktop from the Start menu, then run this script again.\"\n exit 1\n}\n\ntry { docker compose version 2>$null | Out-Null } catch {\n Write-Host \"\"\n Write-Host \" Docker Compose (v2) not available. Update Docker Desktop.\" -ForegroundColor Red\n exit 1\n}\n\nOk \"Docker is ready.\"\n\n# Prepare .env\nif (-not (Test-Path \".env\")) {\n if (Test-Path \".env.example\") {\n Copy-Item \".env.example\" \".env\"\n Info \"Created .env from .env.example\"\n }\n}\n\n# Create dirs\n$configDir = if ($env:OPENCLAW_CONFIG_DIR) { $env:OPENCLAW_CONFIG_DIR } else { \"./openclaw/config\" }\n$workspaceDir = if ($env:OPENCLAW_WORKSPACE_DIR) { $env:OPENCLAW_WORKSPACE_DIR } else { \"./openclaw/workspace\" }\nNew-Item -ItemType Directory -Force -Path $configDir | Out-Null\nNew-Item -ItemType Directory -Force -Path $workspaceDir | Out-Null\nOk \"Directories ready.\"\n\n# Start stack\nInfo \"Starting stack...\"\ndocker compose up -d --remove-orphans\n\n$port = if ($env:OPENCLAW_GATEWAY_PORT) { $env:OPENCLAW_GATEWAY_PORT } else { \"18789\" }\nWrite-Host \"\"\nOk \"Stack started. Gateway: http://localhost:$port\"\n`;\n\nexport interface BareMetalInstallOptions {\n\tplatform: Platform;\n\tprojectName: string;\n\t/** When true, top-level script runs native/install-*.sh|ps1 first, then Docker + compose. */\n\thasNativeServices?: boolean;\n}\n\n/**\n * Returns one file: install.sh (Linux/macOS) or install.ps1 (Windows).\n * When hasNativeServices is true, the script runs the native installer first, then Docker + compose.\n */\nexport function generateBareMetalInstall(options: BareMetalInstallOptions): Record<string, string> {\n\tconst { platform, hasNativeServices } = options;\n\tconst files: Record<string, string> = {};\n\n\tif (platform === \"windows/amd64\") {\n\t\tconst script = hasNativeServices\n\t\t\t? WINDOWS_SCRIPT.replace(\"__NATIVE_BLOCK__\", WINDOWS_SCRIPT_PREFIX_NATIVE)\n\t\t\t: WINDOWS_SCRIPT.replace(\"__NATIVE_BLOCK__\", \"\");\n\t\tfiles[\"install.ps1\"] = script;\n\t\treturn files;\n\t}\n\n\tconst isMac = platform.startsWith(\"macos/\");\n\tconst baseScript = isMac ? MACOS_SCRIPT : LINUX_SCRIPT;\n\tconst prefix = hasNativeServices\n\t\t? isMac\n\t\t\t? MACOS_SCRIPT_PREFIX_NATIVE\n\t\t\t: LINUX_SCRIPT_PREFIX_NATIVE\n\t\t: \"\";\n\tconst script = baseScript.replace(\"__NATIVE_BLOCK__\", prefix);\n\tfiles[\"install.sh\"] = script;\n\treturn files;\n}\n"],"mappings":";AAOA,MAAM,6BAA6B;;;;;;;;AASnC,MAAM,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmErB,MAAM,6BAA6B;;;;;;;AAQnC,MAAM,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAsDrB,MAAM,+BAA+B;;;;;;;AAQrC,MAAM,iBAAiB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAyEvB,SAAgB,yBAAyB,SAA0D;CAClG,MAAM,EAAE,UAAU,sBAAsB;CACxC,MAAM,QAAgC,EAAE;AAExC,KAAI,aAAa,iBAAiB;AAIjC,QAAM,iBAHS,oBACZ,eAAe,QAAQ,oBAAoB,6BAA6B,GACxE,eAAe,QAAQ,oBAAoB,GAAG;AAEjD,SAAO;;CAGR,MAAM,QAAQ,SAAS,WAAW,SAAS;CAC3C,MAAM,aAAa,QAAQ,eAAe;CAC1C,MAAM,SAAS,oBACZ,QACC,6BACA,6BACD;AAEH,OAAM,gBADS,WAAW,QAAQ,oBAAoB,OAAO;AAE7D,QAAO"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { n as describe, r as it, t as globalExpect } from "../vi.2VT5v0um-
|
|
2
|
-
import {
|
|
1
|
+
import { n as describe, r as it, t as globalExpect } from "../vi.2VT5v0um-Qk6MgAnK.mjs";
|
|
2
|
+
import { generateBareMetalInstall } from "./bare-metal-install.mjs";
|
|
3
3
|
|
|
4
4
|
//#region src/generators/bare-metal-install.test.ts
|
|
5
5
|
describe("generateBareMetalInstall", () => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"caddy.d.mts","names":[],"sources":["../../src/generators/caddy.ts"],"
|
|
1
|
+
{"version":3,"file":"caddy.d.mts","names":[],"sources":["../../src/generators/caddy.ts"],"mappings":";;;;;AAYA;;;;;;;;iBAAgB,iBAAA,CAAkB,QAAA,EAAU,cAAA,EAAgB,MAAA"}
|
|
@@ -1,3 +1,77 @@
|
|
|
1
|
-
|
|
1
|
+
//#region src/generators/caddy.ts
|
|
2
|
+
/**
|
|
3
|
+
* Generates a Caddyfile with reverse proxy entries for each exposed service.
|
|
4
|
+
*
|
|
5
|
+
* Each service with exposed ports gets a subdomain route under the provided domain.
|
|
6
|
+
* Services without exposed ports are skipped.
|
|
7
|
+
*
|
|
8
|
+
* @param resolved - The resolved service configuration
|
|
9
|
+
* @param domain - The main domain for routing (e.g. "example.com")
|
|
10
|
+
* @returns The Caddyfile content as a string
|
|
11
|
+
*/
|
|
12
|
+
function generateCaddyfile(resolved, domain) {
|
|
13
|
+
const sections = [];
|
|
14
|
+
sections.push(`# ═══════════════════════════════════════════════════════════════════════════════
|
|
15
|
+
# OpenClaw Caddyfile — Auto-generated reverse proxy configuration
|
|
16
|
+
# Domain: ${domain}
|
|
17
|
+
# ═══════════════════════════════════════════════════════════════════════════════
|
|
2
18
|
|
|
3
|
-
|
|
19
|
+
{
|
|
20
|
+
# Global options
|
|
21
|
+
email admin@${domain}
|
|
22
|
+
acme_ca https://acme-v02.api.letsencrypt.org/directory
|
|
23
|
+
}
|
|
24
|
+
`);
|
|
25
|
+
for (const { definition } of resolved.services) {
|
|
26
|
+
if (definition.id === "caddy" || definition.id === "traefik") continue;
|
|
27
|
+
const exposedPorts = definition.ports.filter((p) => p.exposed);
|
|
28
|
+
if (exposedPorts.length === 0) continue;
|
|
29
|
+
const primaryPort = exposedPorts[0];
|
|
30
|
+
const subdomain = `${definition.id}.${domain}`;
|
|
31
|
+
const block = [
|
|
32
|
+
`# ${definition.icon} ${definition.name}`,
|
|
33
|
+
`# ${definition.description}`,
|
|
34
|
+
`${subdomain} {`,
|
|
35
|
+
` reverse_proxy ${definition.id}:${primaryPort.container} {`,
|
|
36
|
+
` header_up Host {host}`,
|
|
37
|
+
` header_up X-Real-IP {remote_host}`,
|
|
38
|
+
` header_up X-Forwarded-For {remote_host}`,
|
|
39
|
+
` header_up X-Forwarded-Proto {scheme}`,
|
|
40
|
+
` }`
|
|
41
|
+
];
|
|
42
|
+
if (definition.healthcheck) {
|
|
43
|
+
block.push("");
|
|
44
|
+
block.push(` # Health check`);
|
|
45
|
+
block.push(` handle /health {`);
|
|
46
|
+
block.push(` reverse_proxy ${definition.id}:${primaryPort.container}`);
|
|
47
|
+
block.push(` }`);
|
|
48
|
+
}
|
|
49
|
+
block.push(`}`);
|
|
50
|
+
block.push("");
|
|
51
|
+
for (let i = 1; i < exposedPorts.length; i++) {
|
|
52
|
+
const port = exposedPorts[i];
|
|
53
|
+
const portSubdomain = `${definition.id}-${port.description.toLowerCase().replace(/[^a-z0-9]+/g, "-").replace(/-+$/, "")}.${domain}`;
|
|
54
|
+
block.push(`# ${definition.name} — ${port.description}`);
|
|
55
|
+
block.push(`${portSubdomain} {`);
|
|
56
|
+
block.push(` reverse_proxy ${definition.id}:${port.container}`);
|
|
57
|
+
block.push(`}`);
|
|
58
|
+
block.push("");
|
|
59
|
+
}
|
|
60
|
+
sections.push(block.join("\n"));
|
|
61
|
+
}
|
|
62
|
+
sections.push(`# Root domain — serves the OpenClaw gateway
|
|
63
|
+
${domain} {
|
|
64
|
+
reverse_proxy openclaw:18789 {
|
|
65
|
+
header_up Host {host}
|
|
66
|
+
header_up X-Real-IP {remote_host}
|
|
67
|
+
header_up X-Forwarded-For {remote_host}
|
|
68
|
+
header_up X-Forwarded-Proto {scheme}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
`);
|
|
72
|
+
return sections.join("\n");
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
//#endregion
|
|
76
|
+
export { generateCaddyfile };
|
|
77
|
+
//# sourceMappingURL=caddy.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"caddy.mjs","names":[],"sources":["../../src/generators/caddy.ts"],"sourcesContent":["import type { ResolverOutput } from \"../types.js\";\n\n/**\n * Generates a Caddyfile with reverse proxy entries for each exposed service.\n *\n * Each service with exposed ports gets a subdomain route under the provided domain.\n * Services without exposed ports are skipped.\n *\n * @param resolved - The resolved service configuration\n * @param domain - The main domain for routing (e.g. \"example.com\")\n * @returns The Caddyfile content as a string\n */\nexport function generateCaddyfile(resolved: ResolverOutput, domain: string): string {\n\tconst sections: string[] = [];\n\n\t// ── Global Options ──────────────────────────────────────────────────────\n\n\tsections.push(`# ═══════════════════════════════════════════════════════════════════════════════\n# OpenClaw Caddyfile — Auto-generated reverse proxy configuration\n# Domain: ${domain}\n# ═══════════════════════════════════════════════════════════════════════════════\n\n{\n\t# Global options\n\temail admin@${domain}\n\tacme_ca https://acme-v02.api.letsencrypt.org/directory\n}\n`);\n\n\t// ── Per-Service Reverse Proxy Blocks ─────────────────────────────────────\n\n\tfor (const { definition } of resolved.services) {\n\t\t// Skip the proxy service itself\n\t\tif (definition.id === \"caddy\" || definition.id === \"traefik\") continue;\n\n\t\tconst exposedPorts = definition.ports.filter((p) => p.exposed);\n\t\tif (exposedPorts.length === 0) continue;\n\n\t\t// Use the first exposed port as the primary route target\n\t\tconst primaryPort = exposedPorts[0]!;\n\t\tconst subdomain = `${definition.id}.${domain}`;\n\n\t\tconst block = [\n\t\t\t`# ${definition.icon} ${definition.name}`,\n\t\t\t`# ${definition.description}`,\n\t\t\t`${subdomain} {`,\n\t\t\t`\treverse_proxy ${definition.id}:${primaryPort.container} {`,\n\t\t\t`\t\theader_up Host {host}`,\n\t\t\t`\t\theader_up X-Real-IP {remote_host}`,\n\t\t\t`\t\theader_up X-Forwarded-For {remote_host}`,\n\t\t\t`\t\theader_up X-Forwarded-Proto {scheme}`,\n\t\t\t`\t}`,\n\t\t];\n\n\t\t// Add health check if service has one\n\t\tif (definition.healthcheck) {\n\t\t\tblock.push(\"\");\n\t\t\tblock.push(`\t# Health check`);\n\t\t\tblock.push(`\thandle /health {`);\n\t\t\tblock.push(`\t\treverse_proxy ${definition.id}:${primaryPort.container}`);\n\t\t\tblock.push(`\t}`);\n\t\t}\n\n\t\tblock.push(`}`);\n\t\tblock.push(\"\");\n\n\t\t// If there are additional exposed ports, add them as separate entries\n\t\tfor (let i = 1; i < exposedPorts.length; i++) {\n\t\t\tconst port = exposedPorts[i]!;\n\t\t\tconst portSubdomain = `${definition.id}-${port.description\n\t\t\t\t.toLowerCase()\n\t\t\t\t.replace(/[^a-z0-9]+/g, \"-\")\n\t\t\t\t.replace(/-+$/, \"\")}.${domain}`;\n\n\t\t\tblock.push(`# ${definition.name} — ${port.description}`);\n\t\t\tblock.push(`${portSubdomain} {`);\n\t\t\tblock.push(`\treverse_proxy ${definition.id}:${port.container}`);\n\t\t\tblock.push(`}`);\n\t\t\tblock.push(\"\");\n\t\t}\n\n\t\tsections.push(block.join(\"\\n\"));\n\t}\n\n\t// ── Fallback / Root Domain ──────────────────────────────────────────────\n\n\tsections.push(`# Root domain — serves the OpenClaw gateway\n${domain} {\n\treverse_proxy openclaw:18789 {\n\t\theader_up Host {host}\n\t\theader_up X-Real-IP {remote_host}\n\t\theader_up X-Forwarded-For {remote_host}\n\t\theader_up X-Forwarded-Proto {scheme}\n\t}\n}\n`);\n\n\treturn sections.join(\"\\n\");\n}\n"],"mappings":";;;;;;;;;;;AAYA,SAAgB,kBAAkB,UAA0B,QAAwB;CACnF,MAAM,WAAqB,EAAE;AAI7B,UAAS,KAAK;;YAEH,OAAO;;;;;eAKJ,OAAO;;;EAGpB;AAID,MAAK,MAAM,EAAE,gBAAgB,SAAS,UAAU;AAE/C,MAAI,WAAW,OAAO,WAAW,WAAW,OAAO,UAAW;EAE9D,MAAM,eAAe,WAAW,MAAM,QAAQ,MAAM,EAAE,QAAQ;AAC9D,MAAI,aAAa,WAAW,EAAG;EAG/B,MAAM,cAAc,aAAa;EACjC,MAAM,YAAY,GAAG,WAAW,GAAG,GAAG;EAEtC,MAAM,QAAQ;GACb,KAAK,WAAW,KAAK,GAAG,WAAW;GACnC,KAAK,WAAW;GAChB,GAAG,UAAU;GACb,kBAAkB,WAAW,GAAG,GAAG,YAAY,UAAU;GACzD;GACA;GACA;GACA;GACA;GACA;AAGD,MAAI,WAAW,aAAa;AAC3B,SAAM,KAAK,GAAG;AACd,SAAM,KAAK,kBAAkB;AAC7B,SAAM,KAAK,oBAAoB;AAC/B,SAAM,KAAK,mBAAmB,WAAW,GAAG,GAAG,YAAY,YAAY;AACvE,SAAM,KAAK,KAAK;;AAGjB,QAAM,KAAK,IAAI;AACf,QAAM,KAAK,GAAG;AAGd,OAAK,IAAI,IAAI,GAAG,IAAI,aAAa,QAAQ,KAAK;GAC7C,MAAM,OAAO,aAAa;GAC1B,MAAM,gBAAgB,GAAG,WAAW,GAAG,GAAG,KAAK,YAC7C,aAAa,CACb,QAAQ,eAAe,IAAI,CAC3B,QAAQ,OAAO,GAAG,CAAC,GAAG;AAExB,SAAM,KAAK,KAAK,WAAW,KAAK,KAAK,KAAK,cAAc;AACxD,SAAM,KAAK,GAAG,cAAc,IAAI;AAChC,SAAM,KAAK,kBAAkB,WAAW,GAAG,GAAG,KAAK,YAAY;AAC/D,SAAM,KAAK,IAAI;AACf,SAAM,KAAK,GAAG;;AAGf,WAAS,KAAK,MAAM,KAAK,KAAK,CAAC;;AAKhC,UAAS,KAAK;EACb,OAAO;;;;;;;;EAQP;AAED,QAAO,SAAS,KAAK,KAAK"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"env.d.mts","names":[],"sources":["../../src/generators/env.ts"],"
|
|
1
|
+
{"version":3,"file":"env.d.mts","names":[],"sources":["../../src/generators/env.ts"],"mappings":";;;;;AAOA;UAAiB,mBAAA;EAChB,eAAA;EACA,MAAA;EACA,eAAA;EADA;EAGA,gBAAA,GAAmB,GAAA;AAAA;;;;AASpB;;;iBAAgB,gBAAA,CACf,QAAA,EAAU,cAAA,EACV,OAAA,EAAS,mBAAA;EACL,UAAA;EAAoB,GAAA;AAAA;AAAA,UAkSR,WAAA;EAChB,WAAA;EACA,WAAA;EACA,SAAA;EACA,IAAA;IACC,GAAA;IACA,WAAA;IACA,MAAA;IACA,QAAA;IACA,YAAA;EAAA;AAAA;;;;;;;;iBAWc,oBAAA,CAAqB,QAAA,EAAU,cAAA,GAAiB,WAAA"}
|
package/dist/generators/env.mjs
CHANGED
|
@@ -1,3 +1,250 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { getDbRequirements } from "./postgres-init.mjs";
|
|
2
|
+
import { randomBytes } from "node:crypto";
|
|
2
3
|
|
|
3
|
-
|
|
4
|
+
//#region src/generators/env.ts
|
|
5
|
+
/**
|
|
6
|
+
* Generates `.env.example` and `.env` file contents from resolved services.
|
|
7
|
+
*
|
|
8
|
+
* - `.env.example`: every env var with descriptive comments, placeholders for secrets
|
|
9
|
+
* - `.env`: same vars but secrets filled with cryptographically random values when generateSecrets is true
|
|
10
|
+
*/
|
|
11
|
+
function generateEnvFiles(resolved, options) {
|
|
12
|
+
const version = options.openclawVersion ?? "latest";
|
|
13
|
+
const lines = [];
|
|
14
|
+
lines.push({
|
|
15
|
+
comment: formatComment("OpenClaw version to deploy", "OpenClaw Core", true, false),
|
|
16
|
+
key: "OPENCLAW_VERSION",
|
|
17
|
+
exampleValue: version,
|
|
18
|
+
actualValue: version
|
|
19
|
+
});
|
|
20
|
+
const gatewayToken = options.generateSecrets ? randomBytes(24).toString("hex") : "";
|
|
21
|
+
lines.push({
|
|
22
|
+
comment: formatComment("Authentication token for the OpenClaw gateway API", "OpenClaw Core", true, true),
|
|
23
|
+
key: "OPENCLAW_GATEWAY_TOKEN",
|
|
24
|
+
exampleValue: "your_gateway_token_here",
|
|
25
|
+
actualValue: gatewayToken
|
|
26
|
+
});
|
|
27
|
+
lines.push({
|
|
28
|
+
comment: formatComment("Port the OpenClaw gateway listens on", "OpenClaw Core", true, false),
|
|
29
|
+
key: "OPENCLAW_GATEWAY_PORT",
|
|
30
|
+
exampleValue: "18789",
|
|
31
|
+
actualValue: "18789"
|
|
32
|
+
});
|
|
33
|
+
lines.push({
|
|
34
|
+
comment: formatComment("Port for the OpenClaw ACP bridge (WebSocket)", "OpenClaw Core", false, false),
|
|
35
|
+
key: "OPENCLAW_BRIDGE_PORT",
|
|
36
|
+
exampleValue: "18790",
|
|
37
|
+
actualValue: "18790"
|
|
38
|
+
});
|
|
39
|
+
lines.push({
|
|
40
|
+
comment: formatComment("Gateway network bind mode (lan for Docker networking, loopback for local-only)", "OpenClaw Core", false, false),
|
|
41
|
+
key: "OPENCLAW_GATEWAY_BIND",
|
|
42
|
+
exampleValue: "lan",
|
|
43
|
+
actualValue: "lan"
|
|
44
|
+
});
|
|
45
|
+
lines.push({
|
|
46
|
+
comment: formatComment("Host path to OpenClaw configuration directory", "OpenClaw Core", true, false),
|
|
47
|
+
key: "OPENCLAW_CONFIG_DIR",
|
|
48
|
+
exampleValue: "./openclaw/config",
|
|
49
|
+
actualValue: "./openclaw/config"
|
|
50
|
+
});
|
|
51
|
+
lines.push({
|
|
52
|
+
comment: formatComment("Host path to OpenClaw workspace directory", "OpenClaw Core", true, false),
|
|
53
|
+
key: "OPENCLAW_WORKSPACE_DIR",
|
|
54
|
+
exampleValue: "./openclaw/workspace",
|
|
55
|
+
actualValue: "./openclaw/workspace"
|
|
56
|
+
});
|
|
57
|
+
lines.push({
|
|
58
|
+
comment: formatComment("OpenClaw Docker image override (default uses ghcr.io/openclaw/openclaw)", "OpenClaw Core", false, false),
|
|
59
|
+
key: "OPENCLAW_IMAGE",
|
|
60
|
+
exampleValue: "",
|
|
61
|
+
actualValue: ""
|
|
62
|
+
});
|
|
63
|
+
if (options.domain) lines.push({
|
|
64
|
+
comment: formatComment("Primary domain for service routing", "OpenClaw Core", false, false),
|
|
65
|
+
key: "OPENCLAW_DOMAIN",
|
|
66
|
+
exampleValue: "example.com",
|
|
67
|
+
actualValue: options.domain
|
|
68
|
+
});
|
|
69
|
+
lines.push({
|
|
70
|
+
comment: "\n# ═══════════════════════════════════════════════════════════════════════════════\n# Claude Web Provider (optional)\n# ═══════════════════════════════════════════════════════════════════════════════",
|
|
71
|
+
key: "",
|
|
72
|
+
exampleValue: "",
|
|
73
|
+
actualValue: ""
|
|
74
|
+
});
|
|
75
|
+
lines.push({
|
|
76
|
+
comment: formatComment("Claude AI session key for web provider authentication", "OpenClaw Core", false, true),
|
|
77
|
+
key: "CLAUDE_AI_SESSION_KEY",
|
|
78
|
+
exampleValue: "your_claude_ai_session_key_here",
|
|
79
|
+
actualValue: ""
|
|
80
|
+
});
|
|
81
|
+
lines.push({
|
|
82
|
+
comment: formatComment("Claude web session key for web provider authentication", "OpenClaw Core", false, true),
|
|
83
|
+
key: "CLAUDE_WEB_SESSION_KEY",
|
|
84
|
+
exampleValue: "your_claude_web_session_key_here",
|
|
85
|
+
actualValue: ""
|
|
86
|
+
});
|
|
87
|
+
lines.push({
|
|
88
|
+
comment: formatComment("Claude web cookie for web provider authentication", "OpenClaw Core", false, true),
|
|
89
|
+
key: "CLAUDE_WEB_COOKIE",
|
|
90
|
+
exampleValue: "your_claude_web_cookie_here",
|
|
91
|
+
actualValue: ""
|
|
92
|
+
});
|
|
93
|
+
const dbReqs = getDbRequirements(resolved);
|
|
94
|
+
if (dbReqs.length > 0) {
|
|
95
|
+
lines.push({
|
|
96
|
+
comment: "\n# ═══════════════════════════════════════════════════════════════════════════════\n# Per-Service Database Passwords\n# Each service gets its own PostgreSQL database and credentials\n# ═══════════════════════════════════════════════════════════════════════════════",
|
|
97
|
+
key: "",
|
|
98
|
+
exampleValue: "",
|
|
99
|
+
actualValue: ""
|
|
100
|
+
});
|
|
101
|
+
for (const req of dbReqs) {
|
|
102
|
+
const secretValue = options.generateSecrets ? randomBytes(24).toString("hex") : "";
|
|
103
|
+
lines.push({
|
|
104
|
+
comment: formatComment(`PostgreSQL password for ${req.serviceName} (database: ${req.dbName}, user: ${req.dbUser})`, req.serviceName, true, true),
|
|
105
|
+
key: req.passwordEnvVar,
|
|
106
|
+
exampleValue: `your_${req.passwordEnvVar.toLowerCase()}_here`,
|
|
107
|
+
actualValue: secretValue
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
const dbPasswordKeys = dbReqs.map((r) => r.passwordEnvVar);
|
|
112
|
+
const seenKeys = new Set([
|
|
113
|
+
"OPENCLAW_VERSION",
|
|
114
|
+
"OPENCLAW_GATEWAY_TOKEN",
|
|
115
|
+
"OPENCLAW_GATEWAY_PORT",
|
|
116
|
+
"OPENCLAW_BRIDGE_PORT",
|
|
117
|
+
"OPENCLAW_GATEWAY_BIND",
|
|
118
|
+
"OPENCLAW_CONFIG_DIR",
|
|
119
|
+
"OPENCLAW_WORKSPACE_DIR",
|
|
120
|
+
"OPENCLAW_IMAGE",
|
|
121
|
+
"OPENCLAW_DOMAIN",
|
|
122
|
+
"CLAUDE_AI_SESSION_KEY",
|
|
123
|
+
"CLAUDE_WEB_SESSION_KEY",
|
|
124
|
+
"CLAUDE_WEB_COOKIE",
|
|
125
|
+
...dbPasswordKeys
|
|
126
|
+
]);
|
|
127
|
+
for (const { definition } of resolved.services) {
|
|
128
|
+
const allEnvVars = [...definition.environment, ...definition.openclawEnvVars];
|
|
129
|
+
if (allEnvVars.length === 0) continue;
|
|
130
|
+
lines.push({
|
|
131
|
+
comment: `\n# ═══════════════════════════════════════════════════════════════════════════════\n# ${definition.icon} ${definition.name}\n# ═══════════════════════════════════════════════════════════════════════════════`,
|
|
132
|
+
key: "",
|
|
133
|
+
exampleValue: "",
|
|
134
|
+
actualValue: ""
|
|
135
|
+
});
|
|
136
|
+
const isNative = options.nativeServiceIds?.has(definition.id);
|
|
137
|
+
for (const envVar of allEnvVars) {
|
|
138
|
+
if (seenKeys.has(envVar.key)) continue;
|
|
139
|
+
seenKeys.add(envVar.key);
|
|
140
|
+
const secretValue = options.generateSecrets ? randomBytes(24).toString("hex") : "";
|
|
141
|
+
const isHostVar = envVar.key.endsWith("_HOST");
|
|
142
|
+
const hostValue = isNative && isHostVar ? "host.docker.internal" : null;
|
|
143
|
+
const exampleValue = hostValue ? hostValue : envVar.secret ? `your_${envVar.key.toLowerCase()}_here` : envVar.defaultValue;
|
|
144
|
+
let actualValue;
|
|
145
|
+
if (hostValue) actualValue = hostValue;
|
|
146
|
+
else if (envVar.secret) actualValue = envVar.defaultValue.startsWith("${") ? envVar.defaultValue : secretValue;
|
|
147
|
+
else actualValue = envVar.defaultValue;
|
|
148
|
+
lines.push({
|
|
149
|
+
comment: formatComment(envVar.description, definition.name, envVar.required, envVar.secret),
|
|
150
|
+
key: envVar.key,
|
|
151
|
+
exampleValue,
|
|
152
|
+
actualValue
|
|
153
|
+
});
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
const header = [
|
|
157
|
+
"# ═══════════════════════════════════════════════════════════════════════════════",
|
|
158
|
+
"# OpenClaw Environment Configuration",
|
|
159
|
+
`# Generated at ${(/* @__PURE__ */ new Date()).toISOString()}`,
|
|
160
|
+
"# ═══════════════════════════════════════════════════════════════════════════════",
|
|
161
|
+
""
|
|
162
|
+
].join("\n");
|
|
163
|
+
let envExample = header;
|
|
164
|
+
let env = header;
|
|
165
|
+
for (const line of lines) if (line.key === "") {
|
|
166
|
+
envExample += `${line.comment}\n`;
|
|
167
|
+
env += `${line.comment}\n`;
|
|
168
|
+
} else {
|
|
169
|
+
envExample += `${line.comment}\n${line.key}=${line.exampleValue}\n\n`;
|
|
170
|
+
env += `${line.comment}\n${line.key}=${line.actualValue}\n\n`;
|
|
171
|
+
}
|
|
172
|
+
return {
|
|
173
|
+
envExample,
|
|
174
|
+
env
|
|
175
|
+
};
|
|
176
|
+
}
|
|
177
|
+
/**
|
|
178
|
+
* Format a descriptive comment block for an environment variable.
|
|
179
|
+
*/
|
|
180
|
+
function formatComment(description, serviceName, required, secret) {
|
|
181
|
+
return [`# ${description}`, `# Service: ${serviceName} | Required: ${required ? "Yes" : "No"} | Secret: ${secret ? "Yes" : "No"}`].join("\n");
|
|
182
|
+
}
|
|
183
|
+
/**
|
|
184
|
+
* Returns environment variables grouped by service, suitable for UI rendering.
|
|
185
|
+
*
|
|
186
|
+
* - First group is always "OpenClaw Core" with base variables.
|
|
187
|
+
* - Subsequent groups correspond to each resolved service.
|
|
188
|
+
* - Variables are deduplicated across groups (first occurrence wins).
|
|
189
|
+
*/
|
|
190
|
+
function getStructuredEnvVars(resolved) {
|
|
191
|
+
const groups = [];
|
|
192
|
+
const seenKeys = /* @__PURE__ */ new Set();
|
|
193
|
+
const coreVars = [
|
|
194
|
+
{
|
|
195
|
+
key: "OPENCLAW_VERSION",
|
|
196
|
+
description: "OpenClaw version to deploy",
|
|
197
|
+
secret: false,
|
|
198
|
+
required: true,
|
|
199
|
+
defaultValue: "latest"
|
|
200
|
+
},
|
|
201
|
+
{
|
|
202
|
+
key: "OPENCLAW_GATEWAY_TOKEN",
|
|
203
|
+
description: "Authentication token for the OpenClaw gateway API",
|
|
204
|
+
secret: true,
|
|
205
|
+
required: true,
|
|
206
|
+
defaultValue: ""
|
|
207
|
+
},
|
|
208
|
+
{
|
|
209
|
+
key: "OPENCLAW_GATEWAY_PORT",
|
|
210
|
+
description: "Port the OpenClaw gateway listens on",
|
|
211
|
+
secret: false,
|
|
212
|
+
required: true,
|
|
213
|
+
defaultValue: "18789"
|
|
214
|
+
}
|
|
215
|
+
];
|
|
216
|
+
for (const v of coreVars) seenKeys.add(v.key);
|
|
217
|
+
groups.push({
|
|
218
|
+
serviceName: "OpenClaw Core",
|
|
219
|
+
serviceIcon: "⚙️",
|
|
220
|
+
serviceId: "openclaw-core",
|
|
221
|
+
vars: coreVars
|
|
222
|
+
});
|
|
223
|
+
for (const { definition } of resolved.services) {
|
|
224
|
+
const allEnvVars = [...definition.environment, ...definition.openclawEnvVars];
|
|
225
|
+
const vars = [];
|
|
226
|
+
for (const envVar of allEnvVars) {
|
|
227
|
+
if (seenKeys.has(envVar.key)) continue;
|
|
228
|
+
seenKeys.add(envVar.key);
|
|
229
|
+
vars.push({
|
|
230
|
+
key: envVar.key,
|
|
231
|
+
description: envVar.description,
|
|
232
|
+
secret: envVar.secret,
|
|
233
|
+
required: envVar.required,
|
|
234
|
+
defaultValue: envVar.defaultValue
|
|
235
|
+
});
|
|
236
|
+
}
|
|
237
|
+
if (vars.length === 0) continue;
|
|
238
|
+
groups.push({
|
|
239
|
+
serviceName: definition.name,
|
|
240
|
+
serviceIcon: definition.icon,
|
|
241
|
+
serviceId: definition.id,
|
|
242
|
+
vars
|
|
243
|
+
});
|
|
244
|
+
}
|
|
245
|
+
return groups;
|
|
246
|
+
}
|
|
247
|
+
|
|
248
|
+
//#endregion
|
|
249
|
+
export { generateEnvFiles, getStructuredEnvVars };
|
|
250
|
+
//# sourceMappingURL=env.mjs.map
|