@better-openclaw/core 1.0.4 → 1.0.6
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 +32 -33
- package/dist/anything-llm-DIIPhz6K.mjs +44 -0
- package/dist/anything-llm-DIIPhz6K.mjs.map +1 -0
- package/dist/appflowy-DdoE-dKg.mjs +45 -0
- package/dist/appflowy-DdoE-dKg.mjs.map +1 -0
- package/dist/bare-metal-install-DpYZDoGq.mjs +224 -0
- package/dist/bare-metal-install-DpYZDoGq.mjs.map +1 -0
- package/dist/bare-metal-partition-CYlOxf9B.mjs +48 -0
- package/dist/bare-metal-partition-CYlOxf9B.mjs.map +1 -0
- package/dist/bare-metal-partition.d.mts +27 -0
- package/dist/bare-metal-partition.d.mts.map +1 -0
- package/dist/bare-metal-partition.mjs +3 -0
- package/dist/bare-metal-partition.test.d.mts +1 -0
- package/dist/bare-metal-partition.test.mjs +58 -0
- package/dist/bare-metal-partition.test.mjs.map +1 -0
- package/dist/beszel-DHAG1zl0.mjs +45 -0
- package/dist/beszel-DHAG1zl0.mjs.map +1 -0
- package/dist/browserless-gUuvGmMD.mjs +85 -0
- package/dist/browserless-gUuvGmMD.mjs.map +1 -0
- package/dist/caddy-BJDrqnmw.mjs +77 -0
- package/dist/caddy-BJDrqnmw.mjs.map +1 -0
- package/dist/caddy-_NIdWKrf.mjs +52 -0
- package/dist/caddy-_NIdWKrf.mjs.map +1 -0
- package/dist/chromadb-g4rIsfAl.mjs +63 -0
- package/dist/chromadb-g4rIsfAl.mjs.map +1 -0
- package/dist/claude-code-DPRA1fy_.mjs +52 -0
- package/dist/claude-code-DPRA1fy_.mjs.map +1 -0
- package/dist/code-server-BdZZxxm5.mjs +66 -0
- package/dist/code-server-BdZZxxm5.mjs.map +1 -0
- package/dist/codex-DFVzfrfX.mjs +45 -0
- package/dist/codex-DFVzfrfX.mjs.map +1 -0
- package/dist/composer-CSM5YycB.mjs +287 -0
- package/dist/composer-CSM5YycB.mjs.map +1 -0
- package/dist/composer.d.mts +22 -0
- package/dist/composer.d.mts.map +1 -0
- package/dist/composer.mjs +3 -0
- package/dist/composer.snapshot.test.d.mts +1 -0
- package/dist/composer.snapshot.test.mjs +92 -0
- package/dist/composer.snapshot.test.mjs.map +1 -0
- package/dist/composer.test.d.mts +1 -0
- package/dist/composer.test.mjs +166 -0
- package/dist/composer.test.mjs.map +1 -0
- package/dist/coolify-Z5_zDgM3.mjs +49 -0
- package/dist/coolify-Z5_zDgM3.mjs.map +1 -0
- package/dist/definitions-BXpb1kzs.mjs +138 -0
- package/dist/definitions-BXpb1kzs.mjs.map +1 -0
- package/dist/dify-jDc9U6Ku.mjs +81 -0
- package/dist/dify-jDc9U6Ku.mjs.map +1 -0
- package/dist/docsgpt-BXM1c2JC.mjs +45 -0
- package/dist/docsgpt-BXM1c2JC.mjs.map +1 -0
- package/dist/dokploy-Ci8_fb0_.mjs +49 -0
- package/dist/dokploy-Ci8_fb0_.mjs.map +1 -0
- package/dist/dozzle-fAt2sLRL.mjs +41 -0
- package/dist/dozzle-fAt2sLRL.mjs.map +1 -0
- package/dist/env-D2h46lHT.mjs +250 -0
- package/dist/env-D2h46lHT.mjs.map +1 -0
- package/dist/ffmpeg-BCtnA8m_.mjs +66 -0
- package/dist/ffmpeg-BCtnA8m_.mjs.map +1 -0
- package/dist/flowise-CJTTBa7J.mjs +45 -0
- package/dist/flowise-CJTTBa7J.mjs.map +1 -0
- package/dist/gemini-cli-Bfwv6hYe.mjs +46 -0
- package/dist/gemini-cli-Bfwv6hYe.mjs.map +1 -0
- package/dist/generate.d.mts +13 -0
- package/dist/generate.d.mts.map +1 -0
- package/dist/generate.mjs +169 -0
- package/dist/generate.mjs.map +1 -0
- package/dist/generate.test.d.mts +1 -0
- package/dist/generate.test.mjs +283 -0
- package/dist/generate.test.mjs.map +1 -0
- package/dist/generators/bare-metal-install.d.mts +19 -0
- package/dist/generators/bare-metal-install.d.mts.map +1 -0
- package/dist/generators/bare-metal-install.mjs +3 -0
- package/dist/generators/bare-metal-install.test.d.mts +1 -0
- package/dist/generators/bare-metal-install.test.mjs +48 -0
- package/dist/generators/bare-metal-install.test.mjs.map +1 -0
- package/dist/generators/caddy.d.mts +19 -0
- package/dist/generators/caddy.d.mts.map +1 -0
- package/dist/generators/caddy.mjs +3 -0
- package/dist/generators/env.d.mts +47 -0
- package/dist/generators/env.d.mts.map +1 -0
- package/dist/generators/env.mjs +3 -0
- package/dist/generators/grafana.d.mts +22 -0
- package/dist/generators/grafana.d.mts.map +1 -0
- package/dist/generators/grafana.mjs +3 -0
- package/dist/generators/n8n-workflows.d.mts +13 -0
- package/dist/generators/n8n-workflows.d.mts.map +1 -0
- package/dist/generators/n8n-workflows.mjs +3 -0
- package/dist/generators/native-services.d.mts +18 -0
- package/dist/generators/native-services.d.mts.map +1 -0
- package/dist/generators/native-services.mjs +3 -0
- package/dist/generators/postgres-init.d.mts +31 -0
- package/dist/generators/postgres-init.d.mts.map +1 -0
- package/dist/generators/postgres-init.mjs +3 -0
- package/dist/generators/prometheus.d.mts +16 -0
- package/dist/generators/prometheus.d.mts.map +1 -0
- package/dist/generators/prometheus.mjs +3 -0
- package/dist/generators/readme.d.mts +26 -0
- package/dist/generators/readme.d.mts.map +1 -0
- package/dist/generators/readme.mjs +3 -0
- package/dist/generators/scripts.d.mts +10 -0
- package/dist/generators/scripts.d.mts.map +1 -0
- package/dist/generators/scripts.mjs +3 -0
- package/dist/generators/skills.d.mts +16 -0
- package/dist/generators/skills.d.mts.map +1 -0
- package/dist/generators/skills.mjs +3 -0
- package/dist/gitea-BGkqa-sD.mjs +49 -0
- package/dist/gitea-BGkqa-sD.mjs.map +1 -0
- package/dist/gotify-D7p8oNM3.mjs +62 -0
- package/dist/gotify-D7p8oNM3.mjs.map +1 -0
- package/dist/grafana-BlnWc6js.mjs +63 -0
- package/dist/grafana-BlnWc6js.mjs.map +1 -0
- package/dist/grafana-D3kIm8RX.mjs +293 -0
- package/dist/grafana-D3kIm8RX.mjs.map +1 -0
- package/dist/index.d.mts +21 -0
- package/dist/index.mjs +22 -0
- package/dist/kimi-BFu1v1sU.mjs +46 -0
- package/dist/kimi-BFu1v1sU.mjs.map +1 -0
- package/dist/lasuite-meet-agents-nlPhMEaN.mjs +36 -0
- package/dist/lasuite-meet-agents-nlPhMEaN.mjs.map +1 -0
- package/dist/lasuite-meet-backend-9H7rZ8Pc.mjs +134 -0
- package/dist/lasuite-meet-backend-9H7rZ8Pc.mjs.map +1 -0
- package/dist/lasuite-meet-frontend-B4xNbnBa.mjs +48 -0
- package/dist/lasuite-meet-frontend-B4xNbnBa.mjs.map +1 -0
- package/dist/librechat-CoPIHXKK.mjs +50 -0
- package/dist/librechat-CoPIHXKK.mjs.map +1 -0
- package/dist/lightpanda-QchAPgNX.mjs +59 -0
- package/dist/lightpanda-QchAPgNX.mjs.map +1 -0
- package/dist/litellm-Dgl6iTry.mjs +47 -0
- package/dist/litellm-Dgl6iTry.mjs.map +1 -0
- package/dist/livekit-C13SxlVB.mjs +56 -0
- package/dist/livekit-C13SxlVB.mjs.map +1 -0
- package/dist/magic-string.es-Dew0Rnsa.mjs +1014 -0
- package/dist/magic-string.es-Dew0Rnsa.mjs.map +1 -0
- package/dist/matomo-CiOoggYl.mjs +80 -0
- package/dist/matomo-CiOoggYl.mjs.map +1 -0
- package/dist/matrix-synapse-CP20A7NN.mjs +88 -0
- package/dist/matrix-synapse-CP20A7NN.mjs.map +1 -0
- package/dist/mattermost-CeFVuhIr.mjs +61 -0
- package/dist/mattermost-CeFVuhIr.mjs.map +1 -0
- package/dist/meilisearch-CLiQiTdN.mjs +78 -0
- package/dist/meilisearch-CLiQiTdN.mjs.map +1 -0
- package/dist/minio-_QuguAeo.mjs +102 -0
- package/dist/minio-_QuguAeo.mjs.map +1 -0
- package/dist/mixpost-eSFPM9XK.mjs +87 -0
- package/dist/mixpost-eSFPM9XK.mjs.map +1 -0
- package/dist/motion-canvas-Bk1ruvuX.mjs +52 -0
- package/dist/motion-canvas-Bk1ruvuX.mjs.map +1 -0
- package/dist/n8n-W5qeU34C.mjs +154 -0
- package/dist/n8n-W5qeU34C.mjs.map +1 -0
- package/dist/n8n-workflows-BPmKVx8z.mjs +75 -0
- package/dist/n8n-workflows-BPmKVx8z.mjs.map +1 -0
- package/dist/native-services-CwOCM-Xz.mjs +78 -0
- package/dist/native-services-CwOCM-Xz.mjs.map +1 -0
- package/dist/nocodb-DQNbSYh_.mjs +45 -0
- package/dist/nocodb-DQNbSYh_.mjs.map +1 -0
- package/dist/ntfy-B8_cZAx2.mjs +63 -0
- package/dist/ntfy-B8_cZAx2.mjs.map +1 -0
- package/dist/ollama-BiKAypcO.mjs +66 -0
- package/dist/ollama-BiKAypcO.mjs.map +1 -0
- package/dist/open-webui-DZOG4_xL.mjs +50 -0
- package/dist/open-webui-DZOG4_xL.mjs.map +1 -0
- package/dist/opencode-Dvfh5KvA.mjs +50 -0
- package/dist/opencode-Dvfh5KvA.mjs.map +1 -0
- package/dist/openpanel-BuWHhDze.mjs +46 -0
- package/dist/openpanel-BuWHhDze.mjs.map +1 -0
- package/dist/outline-Dy-YzdYS.mjs +74 -0
- package/dist/outline-Dy-YzdYS.mjs.map +1 -0
- package/dist/paperless-ngx-DVtWWpKg.mjs +93 -0
- package/dist/paperless-ngx-DVtWWpKg.mjs.map +1 -0
- package/dist/playwright-server-Boiz8--G.mjs +42 -0
- package/dist/playwright-server-Boiz8--G.mjs.map +1 -0
- package/dist/portainer-D9MU96UI.mjs +49 -0
- package/dist/portainer-D9MU96UI.mjs.map +1 -0
- package/dist/postgres-init-BiM-xZtq.mjs +151 -0
- package/dist/postgres-init-BiM-xZtq.mjs.map +1 -0
- package/dist/postgresql-s65Z9RqR.mjs +84 -0
- package/dist/postgresql-s65Z9RqR.mjs.map +1 -0
- package/dist/postiz-U6EK23EY.mjs +83 -0
- package/dist/postiz-U6EK23EY.mjs.map +1 -0
- package/dist/presets/registry.d.mts +10 -0
- package/dist/presets/registry.d.mts.map +1 -0
- package/dist/presets/registry.mjs +159 -0
- package/dist/presets/registry.mjs.map +1 -0
- package/dist/presets/registry.test.d.mts +1 -0
- package/dist/presets/registry.test.mjs +34 -0
- package/dist/presets/registry.test.mjs.map +1 -0
- package/dist/prometheus-WOlk-a1G.mjs +107 -0
- package/dist/prometheus-WOlk-a1G.mjs.map +1 -0
- package/dist/prometheus-x901F67p.mjs +52 -0
- package/dist/prometheus-x901F67p.mjs.map +1 -0
- package/dist/qdrant-DZW9uW4e.mjs +77 -0
- package/dist/qdrant-DZW9uW4e.mjs.map +1 -0
- package/dist/readme-C7M3QE9a.mjs +199 -0
- package/dist/readme-C7M3QE9a.mjs.map +1 -0
- package/dist/redis-DPMOf237.mjs +91 -0
- package/dist/redis-DPMOf237.mjs.map +1 -0
- package/dist/registry-CqLarEm5.mjs +30 -0
- package/dist/registry-CqLarEm5.mjs.map +1 -0
- package/dist/registry-DLX9Q4VQ.mjs +215 -0
- package/dist/registry-DLX9Q4VQ.mjs.map +1 -0
- package/dist/remotion-COkr0wpr.mjs +55 -0
- package/dist/remotion-COkr0wpr.mjs.map +1 -0
- package/dist/resolver-Dl5clk-d.mjs +194 -0
- package/dist/resolver-Dl5clk-d.mjs.map +1 -0
- package/dist/resolver.d.mts +23 -0
- package/dist/resolver.d.mts.map +1 -0
- package/dist/resolver.mjs +3 -0
- package/dist/resolver.test.d.mts +1 -0
- package/dist/resolver.test.mjs +237 -0
- package/dist/resolver.test.mjs.map +1 -0
- package/dist/rocketchat-BebQT1MZ.mjs +57 -0
- package/dist/rocketchat-BebQT1MZ.mjs.map +1 -0
- package/dist/schema-PSUY6yJU.d.mts +700 -0
- package/dist/schema-PSUY6yJU.d.mts.map +1 -0
- package/dist/schema.d.mts +2 -0
- package/dist/schema.mjs +258 -0
- package/dist/schema.mjs.map +1 -0
- package/dist/schema.test.d.mts +1 -0
- package/dist/schema.test.mjs +264 -0
- package/dist/schema.test.mjs.map +1 -0
- package/dist/scripts-DsljWbP4.mjs +351 -0
- package/dist/scripts-DsljWbP4.mjs.map +1 -0
- package/dist/searxng-tJpBkchC.mjs +65 -0
- package/dist/searxng-tJpBkchC.mjs.map +1 -0
- package/dist/services/definitions/anything-llm.d.mts +8 -0
- package/dist/services/definitions/anything-llm.d.mts.map +1 -0
- package/dist/services/definitions/anything-llm.mjs +3 -0
- package/dist/services/definitions/appflowy.d.mts +8 -0
- package/dist/services/definitions/appflowy.d.mts.map +1 -0
- package/dist/services/definitions/appflowy.mjs +3 -0
- package/dist/services/definitions/beszel.d.mts +8 -0
- package/dist/services/definitions/beszel.d.mts.map +1 -0
- package/dist/services/definitions/beszel.mjs +3 -0
- package/dist/services/definitions/browserless.d.mts +8 -0
- package/dist/services/definitions/browserless.d.mts.map +1 -0
- package/dist/services/definitions/browserless.mjs +3 -0
- package/dist/services/definitions/caddy.d.mts +8 -0
- package/dist/services/definitions/caddy.d.mts.map +1 -0
- package/dist/services/definitions/caddy.mjs +3 -0
- package/dist/services/definitions/chromadb.d.mts +8 -0
- package/dist/services/definitions/chromadb.d.mts.map +1 -0
- package/dist/services/definitions/chromadb.mjs +3 -0
- package/dist/services/definitions/claude-code.d.mts +8 -0
- package/dist/services/definitions/claude-code.d.mts.map +1 -0
- package/dist/services/definitions/claude-code.mjs +3 -0
- package/dist/services/definitions/code-server.d.mts +8 -0
- package/dist/services/definitions/code-server.d.mts.map +1 -0
- package/dist/services/definitions/code-server.mjs +3 -0
- package/dist/services/definitions/codex.d.mts +8 -0
- package/dist/services/definitions/codex.d.mts.map +1 -0
- package/dist/services/definitions/codex.mjs +3 -0
- package/dist/services/definitions/coolify.d.mts +8 -0
- package/dist/services/definitions/coolify.d.mts.map +1 -0
- package/dist/services/definitions/coolify.mjs +3 -0
- package/dist/services/definitions/dify.d.mts +8 -0
- package/dist/services/definitions/dify.d.mts.map +1 -0
- package/dist/services/definitions/dify.mjs +3 -0
- package/dist/services/definitions/docsgpt.d.mts +8 -0
- package/dist/services/definitions/docsgpt.d.mts.map +1 -0
- package/dist/services/definitions/docsgpt.mjs +3 -0
- package/dist/services/definitions/dokploy.d.mts +8 -0
- package/dist/services/definitions/dokploy.d.mts.map +1 -0
- package/dist/services/definitions/dokploy.mjs +3 -0
- package/dist/services/definitions/dozzle.d.mts +8 -0
- package/dist/services/definitions/dozzle.d.mts.map +1 -0
- package/dist/services/definitions/dozzle.mjs +3 -0
- package/dist/services/definitions/ffmpeg.d.mts +8 -0
- package/dist/services/definitions/ffmpeg.d.mts.map +1 -0
- package/dist/services/definitions/ffmpeg.mjs +3 -0
- package/dist/services/definitions/flowise.d.mts +8 -0
- package/dist/services/definitions/flowise.d.mts.map +1 -0
- package/dist/services/definitions/flowise.mjs +3 -0
- package/dist/services/definitions/gemini-cli.d.mts +8 -0
- package/dist/services/definitions/gemini-cli.d.mts.map +1 -0
- package/dist/services/definitions/gemini-cli.mjs +3 -0
- package/dist/services/definitions/gitea.d.mts +8 -0
- package/dist/services/definitions/gitea.d.mts.map +1 -0
- package/dist/services/definitions/gitea.mjs +3 -0
- package/dist/services/definitions/gotify.d.mts +8 -0
- package/dist/services/definitions/gotify.d.mts.map +1 -0
- package/dist/services/definitions/gotify.mjs +3 -0
- package/dist/services/definitions/grafana.d.mts +8 -0
- package/dist/services/definitions/grafana.d.mts.map +1 -0
- package/dist/services/definitions/grafana.mjs +3 -0
- package/dist/services/definitions/index.d.mts +73 -0
- package/dist/services/definitions/index.d.mts.map +1 -0
- package/dist/services/definitions/index.mjs +68 -0
- package/dist/services/definitions/kimi.d.mts +8 -0
- package/dist/services/definitions/kimi.d.mts.map +1 -0
- package/dist/services/definitions/kimi.mjs +3 -0
- package/dist/services/definitions/lasuite-meet-agents.d.mts +8 -0
- package/dist/services/definitions/lasuite-meet-agents.d.mts.map +1 -0
- package/dist/services/definitions/lasuite-meet-agents.mjs +3 -0
- package/dist/services/definitions/lasuite-meet-backend.d.mts +8 -0
- package/dist/services/definitions/lasuite-meet-backend.d.mts.map +1 -0
- package/dist/services/definitions/lasuite-meet-backend.mjs +3 -0
- package/dist/services/definitions/lasuite-meet-frontend.d.mts +8 -0
- package/dist/services/definitions/lasuite-meet-frontend.d.mts.map +1 -0
- package/dist/services/definitions/lasuite-meet-frontend.mjs +3 -0
- package/dist/services/definitions/librechat.d.mts +8 -0
- package/dist/services/definitions/librechat.d.mts.map +1 -0
- package/dist/services/definitions/librechat.mjs +3 -0
- package/dist/services/definitions/lightpanda.d.mts +8 -0
- package/dist/services/definitions/lightpanda.d.mts.map +1 -0
- package/dist/services/definitions/lightpanda.mjs +3 -0
- package/dist/services/definitions/litellm.d.mts +8 -0
- package/dist/services/definitions/litellm.d.mts.map +1 -0
- package/dist/services/definitions/litellm.mjs +3 -0
- package/dist/services/definitions/livekit.d.mts +8 -0
- package/dist/services/definitions/livekit.d.mts.map +1 -0
- package/dist/services/definitions/livekit.mjs +3 -0
- package/dist/services/definitions/matomo.d.mts +8 -0
- package/dist/services/definitions/matomo.d.mts.map +1 -0
- package/dist/services/definitions/matomo.mjs +3 -0
- package/dist/services/definitions/matrix-synapse.d.mts +8 -0
- package/dist/services/definitions/matrix-synapse.d.mts.map +1 -0
- package/dist/services/definitions/matrix-synapse.mjs +3 -0
- package/dist/services/definitions/mattermost.d.mts +8 -0
- package/dist/services/definitions/mattermost.d.mts.map +1 -0
- package/dist/services/definitions/mattermost.mjs +3 -0
- package/dist/services/definitions/meilisearch.d.mts +8 -0
- package/dist/services/definitions/meilisearch.d.mts.map +1 -0
- package/dist/services/definitions/meilisearch.mjs +3 -0
- package/dist/services/definitions/minio.d.mts +8 -0
- package/dist/services/definitions/minio.d.mts.map +1 -0
- package/dist/services/definitions/minio.mjs +3 -0
- package/dist/services/definitions/mixpost.d.mts +8 -0
- package/dist/services/definitions/mixpost.d.mts.map +1 -0
- package/dist/services/definitions/mixpost.mjs +3 -0
- package/dist/services/definitions/motion-canvas.d.mts +8 -0
- package/dist/services/definitions/motion-canvas.d.mts.map +1 -0
- package/dist/services/definitions/motion-canvas.mjs +3 -0
- package/dist/services/definitions/n8n.d.mts +8 -0
- package/dist/services/definitions/n8n.d.mts.map +1 -0
- package/dist/services/definitions/n8n.mjs +3 -0
- package/dist/services/definitions/nocodb.d.mts +8 -0
- package/dist/services/definitions/nocodb.d.mts.map +1 -0
- package/dist/services/definitions/nocodb.mjs +3 -0
- package/dist/services/definitions/ntfy.d.mts +8 -0
- package/dist/services/definitions/ntfy.d.mts.map +1 -0
- package/dist/services/definitions/ntfy.mjs +3 -0
- package/dist/services/definitions/ollama.d.mts +8 -0
- package/dist/services/definitions/ollama.d.mts.map +1 -0
- package/dist/services/definitions/ollama.mjs +3 -0
- package/dist/services/definitions/open-webui.d.mts +8 -0
- package/dist/services/definitions/open-webui.d.mts.map +1 -0
- package/dist/services/definitions/open-webui.mjs +3 -0
- package/dist/services/definitions/opencode.d.mts +8 -0
- package/dist/services/definitions/opencode.d.mts.map +1 -0
- package/dist/services/definitions/opencode.mjs +3 -0
- package/dist/services/definitions/openpanel.d.mts +8 -0
- package/dist/services/definitions/openpanel.d.mts.map +1 -0
- package/dist/services/definitions/openpanel.mjs +3 -0
- package/dist/services/definitions/outline.d.mts +8 -0
- package/dist/services/definitions/outline.d.mts.map +1 -0
- package/dist/services/definitions/outline.mjs +3 -0
- package/dist/services/definitions/paperless-ngx.d.mts +8 -0
- package/dist/services/definitions/paperless-ngx.d.mts.map +1 -0
- package/dist/services/definitions/paperless-ngx.mjs +3 -0
- package/dist/services/definitions/playwright-server.d.mts +8 -0
- package/dist/services/definitions/playwright-server.d.mts.map +1 -0
- package/dist/services/definitions/playwright-server.mjs +3 -0
- package/dist/services/definitions/portainer.d.mts +8 -0
- package/dist/services/definitions/portainer.d.mts.map +1 -0
- package/dist/services/definitions/portainer.mjs +3 -0
- package/dist/services/definitions/postgresql.d.mts +8 -0
- package/dist/services/definitions/postgresql.d.mts.map +1 -0
- package/dist/services/definitions/postgresql.mjs +3 -0
- package/dist/services/definitions/postiz.d.mts +8 -0
- package/dist/services/definitions/postiz.d.mts.map +1 -0
- package/dist/services/definitions/postiz.mjs +3 -0
- package/dist/services/definitions/prometheus.d.mts +8 -0
- package/dist/services/definitions/prometheus.d.mts.map +1 -0
- package/dist/services/definitions/prometheus.mjs +3 -0
- package/dist/services/definitions/qdrant.d.mts +8 -0
- package/dist/services/definitions/qdrant.d.mts.map +1 -0
- package/dist/services/definitions/qdrant.mjs +3 -0
- package/dist/services/definitions/redis.d.mts +8 -0
- package/dist/services/definitions/redis.d.mts.map +1 -0
- package/dist/services/definitions/redis.mjs +3 -0
- package/dist/services/definitions/remotion.d.mts +8 -0
- package/dist/services/definitions/remotion.d.mts.map +1 -0
- package/dist/services/definitions/remotion.mjs +3 -0
- package/dist/services/definitions/rocketchat.d.mts +8 -0
- package/dist/services/definitions/rocketchat.d.mts.map +1 -0
- package/dist/services/definitions/rocketchat.mjs +3 -0
- package/dist/services/definitions/searxng.d.mts +8 -0
- package/dist/services/definitions/searxng.d.mts.map +1 -0
- package/dist/services/definitions/searxng.mjs +3 -0
- package/dist/services/definitions/stable-diffusion.d.mts +8 -0
- package/dist/services/definitions/stable-diffusion.d.mts.map +1 -0
- package/dist/services/definitions/stable-diffusion.mjs +3 -0
- package/dist/services/definitions/steel-browser.d.mts +8 -0
- package/dist/services/definitions/steel-browser.d.mts.map +1 -0
- package/dist/services/definitions/steel-browser.mjs +3 -0
- package/dist/services/definitions/tailscale.d.mts +8 -0
- package/dist/services/definitions/tailscale.d.mts.map +1 -0
- package/dist/services/definitions/tailscale.mjs +3 -0
- package/dist/services/definitions/temporal.d.mts +8 -0
- package/dist/services/definitions/temporal.d.mts.map +1 -0
- package/dist/services/definitions/temporal.mjs +3 -0
- package/dist/services/definitions/traefik.d.mts +8 -0
- package/dist/services/definitions/traefik.d.mts.map +1 -0
- package/dist/services/definitions/traefik.mjs +3 -0
- package/dist/services/definitions/umami.d.mts +8 -0
- package/dist/services/definitions/umami.d.mts.map +1 -0
- package/dist/services/definitions/umami.mjs +3 -0
- package/dist/services/definitions/uptime-kuma.d.mts +8 -0
- package/dist/services/definitions/uptime-kuma.d.mts.map +1 -0
- package/dist/services/definitions/uptime-kuma.mjs +3 -0
- package/dist/services/definitions/valkey.d.mts +8 -0
- package/dist/services/definitions/valkey.d.mts.map +1 -0
- package/dist/services/definitions/valkey.mjs +3 -0
- package/dist/services/definitions/watchtower.d.mts +8 -0
- package/dist/services/definitions/watchtower.d.mts.map +1 -0
- package/dist/services/definitions/watchtower.mjs +3 -0
- package/dist/services/definitions/weaviate.d.mts +8 -0
- package/dist/services/definitions/weaviate.d.mts.map +1 -0
- package/dist/services/definitions/weaviate.mjs +3 -0
- package/dist/services/definitions/whisper.d.mts +8 -0
- package/dist/services/definitions/whisper.d.mts.map +1 -0
- package/dist/services/definitions/whisper.mjs +3 -0
- package/dist/services/registry.d.mts +17 -0
- package/dist/services/registry.d.mts.map +1 -0
- package/dist/services/registry.mjs +3 -0
- package/dist/services/registry.test.d.mts +1 -0
- package/dist/services/registry.test.mjs +64 -0
- package/dist/services/registry.test.mjs.map +1 -0
- package/dist/skills/registry.d.mts +12 -0
- package/dist/skills/registry.d.mts.map +1 -0
- package/dist/skills/registry.mjs +3 -0
- package/dist/skills-DWG72Y3X.mjs +587 -0
- package/dist/skills-DWG72Y3X.mjs.map +1 -0
- package/dist/stable-diffusion-BulAzkyT.mjs +48 -0
- package/dist/stable-diffusion-BulAzkyT.mjs.map +1 -0
- package/dist/steel-browser-Cc0bYBjM.mjs +77 -0
- package/dist/steel-browser-Cc0bYBjM.mjs.map +1 -0
- package/dist/tailscale-CrM4EZlF.mjs +69 -0
- package/dist/tailscale-CrM4EZlF.mjs.map +1 -0
- package/dist/temporal-49gA0msh.mjs +100 -0
- package/dist/temporal-49gA0msh.mjs.map +1 -0
- package/dist/traefik-Da-c1f55.mjs +58 -0
- package/dist/traefik-Da-c1f55.mjs.map +1 -0
- package/dist/types.d.mts +64 -0
- package/dist/types.d.mts.map +1 -0
- package/dist/types.mjs +92 -0
- package/dist/types.mjs.map +1 -0
- package/dist/umami-csBSsHqO.mjs +46 -0
- package/dist/umami-csBSsHqO.mjs.map +1 -0
- package/dist/uptime-kuma-D0NvVuXD.mjs +51 -0
- package/dist/uptime-kuma-D0NvVuXD.mjs.map +1 -0
- package/dist/validator-2FspYNva.mjs +111 -0
- package/dist/validator-2FspYNva.mjs.map +1 -0
- package/dist/validator.d.mts +21 -0
- package/dist/validator.d.mts.map +1 -0
- package/dist/validator.mjs +3 -0
- package/dist/validator.test.d.mts +1 -0
- package/dist/validator.test.mjs +65 -0
- package/dist/validator.test.mjs.map +1 -0
- package/dist/valkey-BCZqGJ0L.mjs +61 -0
- package/dist/valkey-BCZqGJ0L.mjs.map +1 -0
- package/dist/version-manager.d.mts +15 -0
- package/dist/version-manager.d.mts.map +1 -0
- package/dist/version-manager.mjs +55 -0
- package/dist/version-manager.mjs.map +1 -0
- package/dist/vi.2VT5v0um-Cs3Z_fCB.mjs +12916 -0
- package/dist/vi.2VT5v0um-Cs3Z_fCB.mjs.map +1 -0
- package/dist/watchtower-BWuvFGpA.mjs +47 -0
- package/dist/watchtower-BWuvFGpA.mjs.map +1 -0
- package/dist/weaviate-DttY1Hn7.mjs +90 -0
- package/dist/weaviate-DttY1Hn7.mjs.map +1 -0
- package/dist/whisper-CLu7-Vd8.mjs +62 -0
- package/dist/whisper-CLu7-Vd8.mjs.map +1 -0
- package/package.json +27 -26
|
@@ -1,38 +1,37 @@
|
|
|
1
1
|
name: Publish-Core
|
|
2
2
|
|
|
3
3
|
on:
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
permissions:
|
|
8
|
-
contents: read
|
|
9
|
-
id-token: write
|
|
4
|
+
release:
|
|
5
|
+
types: [published]
|
|
10
6
|
|
|
11
7
|
jobs:
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
8
|
+
publish-npm:
|
|
9
|
+
runs-on: ubuntu-latest
|
|
10
|
+
permissions:
|
|
11
|
+
contents: read
|
|
12
|
+
id-token: write
|
|
13
|
+
steps:
|
|
14
|
+
- uses: actions/checkout@v4
|
|
15
|
+
- uses: actions/setup-node@v4
|
|
16
|
+
with:
|
|
17
|
+
node-version: "20.x"
|
|
18
|
+
registry-url: "https://registry.npmjs.org"
|
|
19
|
+
|
|
20
|
+
- uses: pnpm/action-setup@v2
|
|
21
|
+
with:
|
|
22
|
+
version: 9
|
|
23
|
+
run_install: false
|
|
24
|
+
|
|
25
|
+
- name: Install dependencies
|
|
26
|
+
run: pnpm install --no-lockfile
|
|
27
|
+
env:
|
|
28
|
+
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
|
|
29
|
+
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
|
|
30
|
+
|
|
31
|
+
- name: Build and Publish Auth Typescript SDK
|
|
32
|
+
run: |
|
|
33
|
+
pnpm --filter @better-openclaw/core build
|
|
34
|
+
npm publish --access=public
|
|
35
|
+
env:
|
|
36
|
+
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
|
|
37
|
+
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
//#region src/services/definitions/anything-llm.ts
|
|
2
|
+
const anythingLlmDefinition = {
|
|
3
|
+
id: "anything-llm",
|
|
4
|
+
name: "AnythingLLM",
|
|
5
|
+
description: "All-in-one Desktop & Docker AI application with built-in RAG, AI agents, document chat, and multi-user support.",
|
|
6
|
+
category: "ai-platform",
|
|
7
|
+
icon: "📖",
|
|
8
|
+
image: "mintplexlabs/anythingllm",
|
|
9
|
+
imageTag: "latest",
|
|
10
|
+
ports: [{
|
|
11
|
+
host: 3100,
|
|
12
|
+
container: 3001,
|
|
13
|
+
description: "AnythingLLM interface",
|
|
14
|
+
exposed: true
|
|
15
|
+
}],
|
|
16
|
+
volumes: [{
|
|
17
|
+
name: "anythingllm-data",
|
|
18
|
+
containerPath: "/app/server/storage",
|
|
19
|
+
description: "AnythingLLM storage"
|
|
20
|
+
}],
|
|
21
|
+
environment: [],
|
|
22
|
+
dependsOn: [],
|
|
23
|
+
restartPolicy: "unless-stopped",
|
|
24
|
+
networks: ["openclaw-network"],
|
|
25
|
+
skills: [],
|
|
26
|
+
openclawEnvVars: [],
|
|
27
|
+
docsUrl: "https://docs.anythingllm.com/",
|
|
28
|
+
tags: [
|
|
29
|
+
"rag",
|
|
30
|
+
"documents",
|
|
31
|
+
"chat",
|
|
32
|
+
"knowledge-base"
|
|
33
|
+
],
|
|
34
|
+
maturity: "stable",
|
|
35
|
+
requires: [],
|
|
36
|
+
recommends: ["ollama"],
|
|
37
|
+
conflictsWith: [],
|
|
38
|
+
minMemoryMB: 512,
|
|
39
|
+
gpuRequired: false
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
//#endregion
|
|
43
|
+
export { anythingLlmDefinition as t };
|
|
44
|
+
//# sourceMappingURL=anything-llm-DIIPhz6K.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"anything-llm-DIIPhz6K.mjs","names":[],"sources":["../src/services/definitions/anything-llm.ts"],"sourcesContent":["import type { ServiceDefinition } from \"../../types.js\";\n\nexport const anythingLlmDefinition: ServiceDefinition = {\n\tid: \"anything-llm\",\n\tname: \"AnythingLLM\",\n\tdescription:\n\t\t\"All-in-one Desktop & Docker AI application with built-in RAG, AI agents, document chat, and multi-user support.\",\n\tcategory: \"ai-platform\",\n\ticon: \"📖\",\n\n\timage: \"mintplexlabs/anythingllm\",\n\timageTag: \"latest\",\n\tports: [\n\t\t{\n\t\t\thost: 3100,\n\t\t\tcontainer: 3001,\n\t\t\tdescription: \"AnythingLLM interface\",\n\t\t\texposed: true,\n\t\t},\n\t],\n\tvolumes: [\n\t\t{\n\t\t\tname: \"anythingllm-data\",\n\t\t\tcontainerPath: \"/app/server/storage\",\n\t\t\tdescription: \"AnythingLLM storage\",\n\t\t},\n\t],\n\tenvironment: [],\n\tdependsOn: [],\n\trestartPolicy: \"unless-stopped\",\n\tnetworks: [\"openclaw-network\"],\n\n\tskills: [],\n\topenclawEnvVars: [],\n\n\tdocsUrl: \"https://docs.anythingllm.com/\",\n\ttags: [\"rag\", \"documents\", \"chat\", \"knowledge-base\"],\n\tmaturity: \"stable\",\n\n\trequires: [],\n\trecommends: [\"ollama\"],\n\tconflictsWith: [],\n\n\tminMemoryMB: 512,\n\tgpuRequired: false,\n};\n"],"mappings":";AAEA,MAAa,wBAA2C;CACvD,IAAI;CACJ,MAAM;CACN,aACC;CACD,UAAU;CACV,MAAM;CAEN,OAAO;CACP,UAAU;CACV,OAAO,CACN;EACC,MAAM;EACN,WAAW;EACX,aAAa;EACb,SAAS;EACT,CACD;CACD,SAAS,CACR;EACC,MAAM;EACN,eAAe;EACf,aAAa;EACb,CACD;CACD,aAAa,EAAE;CACf,WAAW,EAAE;CACb,eAAe;CACf,UAAU,CAAC,mBAAmB;CAE9B,QAAQ,EAAE;CACV,iBAAiB,EAAE;CAEnB,SAAS;CACT,MAAM;EAAC;EAAO;EAAa;EAAQ;EAAiB;CACpD,UAAU;CAEV,UAAU,EAAE;CACZ,YAAY,CAAC,SAAS;CACtB,eAAe,EAAE;CAEjB,aAAa;CACb,aAAa;CACb"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
//#region src/services/definitions/appflowy.ts
|
|
2
|
+
const appflowyDefinition = {
|
|
3
|
+
id: "appflowy",
|
|
4
|
+
name: "AppFlowy",
|
|
5
|
+
description: "Open-source Notion alternative focused on privacy and extensibility. Self-hosted collaborative workspace.",
|
|
6
|
+
category: "knowledge",
|
|
7
|
+
icon: "🍃",
|
|
8
|
+
image: "appflowyio/appflowy-cloud",
|
|
9
|
+
imageTag: "latest",
|
|
10
|
+
ports: [{
|
|
11
|
+
host: 8087,
|
|
12
|
+
container: 8025,
|
|
13
|
+
description: "AppFlowy Cloud API and Web UI",
|
|
14
|
+
exposed: true
|
|
15
|
+
}],
|
|
16
|
+
volumes: [{
|
|
17
|
+
name: "appflowy-data",
|
|
18
|
+
containerPath: "/data",
|
|
19
|
+
description: "AppFlowy persistent application data"
|
|
20
|
+
}],
|
|
21
|
+
environment: [],
|
|
22
|
+
dependsOn: [],
|
|
23
|
+
restartPolicy: "unless-stopped",
|
|
24
|
+
networks: ["openclaw-network"],
|
|
25
|
+
skills: [],
|
|
26
|
+
openclawEnvVars: [],
|
|
27
|
+
docsUrl: "https://docs.appflowy.io/",
|
|
28
|
+
tags: [
|
|
29
|
+
"notion-alternative",
|
|
30
|
+
"workspace",
|
|
31
|
+
"notes",
|
|
32
|
+
"wiki",
|
|
33
|
+
"collaboration"
|
|
34
|
+
],
|
|
35
|
+
maturity: "beta",
|
|
36
|
+
requires: [],
|
|
37
|
+
recommends: [],
|
|
38
|
+
conflictsWith: [],
|
|
39
|
+
minMemoryMB: 512,
|
|
40
|
+
gpuRequired: false
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
//#endregion
|
|
44
|
+
export { appflowyDefinition as t };
|
|
45
|
+
//# sourceMappingURL=appflowy-DdoE-dKg.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"appflowy-DdoE-dKg.mjs","names":[],"sources":["../src/services/definitions/appflowy.ts"],"sourcesContent":["import type { ServiceDefinition } from \"../../types.js\";\n\nexport const appflowyDefinition: ServiceDefinition = {\n\tid: \"appflowy\",\n\tname: \"AppFlowy\",\n\tdescription:\n\t\t\"Open-source Notion alternative focused on privacy and extensibility. Self-hosted collaborative workspace.\",\n\tcategory: \"knowledge\",\n\ticon: \"🍃\",\n\n\timage: \"appflowyio/appflowy-cloud\",\n\timageTag: \"latest\",\n\tports: [\n\t\t{\n\t\t\thost: 8087,\n\t\t\tcontainer: 8025,\n\t\t\tdescription: \"AppFlowy Cloud API and Web UI\",\n\t\t\texposed: true,\n\t\t},\n\t],\n\tvolumes: [\n\t\t{\n\t\t\tname: \"appflowy-data\",\n\t\t\tcontainerPath: \"/data\",\n\t\t\tdescription: \"AppFlowy persistent application data\",\n\t\t},\n\t],\n\tenvironment: [],\n\tdependsOn: [],\n\trestartPolicy: \"unless-stopped\",\n\tnetworks: [\"openclaw-network\"],\n\n\tskills: [],\n\topenclawEnvVars: [],\n\n\tdocsUrl: \"https://docs.appflowy.io/\",\n\ttags: [\"notion-alternative\", \"workspace\", \"notes\", \"wiki\", \"collaboration\"],\n\tmaturity: \"beta\",\n\n\trequires: [],\n\trecommends: [],\n\tconflictsWith: [],\n\n\tminMemoryMB: 512,\n\tgpuRequired: false,\n};\n"],"mappings":";AAEA,MAAa,qBAAwC;CACpD,IAAI;CACJ,MAAM;CACN,aACC;CACD,UAAU;CACV,MAAM;CAEN,OAAO;CACP,UAAU;CACV,OAAO,CACN;EACC,MAAM;EACN,WAAW;EACX,aAAa;EACb,SAAS;EACT,CACD;CACD,SAAS,CACR;EACC,MAAM;EACN,eAAe;EACf,aAAa;EACb,CACD;CACD,aAAa,EAAE;CACf,WAAW,EAAE;CACb,eAAe;CACf,UAAU,CAAC,mBAAmB;CAE9B,QAAQ,EAAE;CACV,iBAAiB,EAAE;CAEnB,SAAS;CACT,MAAM;EAAC;EAAsB;EAAa;EAAS;EAAQ;EAAgB;CAC3E,UAAU;CAEV,UAAU,EAAE;CACZ,YAAY,EAAE;CACd,eAAe,EAAE;CAEjB,aAAa;CACb,aAAa;CACb"}
|
|
@@ -0,0 +1,224 @@
|
|
|
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
|
|
12
|
+
|
|
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 as t };
|
|
224
|
+
//# sourceMappingURL=bare-metal-install-DpYZDoGq.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bare-metal-install-DpYZDoGq.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"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
//#region src/bare-metal-partition.ts
|
|
2
|
+
/**
|
|
3
|
+
* Maps Platform (e.g. linux/amd64) to NativePlatform (linux, windows, macos).
|
|
4
|
+
*/
|
|
5
|
+
function platformToNativePlatform(platform) {
|
|
6
|
+
if (platform.startsWith("linux/")) return "linux";
|
|
7
|
+
if (platform.startsWith("windows/")) return "windows";
|
|
8
|
+
if (platform.startsWith("macos/")) return "macos";
|
|
9
|
+
return "linux";
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Partitions resolved services into native (run on host via scripts) vs Docker-only.
|
|
13
|
+
* Gateway and CLI are never native; services with nativeSupported and a matching
|
|
14
|
+
* nativeRecipe for the platform go to native, rest to Docker.
|
|
15
|
+
*/
|
|
16
|
+
function partitionBareMetal(resolved, platform) {
|
|
17
|
+
const nativePlatform = platformToNativePlatform(platform);
|
|
18
|
+
const nativeServices = [];
|
|
19
|
+
const dockerOnlyServices = [];
|
|
20
|
+
const nativeIds = /* @__PURE__ */ new Set();
|
|
21
|
+
for (const entry of resolved.services) {
|
|
22
|
+
const def = entry.definition;
|
|
23
|
+
if (def.nativeSupported === true && def.nativeRecipes?.length && def.nativeRecipes.some((r) => r.platform === nativePlatform)) {
|
|
24
|
+
nativeServices.push(entry);
|
|
25
|
+
nativeIds.add(def.id);
|
|
26
|
+
} else dockerOnlyServices.push(entry);
|
|
27
|
+
}
|
|
28
|
+
return {
|
|
29
|
+
nativeServices,
|
|
30
|
+
dockerOnlyServices,
|
|
31
|
+
nativeIds
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Returns a new ResolverOutput containing only the given service list (same order).
|
|
36
|
+
* Used to build compose for Docker-only subset when bare-metal has native services.
|
|
37
|
+
*/
|
|
38
|
+
function resolvedWithOnlyServices(resolved, services) {
|
|
39
|
+
const idSet = new Set(services.map((s) => s.definition.id));
|
|
40
|
+
return {
|
|
41
|
+
...resolved,
|
|
42
|
+
services: resolved.services.filter((s) => idSet.has(s.definition.id))
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
//#endregion
|
|
47
|
+
export { platformToNativePlatform as n, resolvedWithOnlyServices as r, partitionBareMetal as t };
|
|
48
|
+
//# sourceMappingURL=bare-metal-partition-CYlOxf9B.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bare-metal-partition-CYlOxf9B.mjs","names":[],"sources":["../src/bare-metal-partition.ts"],"sourcesContent":["import type { NativePlatform, Platform, ResolvedService, ResolverOutput } from \"./types.js\";\n\n/**\n * Maps Platform (e.g. linux/amd64) to NativePlatform (linux, windows, macos).\n */\nexport function platformToNativePlatform(platform: Platform): NativePlatform {\n\tif (platform.startsWith(\"linux/\")) return \"linux\";\n\tif (platform.startsWith(\"windows/\")) return \"windows\";\n\tif (platform.startsWith(\"macos/\")) return \"macos\";\n\treturn \"linux\";\n}\n\nexport interface BareMetalPartitionResult {\n\tnativeServices: ResolvedService[];\n\tdockerOnlyServices: ResolvedService[];\n\tnativeIds: Set<string>;\n}\n\n/**\n * Partitions resolved services into native (run on host via scripts) vs Docker-only.\n * Gateway and CLI are never native; services with nativeSupported and a matching\n * nativeRecipe for the platform go to native, rest to Docker.\n */\nexport function partitionBareMetal(\n\tresolved: ResolverOutput,\n\tplatform: Platform,\n): BareMetalPartitionResult {\n\tconst nativePlatform = platformToNativePlatform(platform);\n\tconst nativeServices: ResolvedService[] = [];\n\tconst dockerOnlyServices: ResolvedService[] = [];\n\tconst nativeIds = new Set<string>();\n\n\tfor (const entry of resolved.services) {\n\t\tconst def = entry.definition;\n\t\tconst hasNativeRecipe =\n\t\t\tdef.nativeSupported === true &&\n\t\t\tdef.nativeRecipes?.length &&\n\t\t\tdef.nativeRecipes.some((r) => r.platform === nativePlatform);\n\n\t\tif (hasNativeRecipe) {\n\t\t\tnativeServices.push(entry);\n\t\t\tnativeIds.add(def.id);\n\t\t} else {\n\t\t\tdockerOnlyServices.push(entry);\n\t\t}\n\t}\n\n\treturn { nativeServices, dockerOnlyServices, nativeIds };\n}\n\n/**\n * Returns a new ResolverOutput containing only the given service list (same order).\n * Used to build compose for Docker-only subset when bare-metal has native services.\n */\nexport function resolvedWithOnlyServices(\n\tresolved: ResolverOutput,\n\tservices: ResolvedService[],\n): ResolverOutput {\n\tconst idSet = new Set(services.map((s) => s.definition.id));\n\treturn {\n\t\t...resolved,\n\t\tservices: resolved.services.filter((s) => idSet.has(s.definition.id)),\n\t};\n}\n"],"mappings":";;;;AAKA,SAAgB,yBAAyB,UAAoC;AAC5E,KAAI,SAAS,WAAW,SAAS,CAAE,QAAO;AAC1C,KAAI,SAAS,WAAW,WAAW,CAAE,QAAO;AAC5C,KAAI,SAAS,WAAW,SAAS,CAAE,QAAO;AAC1C,QAAO;;;;;;;AAcR,SAAgB,mBACf,UACA,UAC2B;CAC3B,MAAM,iBAAiB,yBAAyB,SAAS;CACzD,MAAM,iBAAoC,EAAE;CAC5C,MAAM,qBAAwC,EAAE;CAChD,MAAM,4BAAY,IAAI,KAAa;AAEnC,MAAK,MAAM,SAAS,SAAS,UAAU;EACtC,MAAM,MAAM,MAAM;AAMlB,MAJC,IAAI,oBAAoB,QACxB,IAAI,eAAe,UACnB,IAAI,cAAc,MAAM,MAAM,EAAE,aAAa,eAAe,EAExC;AACpB,kBAAe,KAAK,MAAM;AAC1B,aAAU,IAAI,IAAI,GAAG;QAErB,oBAAmB,KAAK,MAAM;;AAIhC,QAAO;EAAE;EAAgB;EAAoB;EAAW;;;;;;AAOzD,SAAgB,yBACf,UACA,UACiB;CACjB,MAAM,QAAQ,IAAI,IAAI,SAAS,KAAK,MAAM,EAAE,WAAW,GAAG,CAAC;AAC3D,QAAO;EACN,GAAG;EACH,UAAU,SAAS,SAAS,QAAQ,MAAM,MAAM,IAAI,EAAE,WAAW,GAAG,CAAC;EACrE"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import "./schema-PSUY6yJU.mjs";
|
|
2
|
+
import { NativePlatform, Platform, ResolvedService, ResolverOutput } from "./types.mjs";
|
|
3
|
+
|
|
4
|
+
//#region src/bare-metal-partition.d.ts
|
|
5
|
+
/**
|
|
6
|
+
* Maps Platform (e.g. linux/amd64) to NativePlatform (linux, windows, macos).
|
|
7
|
+
*/
|
|
8
|
+
declare function platformToNativePlatform(platform: Platform): NativePlatform;
|
|
9
|
+
interface BareMetalPartitionResult {
|
|
10
|
+
nativeServices: ResolvedService[];
|
|
11
|
+
dockerOnlyServices: ResolvedService[];
|
|
12
|
+
nativeIds: Set<string>;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Partitions resolved services into native (run on host via scripts) vs Docker-only.
|
|
16
|
+
* Gateway and CLI are never native; services with nativeSupported and a matching
|
|
17
|
+
* nativeRecipe for the platform go to native, rest to Docker.
|
|
18
|
+
*/
|
|
19
|
+
declare function partitionBareMetal(resolved: ResolverOutput, platform: Platform): BareMetalPartitionResult;
|
|
20
|
+
/**
|
|
21
|
+
* Returns a new ResolverOutput containing only the given service list (same order).
|
|
22
|
+
* Used to build compose for Docker-only subset when bare-metal has native services.
|
|
23
|
+
*/
|
|
24
|
+
declare function resolvedWithOnlyServices(resolved: ResolverOutput, services: ResolvedService[]): ResolverOutput;
|
|
25
|
+
//#endregion
|
|
26
|
+
export { BareMetalPartitionResult, partitionBareMetal, platformToNativePlatform, resolvedWithOnlyServices };
|
|
27
|
+
//# sourceMappingURL=bare-metal-partition.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bare-metal-partition.d.mts","names":[],"sources":["../src/bare-metal-partition.ts"],"sourcesContent":[],"mappings":";;;;;;;AAKgB,iBAAA,wBAAA,CAAmC,QAAW,EAAX,QAAyB,CAAA,EAAd,cAAc;AAO3D,UAAA,wBAAA,CAAwB;EACxB,cAAA,EAAA,eAAA,EAAA;EACI,kBAAA,EAAA,eAAA,EAAA;EACT,SAAA,EAAA,GAAA,CAAA,MAAA,CAAA;;AAQZ;;;;;AA+BgB,iBA/BA,kBAAA,CA+BwB,QAAA,EA9B7B,cA8B6B,EAAA,QAAA,EA7B7B,QA6B6B,CAAA,EA5BrC,wBA4BqC;;;;;iBAAxB,wBAAA,WACL,0BACA,oBACR"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { n as describe, r as it, t as globalExpect } from "./vi.2VT5v0um-Cs3Z_fCB.mjs";
|
|
2
|
+
import { n as platformToNativePlatform, r as resolvedWithOnlyServices, t as partitionBareMetal } from "./bare-metal-partition-CYlOxf9B.mjs";
|
|
3
|
+
import { t as resolve } from "./resolver-Dl5clk-d.mjs";
|
|
4
|
+
|
|
5
|
+
//#region src/bare-metal-partition.test.ts
|
|
6
|
+
describe("bare-metal partition", () => {
|
|
7
|
+
it("platformToNativePlatform maps platform to native", () => {
|
|
8
|
+
globalExpect(platformToNativePlatform("linux/amd64")).toBe("linux");
|
|
9
|
+
globalExpect(platformToNativePlatform("linux/arm64")).toBe("linux");
|
|
10
|
+
globalExpect(platformToNativePlatform("windows/amd64")).toBe("windows");
|
|
11
|
+
globalExpect(platformToNativePlatform("macos/arm64")).toBe("macos");
|
|
12
|
+
});
|
|
13
|
+
it("partitions redis as native on Linux when redis has native recipe", () => {
|
|
14
|
+
const result = partitionBareMetal(resolve({
|
|
15
|
+
services: ["redis"],
|
|
16
|
+
skillPacks: [],
|
|
17
|
+
proxy: "none",
|
|
18
|
+
gpu: false,
|
|
19
|
+
platform: "linux/amd64",
|
|
20
|
+
monitoring: false
|
|
21
|
+
}), "linux/amd64");
|
|
22
|
+
globalExpect(result.nativeIds.has("redis")).toBe(true);
|
|
23
|
+
globalExpect(result.nativeServices.length).toBe(1);
|
|
24
|
+
globalExpect(result.nativeServices[0].definition.id).toBe("redis");
|
|
25
|
+
globalExpect(result.dockerOnlyServices.length).toBe(0);
|
|
26
|
+
});
|
|
27
|
+
it("partitions n8n as Docker-only (no native recipe)", () => {
|
|
28
|
+
const result = partitionBareMetal(resolve({
|
|
29
|
+
services: ["n8n"],
|
|
30
|
+
skillPacks: [],
|
|
31
|
+
proxy: "none",
|
|
32
|
+
gpu: false,
|
|
33
|
+
platform: "linux/amd64",
|
|
34
|
+
monitoring: false
|
|
35
|
+
}), "linux/amd64");
|
|
36
|
+
globalExpect(result.nativeIds.has("n8n")).toBe(false);
|
|
37
|
+
globalExpect(result.nativeServices.length).toBe(0);
|
|
38
|
+
globalExpect(result.dockerOnlyServices.length).toBeGreaterThanOrEqual(1);
|
|
39
|
+
globalExpect(result.dockerOnlyServices.some((s) => s.definition.id === "n8n")).toBe(true);
|
|
40
|
+
});
|
|
41
|
+
it("resolvedWithOnlyServices filters to given service list", () => {
|
|
42
|
+
const resolved = resolve({
|
|
43
|
+
services: ["redis", "n8n"],
|
|
44
|
+
skillPacks: [],
|
|
45
|
+
proxy: "none",
|
|
46
|
+
gpu: false,
|
|
47
|
+
platform: "linux/amd64",
|
|
48
|
+
monitoring: false
|
|
49
|
+
});
|
|
50
|
+
const filtered = resolvedWithOnlyServices(resolved, partitionBareMetal(resolved, "linux/amd64").dockerOnlyServices);
|
|
51
|
+
globalExpect(filtered.services.every((s) => s.definition.id !== "redis")).toBe(true);
|
|
52
|
+
globalExpect(filtered.services.some((s) => s.definition.id === "n8n")).toBe(true);
|
|
53
|
+
});
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
//#endregion
|
|
57
|
+
export { };
|
|
58
|
+
//# sourceMappingURL=bare-metal-partition.test.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bare-metal-partition.test.mjs","names":[],"sources":["../src/bare-metal-partition.test.ts"],"sourcesContent":["import { describe, expect, it } from \"vitest\";\nimport {\n\tpartitionBareMetal,\n\tplatformToNativePlatform,\n\tresolvedWithOnlyServices,\n} from \"./bare-metal-partition.js\";\nimport { resolve } from \"./resolver.js\";\n\ndescribe(\"bare-metal partition\", () => {\n\tit(\"platformToNativePlatform maps platform to native\", () => {\n\t\texpect(platformToNativePlatform(\"linux/amd64\")).toBe(\"linux\");\n\t\texpect(platformToNativePlatform(\"linux/arm64\")).toBe(\"linux\");\n\t\texpect(platformToNativePlatform(\"windows/amd64\")).toBe(\"windows\");\n\t\texpect(platformToNativePlatform(\"macos/arm64\")).toBe(\"macos\");\n\t});\n\n\tit(\"partitions redis as native on Linux when redis has native recipe\", () => {\n\t\tconst resolved = resolve({\n\t\t\tservices: [\"redis\"],\n\t\t\tskillPacks: [],\n\t\t\tproxy: \"none\",\n\t\t\tgpu: false,\n\t\t\tplatform: \"linux/amd64\",\n\t\t\tmonitoring: false,\n\t\t});\n\t\tconst result = partitionBareMetal(resolved, \"linux/amd64\");\n\t\texpect(result.nativeIds.has(\"redis\")).toBe(true);\n\t\texpect(result.nativeServices.length).toBe(1);\n\t\texpect(result.nativeServices[0].definition.id).toBe(\"redis\");\n\t\texpect(result.dockerOnlyServices.length).toBe(0);\n\t});\n\n\tit(\"partitions n8n as Docker-only (no native recipe)\", () => {\n\t\tconst resolved = resolve({\n\t\t\tservices: [\"n8n\"],\n\t\t\tskillPacks: [],\n\t\t\tproxy: \"none\",\n\t\t\tgpu: false,\n\t\t\tplatform: \"linux/amd64\",\n\t\t\tmonitoring: false,\n\t\t});\n\t\tconst result = partitionBareMetal(resolved, \"linux/amd64\");\n\t\texpect(result.nativeIds.has(\"n8n\")).toBe(false);\n\t\texpect(result.nativeServices.length).toBe(0);\n\t\texpect(result.dockerOnlyServices.length).toBeGreaterThanOrEqual(1);\n\t\texpect(result.dockerOnlyServices.some((s) => s.definition.id === \"n8n\")).toBe(true);\n\t});\n\n\tit(\"resolvedWithOnlyServices filters to given service list\", () => {\n\t\tconst resolved = resolve({\n\t\t\tservices: [\"redis\", \"n8n\"],\n\t\t\tskillPacks: [],\n\t\t\tproxy: \"none\",\n\t\t\tgpu: false,\n\t\t\tplatform: \"linux/amd64\",\n\t\t\tmonitoring: false,\n\t\t});\n\t\tconst partition = partitionBareMetal(resolved, \"linux/amd64\");\n\t\tconst filtered = resolvedWithOnlyServices(resolved, partition.dockerOnlyServices);\n\t\texpect(filtered.services.every((s) => s.definition.id !== \"redis\")).toBe(true);\n\t\texpect(filtered.services.some((s) => s.definition.id === \"n8n\")).toBe(true);\n\t});\n});\n"],"mappings":";;;;;AAQA,SAAS,8BAA8B;AACtC,IAAG,0DAA0D;AAC5D,eAAO,yBAAyB,cAAc,CAAC,CAAC,KAAK,QAAQ;AAC7D,eAAO,yBAAyB,cAAc,CAAC,CAAC,KAAK,QAAQ;AAC7D,eAAO,yBAAyB,gBAAgB,CAAC,CAAC,KAAK,UAAU;AACjE,eAAO,yBAAyB,cAAc,CAAC,CAAC,KAAK,QAAQ;GAC5D;AAEF,IAAG,0EAA0E;EAS5E,MAAM,SAAS,mBARE,QAAQ;GACxB,UAAU,CAAC,QAAQ;GACnB,YAAY,EAAE;GACd,OAAO;GACP,KAAK;GACL,UAAU;GACV,YAAY;GACZ,CAAC,EAC0C,cAAc;AAC1D,eAAO,OAAO,UAAU,IAAI,QAAQ,CAAC,CAAC,KAAK,KAAK;AAChD,eAAO,OAAO,eAAe,OAAO,CAAC,KAAK,EAAE;AAC5C,eAAO,OAAO,eAAe,GAAG,WAAW,GAAG,CAAC,KAAK,QAAQ;AAC5D,eAAO,OAAO,mBAAmB,OAAO,CAAC,KAAK,EAAE;GAC/C;AAEF,IAAG,0DAA0D;EAS5D,MAAM,SAAS,mBARE,QAAQ;GACxB,UAAU,CAAC,MAAM;GACjB,YAAY,EAAE;GACd,OAAO;GACP,KAAK;GACL,UAAU;GACV,YAAY;GACZ,CAAC,EAC0C,cAAc;AAC1D,eAAO,OAAO,UAAU,IAAI,MAAM,CAAC,CAAC,KAAK,MAAM;AAC/C,eAAO,OAAO,eAAe,OAAO,CAAC,KAAK,EAAE;AAC5C,eAAO,OAAO,mBAAmB,OAAO,CAAC,uBAAuB,EAAE;AAClE,eAAO,OAAO,mBAAmB,MAAM,MAAM,EAAE,WAAW,OAAO,MAAM,CAAC,CAAC,KAAK,KAAK;GAClF;AAEF,IAAG,gEAAgE;EAClE,MAAM,WAAW,QAAQ;GACxB,UAAU,CAAC,SAAS,MAAM;GAC1B,YAAY,EAAE;GACd,OAAO;GACP,KAAK;GACL,UAAU;GACV,YAAY;GACZ,CAAC;EAEF,MAAM,WAAW,yBAAyB,UADxB,mBAAmB,UAAU,cAAc,CACC,mBAAmB;AACjF,eAAO,SAAS,SAAS,OAAO,MAAM,EAAE,WAAW,OAAO,QAAQ,CAAC,CAAC,KAAK,KAAK;AAC9E,eAAO,SAAS,SAAS,MAAM,MAAM,EAAE,WAAW,OAAO,MAAM,CAAC,CAAC,KAAK,KAAK;GAC1E;EACD"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
//#region src/services/definitions/beszel.ts
|
|
2
|
+
const beszelDefinition = {
|
|
3
|
+
id: "beszel",
|
|
4
|
+
name: "Beszel",
|
|
5
|
+
description: "Lightweight server monitoring dashboard with Docker stats, alerts, and historical data.",
|
|
6
|
+
category: "dev-tools",
|
|
7
|
+
icon: "📟",
|
|
8
|
+
image: "henrygd/beszel",
|
|
9
|
+
imageTag: "latest",
|
|
10
|
+
ports: [{
|
|
11
|
+
host: 8099,
|
|
12
|
+
container: 8090,
|
|
13
|
+
description: "Beszel Web UI",
|
|
14
|
+
exposed: true
|
|
15
|
+
}],
|
|
16
|
+
volumes: [{
|
|
17
|
+
name: "beszel-data",
|
|
18
|
+
containerPath: "/beszel_data",
|
|
19
|
+
description: "Beszel data"
|
|
20
|
+
}],
|
|
21
|
+
environment: [],
|
|
22
|
+
dependsOn: [],
|
|
23
|
+
restartPolicy: "unless-stopped",
|
|
24
|
+
networks: ["openclaw-network"],
|
|
25
|
+
skills: [],
|
|
26
|
+
openclawEnvVars: [],
|
|
27
|
+
docsUrl: "https://beszel.dev/",
|
|
28
|
+
tags: [
|
|
29
|
+
"monitoring",
|
|
30
|
+
"server",
|
|
31
|
+
"dashboard",
|
|
32
|
+
"docker-stats",
|
|
33
|
+
"alerts"
|
|
34
|
+
],
|
|
35
|
+
maturity: "beta",
|
|
36
|
+
requires: [],
|
|
37
|
+
recommends: [],
|
|
38
|
+
conflictsWith: [],
|
|
39
|
+
minMemoryMB: 64,
|
|
40
|
+
gpuRequired: false
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
//#endregion
|
|
44
|
+
export { beszelDefinition as t };
|
|
45
|
+
//# sourceMappingURL=beszel-DHAG1zl0.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beszel-DHAG1zl0.mjs","names":[],"sources":["../src/services/definitions/beszel.ts"],"sourcesContent":["import type { ServiceDefinition } from \"../../types.js\";\n\nexport const beszelDefinition: ServiceDefinition = {\n\tid: \"beszel\",\n\tname: \"Beszel\",\n\tdescription:\n\t\t\"Lightweight server monitoring dashboard with Docker stats, alerts, and historical data.\",\n\tcategory: \"dev-tools\",\n\ticon: \"📟\",\n\n\timage: \"henrygd/beszel\",\n\timageTag: \"latest\",\n\tports: [\n\t\t{\n\t\t\thost: 8099,\n\t\t\tcontainer: 8090,\n\t\t\tdescription: \"Beszel Web UI\",\n\t\t\texposed: true,\n\t\t},\n\t],\n\tvolumes: [\n\t\t{\n\t\t\tname: \"beszel-data\",\n\t\t\tcontainerPath: \"/beszel_data\",\n\t\t\tdescription: \"Beszel data\",\n\t\t},\n\t],\n\tenvironment: [],\n\tdependsOn: [],\n\trestartPolicy: \"unless-stopped\",\n\tnetworks: [\"openclaw-network\"],\n\n\tskills: [],\n\topenclawEnvVars: [],\n\n\tdocsUrl: \"https://beszel.dev/\",\n\ttags: [\"monitoring\", \"server\", \"dashboard\", \"docker-stats\", \"alerts\"],\n\tmaturity: \"beta\",\n\n\trequires: [],\n\trecommends: [],\n\tconflictsWith: [],\n\n\tminMemoryMB: 64,\n\tgpuRequired: false,\n};\n"],"mappings":";AAEA,MAAa,mBAAsC;CAClD,IAAI;CACJ,MAAM;CACN,aACC;CACD,UAAU;CACV,MAAM;CAEN,OAAO;CACP,UAAU;CACV,OAAO,CACN;EACC,MAAM;EACN,WAAW;EACX,aAAa;EACb,SAAS;EACT,CACD;CACD,SAAS,CACR;EACC,MAAM;EACN,eAAe;EACf,aAAa;EACb,CACD;CACD,aAAa,EAAE;CACf,WAAW,EAAE;CACb,eAAe;CACf,UAAU,CAAC,mBAAmB;CAE9B,QAAQ,EAAE;CACV,iBAAiB,EAAE;CAEnB,SAAS;CACT,MAAM;EAAC;EAAc;EAAU;EAAa;EAAgB;EAAS;CACrE,UAAU;CAEV,UAAU,EAAE;CACZ,YAAY,EAAE;CACd,eAAe,EAAE;CAEjB,aAAa;CACb,aAAa;CACb"}
|