@better-openclaw/core 1.0.23 → 1.0.24

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.
Files changed (254) hide show
  1. package/dist/bare-metal-partition.test.cjs +3 -4
  2. package/dist/bare-metal-partition.test.cjs.map +1 -1
  3. package/dist/bare-metal-partition.test.mjs +3 -4
  4. package/dist/bare-metal-partition.test.mjs.map +1 -1
  5. package/dist/composer.cjs +13 -1
  6. package/dist/composer.cjs.map +1 -1
  7. package/dist/composer.d.cts.map +1 -1
  8. package/dist/composer.d.mts.map +1 -1
  9. package/dist/composer.mjs +13 -1
  10. package/dist/composer.mjs.map +1 -1
  11. package/dist/composer.snapshot.test.cjs +1 -1
  12. package/dist/composer.snapshot.test.mjs +1 -1
  13. package/dist/composer.test.cjs +3 -2
  14. package/dist/composer.test.cjs.map +1 -1
  15. package/dist/composer.test.mjs +3 -2
  16. package/dist/composer.test.mjs.map +1 -1
  17. package/dist/deployers/strip-host-ports.test.cjs +1 -1
  18. package/dist/deployers/strip-host-ports.test.mjs +1 -1
  19. package/dist/generate.cjs +6 -2
  20. package/dist/generate.cjs.map +1 -1
  21. package/dist/generate.d.cts.map +1 -1
  22. package/dist/generate.d.mts.map +1 -1
  23. package/dist/generate.mjs +6 -2
  24. package/dist/generate.mjs.map +1 -1
  25. package/dist/generate.test.cjs +2 -2
  26. package/dist/generate.test.cjs.map +1 -1
  27. package/dist/generate.test.mjs +2 -2
  28. package/dist/generate.test.mjs.map +1 -1
  29. package/dist/generators/bare-metal-install.test.cjs +1 -1
  30. package/dist/generators/bare-metal-install.test.mjs +1 -1
  31. package/dist/generators/caddy.test.cjs +1 -1
  32. package/dist/generators/caddy.test.mjs +1 -1
  33. package/dist/generators/clone-repos.cjs +140 -0
  34. package/dist/generators/clone-repos.cjs.map +1 -0
  35. package/dist/generators/clone-repos.d.cts +11 -0
  36. package/dist/generators/clone-repos.d.cts.map +1 -0
  37. package/dist/generators/clone-repos.d.mts +11 -0
  38. package/dist/generators/clone-repos.d.mts.map +1 -0
  39. package/dist/generators/clone-repos.mjs +139 -0
  40. package/dist/generators/clone-repos.mjs.map +1 -0
  41. package/dist/generators/clone-repos.test.cjs +140 -0
  42. package/dist/generators/clone-repos.test.cjs.map +1 -0
  43. package/dist/generators/clone-repos.test.d.cts +1 -0
  44. package/dist/generators/clone-repos.test.d.mts +1 -0
  45. package/dist/generators/clone-repos.test.mjs +141 -0
  46. package/dist/generators/clone-repos.test.mjs.map +1 -0
  47. package/dist/generators/env.test.cjs +1 -1
  48. package/dist/generators/env.test.mjs +1 -1
  49. package/dist/generators/health-check.test.cjs +1 -1
  50. package/dist/generators/health-check.test.mjs +1 -1
  51. package/dist/generators/postgres-init.cjs +20 -0
  52. package/dist/generators/postgres-init.cjs.map +1 -1
  53. package/dist/generators/postgres-init.d.cts.map +1 -1
  54. package/dist/generators/postgres-init.d.mts.map +1 -1
  55. package/dist/generators/postgres-init.mjs +20 -0
  56. package/dist/generators/postgres-init.mjs.map +1 -1
  57. package/dist/generators/scripts.cjs +332 -3
  58. package/dist/generators/scripts.cjs.map +1 -1
  59. package/dist/generators/scripts.d.cts +3 -1
  60. package/dist/generators/scripts.d.cts.map +1 -1
  61. package/dist/generators/scripts.d.mts +3 -1
  62. package/dist/generators/scripts.d.mts.map +1 -1
  63. package/dist/generators/scripts.mjs +332 -3
  64. package/dist/generators/scripts.mjs.map +1 -1
  65. package/dist/generators/scripts.test.cjs +39 -5
  66. package/dist/generators/scripts.test.cjs.map +1 -1
  67. package/dist/generators/scripts.test.mjs +39 -5
  68. package/dist/generators/scripts.test.mjs.map +1 -1
  69. package/dist/generators/stack-manifest.cjs +1 -0
  70. package/dist/generators/stack-manifest.cjs.map +1 -1
  71. package/dist/generators/stack-manifest.d.cts +3 -2
  72. package/dist/generators/stack-manifest.d.cts.map +1 -1
  73. package/dist/generators/stack-manifest.d.mts +3 -2
  74. package/dist/generators/stack-manifest.d.mts.map +1 -1
  75. package/dist/generators/stack-manifest.mjs +1 -0
  76. package/dist/generators/stack-manifest.mjs.map +1 -1
  77. package/dist/generators/traefik.test.cjs +1 -1
  78. package/dist/generators/traefik.test.mjs +1 -1
  79. package/dist/index.cjs +8 -1
  80. package/dist/index.d.cts +5 -3
  81. package/dist/index.d.mts +5 -3
  82. package/dist/index.mjs +5 -3
  83. package/dist/migrations.test.cjs +1 -1
  84. package/dist/migrations.test.mjs +1 -1
  85. package/dist/presets/registry.cjs.map +1 -1
  86. package/dist/presets/registry.d.cts.map +1 -1
  87. package/dist/presets/registry.d.mts.map +1 -1
  88. package/dist/presets/registry.mjs.map +1 -1
  89. package/dist/presets/registry.test.cjs +1 -1
  90. package/dist/presets/registry.test.mjs +1 -1
  91. package/dist/resolver.cjs +8 -0
  92. package/dist/resolver.cjs.map +1 -1
  93. package/dist/resolver.mjs +9 -1
  94. package/dist/resolver.mjs.map +1 -1
  95. package/dist/resolver.test.cjs +47 -12
  96. package/dist/resolver.test.cjs.map +1 -1
  97. package/dist/resolver.test.mjs +47 -12
  98. package/dist/resolver.test.mjs.map +1 -1
  99. package/dist/{schema-B4c64P8N.d.cts → schema-eX44HhRp.d.mts} +62 -8
  100. package/dist/schema-eX44HhRp.d.mts.map +1 -0
  101. package/dist/{schema-CXNhYci1.d.mts → schema-tn5RK8CM.d.cts} +62 -8
  102. package/dist/schema-tn5RK8CM.d.cts.map +1 -0
  103. package/dist/schema.cjs +22 -4
  104. package/dist/schema.cjs.map +1 -1
  105. package/dist/schema.d.cts +2 -2
  106. package/dist/schema.d.mts +2 -2
  107. package/dist/schema.mjs +21 -5
  108. package/dist/schema.mjs.map +1 -1
  109. package/dist/schema.test.cjs +1 -1
  110. package/dist/schema.test.mjs +1 -1
  111. package/dist/services/definitions/apptension-saas.cjs +87 -0
  112. package/dist/services/definitions/apptension-saas.cjs.map +1 -0
  113. package/dist/services/definitions/apptension-saas.d.cts +7 -0
  114. package/dist/services/definitions/apptension-saas.d.cts.map +1 -0
  115. package/dist/services/definitions/apptension-saas.d.mts +7 -0
  116. package/dist/services/definitions/apptension-saas.d.mts.map +1 -0
  117. package/dist/services/definitions/apptension-saas.mjs +86 -0
  118. package/dist/services/definitions/apptension-saas.mjs.map +1 -0
  119. package/dist/services/definitions/boxyhq-saas.cjs +88 -0
  120. package/dist/services/definitions/boxyhq-saas.cjs.map +1 -0
  121. package/dist/services/definitions/boxyhq-saas.d.cts +7 -0
  122. package/dist/services/definitions/boxyhq-saas.d.cts.map +1 -0
  123. package/dist/services/definitions/boxyhq-saas.d.mts +7 -0
  124. package/dist/services/definitions/boxyhq-saas.d.mts.map +1 -0
  125. package/dist/services/definitions/boxyhq-saas.mjs +87 -0
  126. package/dist/services/definitions/boxyhq-saas.mjs.map +1 -0
  127. package/dist/services/definitions/cmsaas-starter.cjs +86 -0
  128. package/dist/services/definitions/cmsaas-starter.cjs.map +1 -0
  129. package/dist/services/definitions/cmsaas-starter.d.cts +7 -0
  130. package/dist/services/definitions/cmsaas-starter.d.cts.map +1 -0
  131. package/dist/services/definitions/cmsaas-starter.d.mts +7 -0
  132. package/dist/services/definitions/cmsaas-starter.d.mts.map +1 -0
  133. package/dist/services/definitions/cmsaas-starter.mjs +85 -0
  134. package/dist/services/definitions/cmsaas-starter.mjs.map +1 -0
  135. package/dist/services/definitions/index.cjs +51 -36
  136. package/dist/services/definitions/index.cjs.map +1 -1
  137. package/dist/services/definitions/index.d.cts +30 -25
  138. package/dist/services/definitions/index.d.cts.map +1 -1
  139. package/dist/services/definitions/index.d.mts +30 -25
  140. package/dist/services/definitions/index.d.mts.map +1 -1
  141. package/dist/services/definitions/index.mjs +47 -37
  142. package/dist/services/definitions/index.mjs.map +1 -1
  143. package/dist/services/definitions/ixartz-saas.cjs +88 -0
  144. package/dist/services/definitions/ixartz-saas.cjs.map +1 -0
  145. package/dist/services/definitions/ixartz-saas.d.cts +7 -0
  146. package/dist/services/definitions/ixartz-saas.d.cts.map +1 -0
  147. package/dist/services/definitions/ixartz-saas.d.mts +7 -0
  148. package/dist/services/definitions/ixartz-saas.d.mts.map +1 -0
  149. package/dist/services/definitions/ixartz-saas.mjs +87 -0
  150. package/dist/services/definitions/ixartz-saas.mjs.map +1 -0
  151. package/dist/services/definitions/mission-control.cjs +16 -2
  152. package/dist/services/definitions/mission-control.cjs.map +1 -1
  153. package/dist/services/definitions/mission-control.mjs +16 -2
  154. package/dist/services/definitions/mission-control.mjs.map +1 -1
  155. package/dist/services/definitions/open-saas.cjs +81 -0
  156. package/dist/services/definitions/open-saas.cjs.map +1 -0
  157. package/dist/services/definitions/open-saas.d.cts +7 -0
  158. package/dist/services/definitions/open-saas.d.cts.map +1 -0
  159. package/dist/services/definitions/open-saas.d.mts +7 -0
  160. package/dist/services/definitions/open-saas.d.mts.map +1 -0
  161. package/dist/services/definitions/open-saas.mjs +80 -0
  162. package/dist/services/definitions/open-saas.mjs.map +1 -0
  163. package/dist/services/registry.cjs +3 -0
  164. package/dist/services/registry.cjs.map +1 -1
  165. package/dist/services/registry.d.cts.map +1 -1
  166. package/dist/services/registry.d.mts.map +1 -1
  167. package/dist/services/registry.mjs +3 -0
  168. package/dist/services/registry.mjs.map +1 -1
  169. package/dist/services/registry.test.cjs +8 -1
  170. package/dist/services/registry.test.cjs.map +1 -1
  171. package/dist/services/registry.test.mjs +8 -1
  172. package/dist/services/registry.test.mjs.map +1 -1
  173. package/dist/{skill-manifest-BVUXU0__.mjs → skill-manifest-6XhrhWsG.mjs} +49 -1
  174. package/dist/{skill-manifest--IgY9REK.cjs.map → skill-manifest-6XhrhWsG.mjs.map} +1 -1
  175. package/dist/{skill-manifest--IgY9REK.cjs → skill-manifest-B8znSsym.cjs} +49 -1
  176. package/dist/{skill-manifest-BVUXU0__.mjs.map → skill-manifest-B8znSsym.cjs.map} +1 -1
  177. package/dist/skills/registry.cjs +3 -3
  178. package/dist/skills/registry.cjs.map +1 -1
  179. package/dist/skills/registry.mjs +3 -3
  180. package/dist/skills/registry.mjs.map +1 -1
  181. package/dist/skills/skill-manifest.cjs +1 -1
  182. package/dist/skills/skill-manifest.mjs +1 -1
  183. package/dist/track-analytics.cjs +50 -0
  184. package/dist/track-analytics.cjs.map +1 -0
  185. package/dist/track-analytics.d.cts +34 -0
  186. package/dist/track-analytics.d.cts.map +1 -0
  187. package/dist/track-analytics.d.mts +34 -0
  188. package/dist/track-analytics.d.mts.map +1 -0
  189. package/dist/track-analytics.mjs +48 -0
  190. package/dist/track-analytics.mjs.map +1 -0
  191. package/dist/track-analytics.test.cjs +91 -0
  192. package/dist/track-analytics.test.cjs.map +1 -0
  193. package/dist/track-analytics.test.d.cts +1 -0
  194. package/dist/track-analytics.test.d.mts +1 -0
  195. package/dist/track-analytics.test.mjs +92 -0
  196. package/dist/track-analytics.test.mjs.map +1 -0
  197. package/dist/types.cjs +7 -0
  198. package/dist/types.cjs.map +1 -1
  199. package/dist/types.d.cts +4 -2
  200. package/dist/types.d.cts.map +1 -1
  201. package/dist/types.d.mts +4 -2
  202. package/dist/types.d.mts.map +1 -1
  203. package/dist/types.mjs +7 -0
  204. package/dist/types.mjs.map +1 -1
  205. package/dist/validator.test.cjs +1 -1
  206. package/dist/validator.test.mjs +1 -1
  207. package/dist/version-manager.cjs +1 -1
  208. package/dist/version-manager.cjs.map +1 -1
  209. package/dist/version-manager.mjs +1 -1
  210. package/dist/version-manager.mjs.map +1 -1
  211. package/dist/version-manager.test.cjs +7 -5
  212. package/dist/version-manager.test.cjs.map +1 -1
  213. package/dist/version-manager.test.mjs +7 -5
  214. package/dist/version-manager.test.mjs.map +1 -1
  215. package/dist/{vi.2VT5v0um-DvC3SVNc.mjs → vi.2VT5v0um-C_jmO7m2.mjs} +5 -5
  216. package/dist/{vi.2VT5v0um-DvC3SVNc.mjs.map → vi.2VT5v0um-C_jmO7m2.mjs.map} +1 -1
  217. package/dist/{vi.2VT5v0um-CRqXre87.cjs → vi.2VT5v0um-iVBt6Fyq.cjs} +5 -5
  218. package/dist/{vi.2VT5v0um-CRqXre87.cjs.map → vi.2VT5v0um-iVBt6Fyq.cjs.map} +1 -1
  219. package/package.json +1 -1
  220. package/src/__snapshots__/composer.snapshot.test.ts.snap +155 -0
  221. package/src/bare-metal-partition.test.ts +4 -3
  222. package/src/composer.test.ts +4 -2
  223. package/src/composer.ts +20 -1
  224. package/src/generate.test.ts +2 -1
  225. package/src/generate.ts +10 -1
  226. package/src/generators/clone-repos.test.ts +154 -0
  227. package/src/generators/clone-repos.ts +159 -0
  228. package/src/generators/postgres-init.ts +17 -0
  229. package/src/generators/scripts.test.ts +52 -4
  230. package/src/generators/scripts.ts +351 -3
  231. package/src/generators/stack-manifest.ts +4 -2
  232. package/src/index.ts +8 -0
  233. package/src/presets/registry.ts +241 -329
  234. package/src/resolver.test.ts +53 -15
  235. package/src/resolver.ts +13 -1
  236. package/src/schema.ts +33 -4
  237. package/src/services/definitions/apptension-saas.ts +84 -0
  238. package/src/services/definitions/boxyhq-saas.ts +84 -0
  239. package/src/services/definitions/cmsaas-starter.ts +84 -0
  240. package/src/services/definitions/index.ts +90 -70
  241. package/src/services/definitions/ixartz-saas.ts +84 -0
  242. package/src/services/definitions/mission-control.ts +19 -2
  243. package/src/services/definitions/open-saas.ts +79 -0
  244. package/src/services/registry.test.ts +8 -0
  245. package/src/services/registry.ts +7 -0
  246. package/src/skills/manifest.json +64 -0
  247. package/src/skills/registry.ts +3 -3
  248. package/src/track-analytics.test.ts +82 -0
  249. package/src/track-analytics.ts +76 -0
  250. package/src/types.ts +11 -0
  251. package/src/version-manager.test.ts +10 -5
  252. package/src/version-manager.ts +1 -1
  253. package/dist/schema-B4c64P8N.d.cts.map +0 -1
  254. package/dist/schema-CXNhYci1.d.mts.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"schema.mjs","names":[],"sources":["../src/schema.ts"],"sourcesContent":["import { z } from \"zod\";\n\n// ─── Enums ──────────────────────────────────────────────────────────────────\n\nexport const ServiceCategorySchema = z.enum([\n\t\"automation\",\n\t\"vector-db\",\n\t\"media\",\n\t\"storage\",\n\t\"database\",\n\t\"proxy\",\n\t\"monitoring\",\n\t\"browser\",\n\t\"search\",\n\t\"ai\",\n\t\"communication\",\n\t\"coding-agent\",\n\t\"social-media\",\n\t\"analytics\",\n\t\"ai-platform\",\n\t\"dev-tools\",\n\t\"knowledge\",\n\t\"desktop\",\n\t\"streaming\",\n\t\"security\",\n\t\"billing\",\n\t\"crm\",\n\t\"email-marketing\",\n\t\"forms\",\n\t\"api-gateway\",\n\t\"backup\",\n\t\"voice\",\n\t\"ecommerce\",\n\t\"collaboration\",\n\t\"ai-observability\",\n\t\"fine-tuning\",\n\t\"project-management\",\n\t\"business-intelligence\",\n\t\"dns-networking\",\n\t\"iot\",\n]);\n\nexport const MaturitySchema = z.enum([\"stable\", \"beta\", \"experimental\"]);\n\nexport const PlatformSchema = z.enum([\n\t\"linux/amd64\",\n\t\"linux/arm64\",\n\t\"windows/amd64\",\n\t\"macos/amd64\",\n\t\"macos/arm64\",\n]);\n\n/** Platform for Docker image arch only (used by resolver/compose). */\nexport const ComposePlatformSchema = z.enum([\"linux/amd64\", \"linux/arm64\"]);\n\nexport const DeploymentTypeSchema = z.enum([\"docker\", \"bare-metal\", \"local\"]);\n\nexport const RestartPolicySchema = z.enum([\"unless-stopped\", \"always\", \"on-failure\", \"no\"]);\n\nexport const ProxyTypeSchema = z.enum([\"none\", \"caddy\", \"traefik\"]);\n\nexport const DeploymentTargetSchema = z.enum([\"local\", \"vps\", \"homelab\", \"clawexa\"]);\n\nexport const OutputFormatSchema = z.enum([\"directory\", \"tar\", \"zip\"]);\n\nexport const OpenclawImageVariantSchema = z.enum([\"official\", \"coolify\", \"alpine\"]);\n\nexport const OpenclawInstallMethodSchema = z.enum([\"docker\", \"direct\"]);\n\nexport const DeployTargetSchema = z.enum([\"local\", \"cloud-init\"]);\n\nexport const AiProviderSchema = z.enum([\n\t\"openai\",\n\t\"anthropic\",\n\t\"google\",\n\t\"xai\",\n\t\"deepseek\",\n\t\"groq\",\n\t\"openrouter\",\n\t\"mistral\",\n\t\"together\",\n\t\"ollama\",\n\t\"ollama-cloud\",\n\t\"lmstudio\",\n\t\"vllm\",\n]);\n\nexport const GsdRuntimeSchema = z.enum([\"claude\", \"opencode\", \"gemini\", \"codex\"]);\n\n// ─── Sub-Schemas ────────────────────────────────────────────────────────────\n\nexport const PortMappingSchema = z.object({\n\thost: z.number().int().min(1).max(65535),\n\tcontainer: z.number().int().min(1).max(65535),\n\tdescription: z.string(),\n\texposed: z.boolean().default(true),\n});\n\nexport const VolumeMappingSchema = z.object({\n\tname: z.string().min(1),\n\tcontainerPath: z.string().min(1),\n\tdescription: z.string(),\n\tdriver: z.string().optional(),\n});\n\nexport const EnvVariableSchema = z.object({\n\tkey: z.string().min(1),\n\tdefaultValue: z.string(),\n\tsecret: z.boolean().default(false),\n\tdescription: z.string(),\n\trequired: z.boolean().default(true),\n\tvalidation: z.string().optional(),\n});\n\nexport const HealthCheckSchema = z.object({\n\ttest: z.string().min(1),\n\tinterval: z.string().default(\"30s\"),\n\ttimeout: z.string().default(\"10s\"),\n\tretries: z.number().int().min(1).default(3),\n\tstartPeriod: z.string().optional(),\n});\n\nexport const ResourceLimitsSchema = z.object({\n\tcpus: z.string().optional(),\n\tmemory: z.string().optional(),\n});\n\nexport const DeploySchema = z.object({\n\tresources: z\n\t\t.object({\n\t\t\tlimits: ResourceLimitsSchema.optional(),\n\t\t\treservations: ResourceLimitsSchema.optional(),\n\t\t})\n\t\t.optional(),\n});\n\nexport const SkillBindingSchema = z.object({\n\tskillId: z.string().min(1),\n\tautoInstall: z.boolean().default(true),\n\tconfigOverrides: z.record(z.string(), z.string()).optional(),\n});\n\n/** Platform for native install (linux, windows, macos — no arch). */\nexport const NativePlatformSchema = z.enum([\"linux\", \"windows\", \"macos\"]);\n\nexport const NativeRecipeSchema = z.object({\n\tplatform: NativePlatformSchema,\n\tinstallSteps: z.array(z.string()).min(1),\n\tstartCommand: z.string(),\n\tstopCommand: z.string().optional(),\n\tconfigPath: z.string().optional(),\n\tconfigTemplate: z.string().optional(),\n\tsystemdUnit: z.string().optional(),\n});\n\n// ─── Service Definition ─────────────────────────────────────────────────────\n\nexport const ServiceDefinitionSchema = z.object({\n\t// Identity\n\tid: z\n\t\t.string()\n\t\t.min(1)\n\t\t.regex(/^[a-z0-9-]+$/),\n\tname: z.string().min(1),\n\tdescription: z.string(),\n\tcategory: ServiceCategorySchema,\n\ticon: z.string(),\n\n\t// Docker\n\timage: z.string().min(1),\n\timageTag: z.string().min(1),\n\tports: z.array(PortMappingSchema).default([]),\n\tvolumes: z.array(VolumeMappingSchema).default([]),\n\tenvironment: z.array(EnvVariableSchema).default([]),\n\thealthcheck: HealthCheckSchema.optional(),\n\tcommand: z.string().optional(),\n\tentrypoint: z.string().optional(),\n\tdependsOn: z.array(z.string()).default([]),\n\trestartPolicy: RestartPolicySchema.default(\"unless-stopped\"),\n\tnetworks: z.array(z.string()).default([\"openclaw-network\"]),\n\tlabels: z.record(z.string(), z.string()).optional(),\n\tdeploy: DeploySchema.optional(),\n\n\t// OpenClaw Integration\n\tskills: z.array(SkillBindingSchema).default([]),\n\topenclawEnvVars: z.array(EnvVariableSchema).default([]),\n\topenclawVolumeMounts: z.array(VolumeMappingSchema).optional(),\n\n\t// Metadata\n\tdocsUrl: z.string().url(),\n\tselfHostedDocsUrl: z.string().url().optional(),\n\ttags: z.array(z.string()).default([]),\n\tmaturity: MaturitySchema.default(\"stable\"),\n\n\t// Dependencies & Conflicts\n\trequires: z.array(z.string()).default([]),\n\trecommends: z.array(z.string()).default([]),\n\tconflictsWith: z.array(z.string()).default([]),\n\tmandatory: z.boolean().default(false).optional(),\n\tremovalWarning: z.string().optional(),\n\n\t// Platform Constraints\n\tplatforms: z.array(PlatformSchema).optional(),\n\tminMemoryMB: z.number().int().min(0).optional(),\n\tgpuRequired: z.boolean().default(false),\n\n\t// Bare-metal native (install/run on host when no Docker)\n\tnativeSupported: z.boolean().optional(),\n\tnativeRecipes: z.array(NativeRecipeSchema).optional(),\n});\n\n// ─── Skill Pack ─────────────────────────────────────────────────────────────\n\nexport const SkillPackSchema = z.object({\n\tid: z\n\t\t.string()\n\t\t.min(1)\n\t\t.regex(/^[a-z0-9-]+$/),\n\tname: z.string().min(1),\n\tdescription: z.string(),\n\trequiredServices: z.array(z.string()).min(1),\n\tskills: z.array(z.string()),\n\ticon: z.string().optional(),\n\ttags: z.array(z.string()).default([]),\n});\n\n// ─── Preset ─────────────────────────────────────────────────────────────────\n\nexport const PresetSchema = z.object({\n\tid: z\n\t\t.string()\n\t\t.min(1)\n\t\t.regex(/^[a-z0-9-]+$/),\n\tname: z.string().min(1),\n\tdescription: z.string(),\n\tservices: z.array(z.string()),\n\tskillPacks: z.array(z.string()).default([]),\n\testimatedMemoryMB: z.number().int().min(0).optional(),\n});\n\n// ─── Generation Input ───────────────────────────────────────────────────────\n\nexport const GenerationInputSchema = z.object({\n\tconfigVersion: z.number().int().min(1).optional(),\n\tprojectName: z\n\t\t.string()\n\t\t.min(1)\n\t\t.max(64)\n\t\t.regex(/^[a-z0-9][a-z0-9-]*[a-z0-9]$|^[a-z0-9]$/, {\n\t\t\tmessage:\n\t\t\t\t\"Project name must be lowercase alphanumeric with hyphens, cannot start or end with hyphen\",\n\t\t}),\n\tservices: z.array(z.string()).default([]),\n\tskillPacks: z.array(z.string()).default([]),\n\taiProviders: z.array(AiProviderSchema).default([]),\n\tgsdRuntimes: z.array(GsdRuntimeSchema).default([]),\n\tproxy: ProxyTypeSchema.default(\"none\"),\n\tproxyHttpPort: z.number().int().min(1).max(65535).optional(),\n\tproxyHttpsPort: z.number().int().min(1).max(65535).optional(),\n\tportOverrides: z\n\t\t.record(z.string(), z.record(z.string(), z.number().int().min(1).max(65535)))\n\t\t.optional(),\n\tdomain: z.string().optional(),\n\tgpu: z.boolean().default(false),\n\tplatform: PlatformSchema.default(\"linux/amd64\"),\n\tdeployment: DeploymentTargetSchema.default(\"local\"),\n\tdeploymentType: DeploymentTypeSchema.default(\"docker\"),\n\tgenerateSecrets: z.boolean().default(true),\n\topenclawVersion: z.string().default(\"latest\"),\n\tmonitoring: z.boolean().default(false),\n\topenclawImage: OpenclawImageVariantSchema.default(\"official\"),\n\topenclawInstallMethod: OpenclawInstallMethodSchema.default(\"docker\"),\n\tdeployTarget: DeployTargetSchema.default(\"local\"),\n\thardened: z.boolean().default(true),\n});\n\n// ─── Resolver Output ────────────────────────────────────────────────────────\n\nexport const ResolvedServiceSchema = z.object({\n\tdefinition: ServiceDefinitionSchema,\n\taddedBy: z.enum([\"user\", \"dependency\", \"skill-pack\", \"proxy\", \"monitoring\"]).default(\"user\"),\n});\n\nexport const AddedDependencySchema = z.object({\n\tservice: z.string(),\n\tserviceId: z.string().optional(),\n\trequiredBy: z.string().optional(),\n\treason: z.string(),\n});\n\nexport const WarningSchema = z.object({\n\ttype: z.string(),\n\tmessage: z.string(),\n});\n\nexport const ErrorSchema = z.object({\n\ttype: z.string(),\n\tmessage: z.string(),\n});\n\nexport const ResolverOutputSchema = z.object({\n\tservices: z.array(ResolvedServiceSchema),\n\taddedDependencies: z.array(AddedDependencySchema),\n\tremovedConflicts: z.array(z.object({ service: z.string(), reason: z.string() })),\n\twarnings: z.array(WarningSchema),\n\terrors: z.array(ErrorSchema),\n\tisValid: z.boolean(),\n\testimatedMemoryMB: z.number().int().min(0),\n\taiProviders: z.array(AiProviderSchema).default([]),\n\tgsdRuntimes: z.array(GsdRuntimeSchema).default([]),\n});\n\n// ─── Compose Options ────────────────────────────────────────────────────────\n\nexport const ComposeOptionsSchema = z.object({\n\tprojectName: z.string(),\n\tproxy: ProxyTypeSchema.default(\"none\"),\n\tproxyHttpPort: z.number().int().min(1).max(65535).optional(),\n\tproxyHttpsPort: z.number().int().min(1).max(65535).optional(),\n\tportOverrides: z\n\t\t.record(z.string(), z.record(z.string(), z.number().int().min(1).max(65535)))\n\t\t.optional(),\n\tdomain: z.string().optional(),\n\tgpu: z.boolean().default(false),\n\tplatform: PlatformSchema.default(\"linux/amd64\"),\n\tdeployment: DeploymentTargetSchema.default(\"local\"),\n\topenclawVersion: z.string().default(\"latest\"),\n\t/** When true, gateway gets extra_hosts so it can reach host-run (native) services. */\n\tbareMetalNativeHost: z.boolean().optional(),\n\t/** OpenClaw Docker image variant: official, coolify, or alpine. */\n\topenclawImage: OpenclawImageVariantSchema.default(\"official\"),\n\t/** Whether to apply security hardening (cap_drop, no-new-privileges, etc.) */\n\thardened: z.boolean().default(true),\n\t/** How to install OpenClaw itself: docker (in container) or direct (host install). */\n\topenclawInstallMethod: OpenclawInstallMethodSchema.default(\"docker\"),\n});\n\n// ─── API Request/Response ───────────────────────────────────────────────────\n\nexport const ValidateRequestSchema = z.object({\n\tservices: z.array(z.string()),\n\tskillPacks: z.array(z.string()).default([]),\n\taiProviders: z.array(AiProviderSchema).default([]),\n\tgsdRuntimes: z.array(GsdRuntimeSchema).default([]),\n\tproxy: ProxyTypeSchema.default(\"none\"),\n\tdomain: z.string().optional(),\n\tgpu: z.boolean().default(false),\n\tplatform: PlatformSchema.default(\"linux/amd64\"),\n});\n\nexport const ValidateResponseSchema = z.object({\n\tvalid: z.boolean(),\n\tresolvedServices: z.array(z.string()),\n\taddedDependencies: z.array(AddedDependencySchema),\n\twarnings: z.array(WarningSchema),\n\tconflicts: z.array(ErrorSchema),\n\testimatedMemoryMB: z.number(),\n});\n\nexport const ApiErrorSchema = z.object({\n\terror: z.object({\n\t\tcode: z.enum([\n\t\t\t\"VALIDATION_ERROR\",\n\t\t\t\"CONFLICT_ERROR\",\n\t\t\t\"GENERATION_ERROR\",\n\t\t\t\"RATE_LIMITED\",\n\t\t\t\"INTERNAL_ERROR\",\n\t\t]),\n\t\tmessage: z.string(),\n\t\tdetails: z\n\t\t\t.array(\n\t\t\t\tz.object({\n\t\t\t\t\tfield: z.string().optional(),\n\t\t\t\t\tmessage: z.string(),\n\t\t\t\t}),\n\t\t\t)\n\t\t\t.optional(),\n\t}),\n});\n"],"mappings":"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"}
1
+ {"version":3,"file":"schema.mjs","names":[],"sources":["../src/schema.ts"],"sourcesContent":["import { z } from \"zod\";\n\n// ─── Enums ──────────────────────────────────────────────────────────────────\n\nexport const ServiceCategorySchema = z.enum([\n\t\"automation\",\n\t\"vector-db\",\n\t\"media\",\n\t\"storage\",\n\t\"database\",\n\t\"proxy\",\n\t\"monitoring\",\n\t\"browser\",\n\t\"search\",\n\t\"ai\",\n\t\"communication\",\n\t\"coding-agent\",\n\t\"social-media\",\n\t\"analytics\",\n\t\"ai-platform\",\n\t\"dev-tools\",\n\t\"knowledge\",\n\t\"desktop\",\n\t\"streaming\",\n\t\"security\",\n\t\"billing\",\n\t\"crm\",\n\t\"email-marketing\",\n\t\"forms\",\n\t\"api-gateway\",\n\t\"backup\",\n\t\"voice\",\n\t\"ecommerce\",\n\t\"collaboration\",\n\t\"ai-observability\",\n\t\"fine-tuning\",\n\t\"project-management\",\n\t\"business-intelligence\",\n\t\"dns-networking\",\n\t\"iot\",\n\t\"saas-boilerplate\",\n]);\n\nexport const MaturitySchema = z.enum([\"stable\", \"beta\", \"experimental\"]);\n\nexport const PlatformSchema = z.enum([\n\t\"linux/amd64\",\n\t\"linux/arm64\",\n\t\"windows/amd64\",\n\t\"macos/amd64\",\n\t\"macos/arm64\",\n]);\n\n/** Platform for Docker image arch only (used by resolver/compose). */\nexport const ComposePlatformSchema = z.enum([\"linux/amd64\", \"linux/arm64\"]);\n\nexport const DeploymentTypeSchema = z.enum([\"docker\", \"bare-metal\", \"local\"]);\n\nexport const RestartPolicySchema = z.enum([\"unless-stopped\", \"always\", \"on-failure\", \"no\"]);\n\nexport const ProxyTypeSchema = z.enum([\"none\", \"caddy\", \"traefik\"]);\n\nexport const DeploymentTargetSchema = z.enum([\"local\", \"vps\", \"homelab\", \"clawexa\"]);\n\nexport const OutputFormatSchema = z.enum([\"directory\", \"tar\", \"zip\"]);\n\nexport const OpenclawImageVariantSchema = z.enum([\"official\", \"coolify\", \"alpine\"]);\n\nexport const OpenclawInstallMethodSchema = z.enum([\"docker\", \"direct\"]);\n\nexport const DeployTargetSchema = z.enum([\"local\", \"cloud-init\"]);\n\nexport const AiProviderSchema = z.enum([\n\t\"openai\",\n\t\"anthropic\",\n\t\"google\",\n\t\"xai\",\n\t\"deepseek\",\n\t\"groq\",\n\t\"openrouter\",\n\t\"mistral\",\n\t\"together\",\n\t\"ollama\",\n\t\"ollama-cloud\",\n\t\"lmstudio\",\n\t\"vllm\",\n]);\n\nexport const GsdRuntimeSchema = z.enum([\"claude\", \"opencode\", \"gemini\", \"codex\"]);\n\n// ─── Sub-Schemas ────────────────────────────────────────────────────────────\n\nexport const PortMappingSchema = z.object({\n\thost: z.number().int().min(1).max(65535),\n\tcontainer: z.number().int().min(1).max(65535),\n\tdescription: z.string(),\n\texposed: z.boolean().default(true),\n});\n\nexport const VolumeMappingSchema = z.object({\n\tname: z.string().min(1),\n\tcontainerPath: z.string().min(1),\n\tdescription: z.string(),\n\tdriver: z.string().optional(),\n});\n\nexport const EnvVariableSchema = z.object({\n\tkey: z.string().min(1),\n\tdefaultValue: z.string(),\n\tsecret: z.boolean().default(false),\n\tdescription: z.string(),\n\trequired: z.boolean().default(true),\n\tvalidation: z.string().optional(),\n});\n\nexport const HealthCheckSchema = z.object({\n\ttest: z.string().min(1),\n\tinterval: z.string().default(\"30s\"),\n\ttimeout: z.string().default(\"10s\"),\n\tretries: z.number().int().min(1).default(3),\n\tstartPeriod: z.string().optional(),\n});\n\nexport const ResourceLimitsSchema = z.object({\n\tcpus: z.string().optional(),\n\tmemory: z.string().optional(),\n});\n\nexport const DeploySchema = z.object({\n\tresources: z\n\t\t.object({\n\t\t\tlimits: ResourceLimitsSchema.optional(),\n\t\t\treservations: ResourceLimitsSchema.optional(),\n\t\t})\n\t\t.optional(),\n});\n\nexport const SkillBindingSchema = z.object({\n\tskillId: z.string().min(1),\n\tautoInstall: z.boolean().default(true),\n\tconfigOverrides: z.record(z.string(), z.string()).optional(),\n});\n\n/** Platform for native install (linux, windows, macos — no arch). */\nexport const NativePlatformSchema = z.enum([\"linux\", \"windows\", \"macos\"]);\n\nexport const NativeRecipeSchema = z.object({\n\tplatform: NativePlatformSchema,\n\tinstallSteps: z.array(z.string()).min(1),\n\tstartCommand: z.string(),\n\tstopCommand: z.string().optional(),\n\tconfigPath: z.string().optional(),\n\tconfigTemplate: z.string().optional(),\n\tsystemdUnit: z.string().optional(),\n});\n\n// ─── Git Source / Build Context (for repo-based services) ───────────────────\n\nexport const GitSourceSchema = z.object({\n\t/** Git clone URL, e.g. \"https://github.com/wasp-lang/open-saas.git\" */\n\trepoUrl: z.string().url(),\n\t/** Branch or tag to clone. Defaults to repo's default branch. */\n\tbranch: z.string().optional(),\n\t/** Subdirectory within the cloned repo to use as build context root. */\n\tsubdirectory: z.string().optional(),\n\t/** Commands to run after cloning (e.g. \"cp .env.example .env\"). */\n\tpostCloneCommands: z.array(z.string()).default([]),\n});\n\nexport const BuildContextSchema = z.object({\n\t/** Path to Dockerfile relative to the context root. Defaults to \"Dockerfile\". */\n\tdockerfile: z.string().optional(),\n\t/** Build context path relative to the subdirectory root. Defaults to \".\". */\n\tcontext: z.string().default(\".\"),\n\t/** Docker build args to pass at build time. */\n\targs: z.record(z.string(), z.string()).optional(),\n\t/** Target stage in a multi-stage Dockerfile. */\n\ttarget: z.string().optional(),\n});\n\n// ─── Service Definition ─────────────────────────────────────────────────────\n\nexport const ServiceDefinitionSchema = z.object({\n\t// Identity\n\tid: z\n\t\t.string()\n\t\t.min(1)\n\t\t.regex(/^[a-z0-9-]+$/),\n\tname: z.string().min(1),\n\tdescription: z.string(),\n\tcategory: ServiceCategorySchema,\n\ticon: z.string(),\n\n\t// Docker (required for image-based services, omitted for git-based)\n\timage: z.string().min(1).optional(),\n\timageTag: z.string().min(1).optional(),\n\n\t// Git source (for services built from cloned repositories)\n\tgitSource: GitSourceSchema.optional(),\n\tbuildContext: BuildContextSchema.optional(),\n\tports: z.array(PortMappingSchema).default([]),\n\tvolumes: z.array(VolumeMappingSchema).default([]),\n\tenvironment: z.array(EnvVariableSchema).default([]),\n\thealthcheck: HealthCheckSchema.optional(),\n\tcommand: z.string().optional(),\n\tentrypoint: z.string().optional(),\n\tdependsOn: z.array(z.string()).default([]),\n\trestartPolicy: RestartPolicySchema.default(\"unless-stopped\"),\n\tnetworks: z.array(z.string()).default([\"openclaw-network\"]),\n\tlabels: z.record(z.string(), z.string()).optional(),\n\tdeploy: DeploySchema.optional(),\n\n\t// OpenClaw Integration\n\tskills: z.array(SkillBindingSchema).default([]),\n\topenclawEnvVars: z.array(EnvVariableSchema).default([]),\n\topenclawVolumeMounts: z.array(VolumeMappingSchema).optional(),\n\n\t// Metadata\n\tdocsUrl: z.string().url(),\n\tselfHostedDocsUrl: z.string().url().optional(),\n\ttags: z.array(z.string()).default([]),\n\tmaturity: MaturitySchema.default(\"stable\"),\n\n\t// Dependencies & Conflicts\n\trequires: z.array(z.string()).default([]),\n\trecommends: z.array(z.string()).default([]),\n\tconflictsWith: z.array(z.string()).default([]),\n\tmandatory: z.boolean().default(false).optional(),\n\tremovalWarning: z.string().optional(),\n\n\t// Platform Constraints\n\tplatforms: z.array(PlatformSchema).optional(),\n\tminMemoryMB: z.number().int().min(0).optional(),\n\tgpuRequired: z.boolean().default(false),\n\n\t// Bare-metal native (install/run on host when no Docker)\n\tnativeSupported: z.boolean().optional(),\n\tnativeRecipes: z.array(NativeRecipeSchema).optional(),\n});\n\n// ─── Skill Pack ─────────────────────────────────────────────────────────────\n\nexport const SkillPackSchema = z.object({\n\tid: z\n\t\t.string()\n\t\t.min(1)\n\t\t.regex(/^[a-z0-9-]+$/),\n\tname: z.string().min(1),\n\tdescription: z.string(),\n\trequiredServices: z.array(z.string()).min(1),\n\tskills: z.array(z.string()),\n\ticon: z.string().optional(),\n\ttags: z.array(z.string()).default([]),\n});\n\n// ─── Preset ─────────────────────────────────────────────────────────────────\n\nexport const PresetSchema = z.object({\n\tid: z\n\t\t.string()\n\t\t.min(1)\n\t\t.regex(/^[a-z0-9-]+$/),\n\tname: z.string().min(1),\n\tdescription: z.string(),\n\tservices: z.array(z.string()),\n\tskillPacks: z.array(z.string()).default([]),\n\testimatedMemoryMB: z.number().int().min(0).optional(),\n});\n\n// ─── Generation Input ───────────────────────────────────────────────────────\n\nexport const GenerationInputSchema = z.object({\n\tconfigVersion: z.number().int().min(1).optional(),\n\tprojectName: z\n\t\t.string()\n\t\t.min(1)\n\t\t.max(64)\n\t\t.regex(/^[a-z0-9][a-z0-9-]*[a-z0-9]$|^[a-z0-9]$/, {\n\t\t\tmessage:\n\t\t\t\t\"Project name must be lowercase alphanumeric with hyphens, cannot start or end with hyphen\",\n\t\t}),\n\tservices: z.array(z.string()).default([]),\n\tskillPacks: z.array(z.string()).default([]),\n\taiProviders: z.array(AiProviderSchema).default([]),\n\tgsdRuntimes: z.array(GsdRuntimeSchema).default([]),\n\tproxy: ProxyTypeSchema.default(\"none\"),\n\tproxyHttpPort: z.number().int().min(1).max(65535).optional(),\n\tproxyHttpsPort: z.number().int().min(1).max(65535).optional(),\n\tportOverrides: z\n\t\t.record(z.string(), z.record(z.string(), z.number().int().min(1).max(65535)))\n\t\t.optional(),\n\tdomain: z.string().optional(),\n\tgpu: z.boolean().default(false),\n\tplatform: PlatformSchema.default(\"linux/amd64\"),\n\tdeployment: DeploymentTargetSchema.default(\"local\"),\n\tdeploymentType: DeploymentTypeSchema.default(\"docker\"),\n\tgenerateSecrets: z.boolean().default(true),\n\topenclawVersion: z.string().default(\"latest\"),\n\tmonitoring: z.boolean().default(false),\n\topenclawImage: OpenclawImageVariantSchema.default(\"official\"),\n\topenclawInstallMethod: OpenclawInstallMethodSchema.default(\"docker\"),\n\tdeployTarget: DeployTargetSchema.default(\"local\"),\n\thardened: z.boolean().default(true),\n});\n\n// ─── Resolver Output ────────────────────────────────────────────────────────\n\nexport const ResolvedServiceSchema = z.object({\n\tdefinition: ServiceDefinitionSchema,\n\taddedBy: z.enum([\"user\", \"dependency\", \"skill-pack\", \"proxy\", \"monitoring\", \"mandatory\"]).default(\"user\"),\n});\n\nexport const AddedDependencySchema = z.object({\n\tservice: z.string(),\n\tserviceId: z.string().optional(),\n\trequiredBy: z.string().optional(),\n\treason: z.string(),\n});\n\nexport const WarningSchema = z.object({\n\ttype: z.string(),\n\tmessage: z.string(),\n});\n\nexport const ErrorSchema = z.object({\n\ttype: z.string(),\n\tmessage: z.string(),\n});\n\nexport const ResolverOutputSchema = z.object({\n\tservices: z.array(ResolvedServiceSchema),\n\taddedDependencies: z.array(AddedDependencySchema),\n\tremovedConflicts: z.array(z.object({ service: z.string(), reason: z.string() })),\n\twarnings: z.array(WarningSchema),\n\terrors: z.array(ErrorSchema),\n\tisValid: z.boolean(),\n\testimatedMemoryMB: z.number().int().min(0),\n\taiProviders: z.array(AiProviderSchema).default([]),\n\tgsdRuntimes: z.array(GsdRuntimeSchema).default([]),\n});\n\n// ─── Compose Options ────────────────────────────────────────────────────────\n\nexport const ComposeOptionsSchema = z.object({\n\tprojectName: z.string(),\n\tproxy: ProxyTypeSchema.default(\"none\"),\n\tproxyHttpPort: z.number().int().min(1).max(65535).optional(),\n\tproxyHttpsPort: z.number().int().min(1).max(65535).optional(),\n\tportOverrides: z\n\t\t.record(z.string(), z.record(z.string(), z.number().int().min(1).max(65535)))\n\t\t.optional(),\n\tdomain: z.string().optional(),\n\tgpu: z.boolean().default(false),\n\tplatform: PlatformSchema.default(\"linux/amd64\"),\n\tdeployment: DeploymentTargetSchema.default(\"local\"),\n\topenclawVersion: z.string().default(\"latest\"),\n\t/** When true, gateway gets extra_hosts so it can reach host-run (native) services. */\n\tbareMetalNativeHost: z.boolean().optional(),\n\t/** OpenClaw Docker image variant: official, coolify, or alpine. */\n\topenclawImage: OpenclawImageVariantSchema.default(\"official\"),\n\t/** Whether to apply security hardening (cap_drop, no-new-privileges, etc.) */\n\thardened: z.boolean().default(true),\n\t/** How to install OpenClaw itself: docker (in container) or direct (host install). */\n\topenclawInstallMethod: OpenclawInstallMethodSchema.default(\"docker\"),\n});\n\n// ─── API Request/Response ───────────────────────────────────────────────────\n\nexport const ValidateRequestSchema = z.object({\n\tservices: z.array(z.string()),\n\tskillPacks: z.array(z.string()).default([]),\n\taiProviders: z.array(AiProviderSchema).default([]),\n\tgsdRuntimes: z.array(GsdRuntimeSchema).default([]),\n\tproxy: ProxyTypeSchema.default(\"none\"),\n\tdomain: z.string().optional(),\n\tgpu: z.boolean().default(false),\n\tplatform: PlatformSchema.default(\"linux/amd64\"),\n});\n\nexport const ValidateResponseSchema = z.object({\n\tvalid: z.boolean(),\n\tresolvedServices: z.array(z.string()),\n\taddedDependencies: z.array(AddedDependencySchema),\n\twarnings: z.array(WarningSchema),\n\tconflicts: z.array(ErrorSchema),\n\testimatedMemoryMB: z.number(),\n});\n\nexport const ApiErrorSchema = z.object({\n\terror: z.object({\n\t\tcode: z.enum([\n\t\t\t\"VALIDATION_ERROR\",\n\t\t\t\"CONFLICT_ERROR\",\n\t\t\t\"GENERATION_ERROR\",\n\t\t\t\"RATE_LIMITED\",\n\t\t\t\"INTERNAL_ERROR\",\n\t\t]),\n\t\tmessage: z.string(),\n\t\tdetails: z\n\t\t\t.array(\n\t\t\t\tz.object({\n\t\t\t\t\tfield: z.string().optional(),\n\t\t\t\t\tmessage: z.string(),\n\t\t\t\t}),\n\t\t\t)\n\t\t\t.optional(),\n\t}),\n});\n"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- const require_vi_2VT5v0um = require("./vi.2VT5v0um-CRqXre87.cjs");
1
+ const require_vi_2VT5v0um = require("./vi.2VT5v0um-iVBt6Fyq.cjs");
2
2
  const require_schema = require("./schema.cjs");
3
3
  //#region src/schema.test.ts
4
4
  require_vi_2VT5v0um.describe("ServiceCategorySchema", () => {
@@ -1,4 +1,4 @@
1
- import { n as describe, r as it, t as globalExpect } from "./vi.2VT5v0um-DvC3SVNc.mjs";
1
+ import { n as describe, r as it, t as globalExpect } from "./vi.2VT5v0um-C_jmO7m2.mjs";
2
2
  import { EnvVariableSchema, GenerationInputSchema, HealthCheckSchema, PortMappingSchema, PresetSchema, ServiceCategorySchema, ServiceDefinitionSchema, SkillPackSchema, VolumeMappingSchema } from "./schema.mjs";
3
3
  //#region src/schema.test.ts
4
4
  describe("ServiceCategorySchema", () => {
@@ -0,0 +1,87 @@
1
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
2
+ //#region src/services/definitions/apptension-saas.ts
3
+ const apptensionSaasDefinition = {
4
+ id: "apptension-saas",
5
+ name: "SaaS Boilerplate (Apptension)",
6
+ description: "Production-ready SaaS boilerplate with React frontend, Django backend, GraphQL API, PostgreSQL, async workers, email, Stripe payments, and Docker Compose support.",
7
+ category: "saas-boilerplate",
8
+ icon: "🚀",
9
+ gitSource: {
10
+ repoUrl: "https://github.com/apptension/saas-boilerplate.git",
11
+ branch: "master",
12
+ postCloneCommands: []
13
+ },
14
+ buildContext: {
15
+ dockerfile: "Dockerfile",
16
+ context: "."
17
+ },
18
+ ports: [{
19
+ host: 3101,
20
+ container: 80,
21
+ description: "Apptension SaaS web application",
22
+ exposed: true
23
+ }],
24
+ volumes: [],
25
+ environment: [
26
+ {
27
+ key: "APPTENSION_SAAS_DB_PASSWORD",
28
+ defaultValue: "",
29
+ secret: true,
30
+ description: "Database password for Apptension SaaS",
31
+ required: true
32
+ },
33
+ {
34
+ key: "DB_CONNECTION",
35
+ defaultValue: "postgresql://apptensionsaas:${APPTENSION_SAAS_DB_PASSWORD}@postgresql:5432/apptensionsaas",
36
+ secret: false,
37
+ description: "PostgreSQL connection string",
38
+ required: true
39
+ },
40
+ {
41
+ key: "DJANGO_SECRET_KEY",
42
+ defaultValue: "",
43
+ secret: true,
44
+ description: "Django secret key",
45
+ required: true
46
+ },
47
+ {
48
+ key: "REDIS_URL",
49
+ defaultValue: "redis://redis:6379/0",
50
+ secret: false,
51
+ description: "Redis connection URL for caching and async workers",
52
+ required: true
53
+ }
54
+ ],
55
+ healthcheck: {
56
+ test: "wget -q --spider http://localhost:80/ || exit 1",
57
+ interval: "30s",
58
+ timeout: "10s",
59
+ retries: 3,
60
+ startPeriod: "60s"
61
+ },
62
+ dependsOn: ["postgresql", "redis"],
63
+ restartPolicy: "unless-stopped",
64
+ networks: ["openclaw-network"],
65
+ skills: [],
66
+ openclawEnvVars: [],
67
+ docsUrl: "https://docs.demo.saas.apptension.com",
68
+ tags: [
69
+ "saas",
70
+ "boilerplate",
71
+ "react",
72
+ "django",
73
+ "graphql",
74
+ "stripe",
75
+ "enterprise"
76
+ ],
77
+ maturity: "beta",
78
+ requires: ["postgresql", "redis"],
79
+ recommends: [],
80
+ conflictsWith: [],
81
+ minMemoryMB: 768,
82
+ gpuRequired: false
83
+ };
84
+ //#endregion
85
+ exports.apptensionSaasDefinition = apptensionSaasDefinition;
86
+
87
+ //# sourceMappingURL=apptension-saas.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apptension-saas.cjs","names":[],"sources":["../../../src/services/definitions/apptension-saas.ts"],"sourcesContent":["import type { ServiceDefinition } from \"../../types.js\";\n\nexport const apptensionSaasDefinition: ServiceDefinition = {\n\tid: \"apptension-saas\",\n\tname: \"SaaS Boilerplate (Apptension)\",\n\tdescription:\n\t\t\"Production-ready SaaS boilerplate with React frontend, Django backend, GraphQL API, PostgreSQL, async workers, email, Stripe payments, and Docker Compose support.\",\n\tcategory: \"saas-boilerplate\",\n\ticon: \"🚀\",\n\n\tgitSource: {\n\t\trepoUrl: \"https://github.com/apptension/saas-boilerplate.git\",\n\t\tbranch: \"master\",\n\t\tpostCloneCommands: [],\n\t},\n\tbuildContext: {\n\t\tdockerfile: \"Dockerfile\",\n\t\tcontext: \".\",\n\t},\n\n\tports: [\n\t\t{\n\t\t\thost: 3101,\n\t\t\tcontainer: 80,\n\t\t\tdescription: \"Apptension SaaS web application\",\n\t\t\texposed: true,\n\t\t},\n\t],\n\tvolumes: [],\n\tenvironment: [\n\t\t{\n\t\t\tkey: \"APPTENSION_SAAS_DB_PASSWORD\",\n\t\t\tdefaultValue: \"\",\n\t\t\tsecret: true,\n\t\t\tdescription: \"Database password for Apptension SaaS\",\n\t\t\trequired: true,\n\t\t},\n\t\t{\n\t\t\tkey: \"DB_CONNECTION\",\n\t\t\tdefaultValue: \"postgresql://apptensionsaas:${APPTENSION_SAAS_DB_PASSWORD}@postgresql:5432/apptensionsaas\",\n\t\t\tsecret: false,\n\t\t\tdescription: \"PostgreSQL connection string\",\n\t\t\trequired: true,\n\t\t},\n\t\t{\n\t\t\tkey: \"DJANGO_SECRET_KEY\",\n\t\t\tdefaultValue: \"\",\n\t\t\tsecret: true,\n\t\t\tdescription: \"Django secret key\",\n\t\t\trequired: true,\n\t\t},\n\t\t{\n\t\t\tkey: \"REDIS_URL\",\n\t\t\tdefaultValue: \"redis://redis:6379/0\",\n\t\t\tsecret: false,\n\t\t\tdescription: \"Redis connection URL for caching and async workers\",\n\t\t\trequired: true,\n\t\t},\n\t],\n\thealthcheck: {\n\t\ttest: \"wget -q --spider http://localhost:80/ || exit 1\",\n\t\tinterval: \"30s\",\n\t\ttimeout: \"10s\",\n\t\tretries: 3,\n\t\tstartPeriod: \"60s\",\n\t},\n\tdependsOn: [\"postgresql\", \"redis\"],\n\trestartPolicy: \"unless-stopped\",\n\tnetworks: [\"openclaw-network\"],\n\n\tskills: [],\n\topenclawEnvVars: [],\n\n\tdocsUrl: \"https://docs.demo.saas.apptension.com\",\n\ttags: [\"saas\", \"boilerplate\", \"react\", \"django\", \"graphql\", \"stripe\", \"enterprise\"],\n\tmaturity: \"beta\",\n\n\trequires: [\"postgresql\", \"redis\"],\n\trecommends: [],\n\tconflictsWith: [],\n\n\tminMemoryMB: 768,\n\tgpuRequired: false,\n};\n"],"mappings":";;AAEA,MAAa,2BAA8C;CAC1D,IAAI;CACJ,MAAM;CACN,aACC;CACD,UAAU;CACV,MAAM;CAEN,WAAW;EACV,SAAS;EACT,QAAQ;EACR,mBAAmB,EAAE;EACrB;CACD,cAAc;EACb,YAAY;EACZ,SAAS;EACT;CAED,OAAO,CACN;EACC,MAAM;EACN,WAAW;EACX,aAAa;EACb,SAAS;EACT,CACD;CACD,SAAS,EAAE;CACX,aAAa;EACZ;GACC,KAAK;GACL,cAAc;GACd,QAAQ;GACR,aAAa;GACb,UAAU;GACV;EACD;GACC,KAAK;GACL,cAAc;GACd,QAAQ;GACR,aAAa;GACb,UAAU;GACV;EACD;GACC,KAAK;GACL,cAAc;GACd,QAAQ;GACR,aAAa;GACb,UAAU;GACV;EACD;GACC,KAAK;GACL,cAAc;GACd,QAAQ;GACR,aAAa;GACb,UAAU;GACV;EACD;CACD,aAAa;EACZ,MAAM;EACN,UAAU;EACV,SAAS;EACT,SAAS;EACT,aAAa;EACb;CACD,WAAW,CAAC,cAAc,QAAQ;CAClC,eAAe;CACf,UAAU,CAAC,mBAAmB;CAE9B,QAAQ,EAAE;CACV,iBAAiB,EAAE;CAEnB,SAAS;CACT,MAAM;EAAC;EAAQ;EAAe;EAAS;EAAU;EAAW;EAAU;EAAa;CACnF,UAAU;CAEV,UAAU,CAAC,cAAc,QAAQ;CACjC,YAAY,EAAE;CACd,eAAe,EAAE;CAEjB,aAAa;CACb,aAAa;CACb"}
@@ -0,0 +1,7 @@
1
+ import { ServiceDefinition } from "../../types.cjs";
2
+
3
+ //#region src/services/definitions/apptension-saas.d.ts
4
+ declare const apptensionSaasDefinition: ServiceDefinition;
5
+ //#endregion
6
+ export { apptensionSaasDefinition };
7
+ //# sourceMappingURL=apptension-saas.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apptension-saas.d.cts","names":[],"sources":["../../../src/services/definitions/apptension-saas.ts"],"mappings":";;;cAEa,wBAAA,EAA0B,iBAAA"}
@@ -0,0 +1,7 @@
1
+ import { ServiceDefinition } from "../../types.mjs";
2
+
3
+ //#region src/services/definitions/apptension-saas.d.ts
4
+ declare const apptensionSaasDefinition: ServiceDefinition;
5
+ //#endregion
6
+ export { apptensionSaasDefinition };
7
+ //# sourceMappingURL=apptension-saas.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apptension-saas.d.mts","names":[],"sources":["../../../src/services/definitions/apptension-saas.ts"],"mappings":";;;cAEa,wBAAA,EAA0B,iBAAA"}
@@ -0,0 +1,86 @@
1
+ //#region src/services/definitions/apptension-saas.ts
2
+ const apptensionSaasDefinition = {
3
+ id: "apptension-saas",
4
+ name: "SaaS Boilerplate (Apptension)",
5
+ description: "Production-ready SaaS boilerplate with React frontend, Django backend, GraphQL API, PostgreSQL, async workers, email, Stripe payments, and Docker Compose support.",
6
+ category: "saas-boilerplate",
7
+ icon: "🚀",
8
+ gitSource: {
9
+ repoUrl: "https://github.com/apptension/saas-boilerplate.git",
10
+ branch: "master",
11
+ postCloneCommands: []
12
+ },
13
+ buildContext: {
14
+ dockerfile: "Dockerfile",
15
+ context: "."
16
+ },
17
+ ports: [{
18
+ host: 3101,
19
+ container: 80,
20
+ description: "Apptension SaaS web application",
21
+ exposed: true
22
+ }],
23
+ volumes: [],
24
+ environment: [
25
+ {
26
+ key: "APPTENSION_SAAS_DB_PASSWORD",
27
+ defaultValue: "",
28
+ secret: true,
29
+ description: "Database password for Apptension SaaS",
30
+ required: true
31
+ },
32
+ {
33
+ key: "DB_CONNECTION",
34
+ defaultValue: "postgresql://apptensionsaas:${APPTENSION_SAAS_DB_PASSWORD}@postgresql:5432/apptensionsaas",
35
+ secret: false,
36
+ description: "PostgreSQL connection string",
37
+ required: true
38
+ },
39
+ {
40
+ key: "DJANGO_SECRET_KEY",
41
+ defaultValue: "",
42
+ secret: true,
43
+ description: "Django secret key",
44
+ required: true
45
+ },
46
+ {
47
+ key: "REDIS_URL",
48
+ defaultValue: "redis://redis:6379/0",
49
+ secret: false,
50
+ description: "Redis connection URL for caching and async workers",
51
+ required: true
52
+ }
53
+ ],
54
+ healthcheck: {
55
+ test: "wget -q --spider http://localhost:80/ || exit 1",
56
+ interval: "30s",
57
+ timeout: "10s",
58
+ retries: 3,
59
+ startPeriod: "60s"
60
+ },
61
+ dependsOn: ["postgresql", "redis"],
62
+ restartPolicy: "unless-stopped",
63
+ networks: ["openclaw-network"],
64
+ skills: [],
65
+ openclawEnvVars: [],
66
+ docsUrl: "https://docs.demo.saas.apptension.com",
67
+ tags: [
68
+ "saas",
69
+ "boilerplate",
70
+ "react",
71
+ "django",
72
+ "graphql",
73
+ "stripe",
74
+ "enterprise"
75
+ ],
76
+ maturity: "beta",
77
+ requires: ["postgresql", "redis"],
78
+ recommends: [],
79
+ conflictsWith: [],
80
+ minMemoryMB: 768,
81
+ gpuRequired: false
82
+ };
83
+ //#endregion
84
+ export { apptensionSaasDefinition };
85
+
86
+ //# sourceMappingURL=apptension-saas.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apptension-saas.mjs","names":[],"sources":["../../../src/services/definitions/apptension-saas.ts"],"sourcesContent":["import type { ServiceDefinition } from \"../../types.js\";\n\nexport const apptensionSaasDefinition: ServiceDefinition = {\n\tid: \"apptension-saas\",\n\tname: \"SaaS Boilerplate (Apptension)\",\n\tdescription:\n\t\t\"Production-ready SaaS boilerplate with React frontend, Django backend, GraphQL API, PostgreSQL, async workers, email, Stripe payments, and Docker Compose support.\",\n\tcategory: \"saas-boilerplate\",\n\ticon: \"🚀\",\n\n\tgitSource: {\n\t\trepoUrl: \"https://github.com/apptension/saas-boilerplate.git\",\n\t\tbranch: \"master\",\n\t\tpostCloneCommands: [],\n\t},\n\tbuildContext: {\n\t\tdockerfile: \"Dockerfile\",\n\t\tcontext: \".\",\n\t},\n\n\tports: [\n\t\t{\n\t\t\thost: 3101,\n\t\t\tcontainer: 80,\n\t\t\tdescription: \"Apptension SaaS web application\",\n\t\t\texposed: true,\n\t\t},\n\t],\n\tvolumes: [],\n\tenvironment: [\n\t\t{\n\t\t\tkey: \"APPTENSION_SAAS_DB_PASSWORD\",\n\t\t\tdefaultValue: \"\",\n\t\t\tsecret: true,\n\t\t\tdescription: \"Database password for Apptension SaaS\",\n\t\t\trequired: true,\n\t\t},\n\t\t{\n\t\t\tkey: \"DB_CONNECTION\",\n\t\t\tdefaultValue: \"postgresql://apptensionsaas:${APPTENSION_SAAS_DB_PASSWORD}@postgresql:5432/apptensionsaas\",\n\t\t\tsecret: false,\n\t\t\tdescription: \"PostgreSQL connection string\",\n\t\t\trequired: true,\n\t\t},\n\t\t{\n\t\t\tkey: \"DJANGO_SECRET_KEY\",\n\t\t\tdefaultValue: \"\",\n\t\t\tsecret: true,\n\t\t\tdescription: \"Django secret key\",\n\t\t\trequired: true,\n\t\t},\n\t\t{\n\t\t\tkey: \"REDIS_URL\",\n\t\t\tdefaultValue: \"redis://redis:6379/0\",\n\t\t\tsecret: false,\n\t\t\tdescription: \"Redis connection URL for caching and async workers\",\n\t\t\trequired: true,\n\t\t},\n\t],\n\thealthcheck: {\n\t\ttest: \"wget -q --spider http://localhost:80/ || exit 1\",\n\t\tinterval: \"30s\",\n\t\ttimeout: \"10s\",\n\t\tretries: 3,\n\t\tstartPeriod: \"60s\",\n\t},\n\tdependsOn: [\"postgresql\", \"redis\"],\n\trestartPolicy: \"unless-stopped\",\n\tnetworks: [\"openclaw-network\"],\n\n\tskills: [],\n\topenclawEnvVars: [],\n\n\tdocsUrl: \"https://docs.demo.saas.apptension.com\",\n\ttags: [\"saas\", \"boilerplate\", \"react\", \"django\", \"graphql\", \"stripe\", \"enterprise\"],\n\tmaturity: \"beta\",\n\n\trequires: [\"postgresql\", \"redis\"],\n\trecommends: [],\n\tconflictsWith: [],\n\n\tminMemoryMB: 768,\n\tgpuRequired: false,\n};\n"],"mappings":";AAEA,MAAa,2BAA8C;CAC1D,IAAI;CACJ,MAAM;CACN,aACC;CACD,UAAU;CACV,MAAM;CAEN,WAAW;EACV,SAAS;EACT,QAAQ;EACR,mBAAmB,EAAE;EACrB;CACD,cAAc;EACb,YAAY;EACZ,SAAS;EACT;CAED,OAAO,CACN;EACC,MAAM;EACN,WAAW;EACX,aAAa;EACb,SAAS;EACT,CACD;CACD,SAAS,EAAE;CACX,aAAa;EACZ;GACC,KAAK;GACL,cAAc;GACd,QAAQ;GACR,aAAa;GACb,UAAU;GACV;EACD;GACC,KAAK;GACL,cAAc;GACd,QAAQ;GACR,aAAa;GACb,UAAU;GACV;EACD;GACC,KAAK;GACL,cAAc;GACd,QAAQ;GACR,aAAa;GACb,UAAU;GACV;EACD;GACC,KAAK;GACL,cAAc;GACd,QAAQ;GACR,aAAa;GACb,UAAU;GACV;EACD;CACD,aAAa;EACZ,MAAM;EACN,UAAU;EACV,SAAS;EACT,SAAS;EACT,aAAa;EACb;CACD,WAAW,CAAC,cAAc,QAAQ;CAClC,eAAe;CACf,UAAU,CAAC,mBAAmB;CAE9B,QAAQ,EAAE;CACV,iBAAiB,EAAE;CAEnB,SAAS;CACT,MAAM;EAAC;EAAQ;EAAe;EAAS;EAAU;EAAW;EAAU;EAAa;CACnF,UAAU;CAEV,UAAU,CAAC,cAAc,QAAQ;CACjC,YAAY,EAAE;CACd,eAAe,EAAE;CAEjB,aAAa;CACb,aAAa;CACb"}
@@ -0,0 +1,88 @@
1
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
2
+ //#region src/services/definitions/boxyhq-saas.ts
3
+ const boxyhqSaasDefinition = {
4
+ id: "boxyhq-saas",
5
+ name: "BoxyHQ Enterprise SaaS Starter",
6
+ description: "Enterprise-grade Next.js SaaS starter kit with SSO (SAML/OIDC), directory sync, audit logs, team management, Prisma ORM, Stripe billing, and PostgreSQL.",
7
+ category: "saas-boilerplate",
8
+ icon: "🚀",
9
+ gitSource: {
10
+ repoUrl: "https://github.com/boxyhq/saas-starter-kit.git",
11
+ branch: "main",
12
+ postCloneCommands: ["cp .env.example .env"]
13
+ },
14
+ buildContext: {
15
+ dockerfile: "Dockerfile",
16
+ context: "."
17
+ },
18
+ ports: [{
19
+ host: 3102,
20
+ container: 3e3,
21
+ description: "BoxyHQ SaaS web application",
22
+ exposed: true
23
+ }],
24
+ volumes: [],
25
+ environment: [
26
+ {
27
+ key: "BOXYHQ_SAAS_DB_PASSWORD",
28
+ defaultValue: "",
29
+ secret: true,
30
+ description: "Database password for BoxyHQ SaaS",
31
+ required: true
32
+ },
33
+ {
34
+ key: "DATABASE_URL",
35
+ defaultValue: "postgresql://boxyhqsaas:${BOXYHQ_SAAS_DB_PASSWORD}@postgresql:5432/boxyhqsaas",
36
+ secret: false,
37
+ description: "PostgreSQL connection string",
38
+ required: true
39
+ },
40
+ {
41
+ key: "NEXTAUTH_SECRET",
42
+ defaultValue: "",
43
+ secret: true,
44
+ description: "NextAuth.js session encryption secret",
45
+ required: true
46
+ },
47
+ {
48
+ key: "NEXTAUTH_URL",
49
+ defaultValue: "http://localhost:3102",
50
+ secret: false,
51
+ description: "NextAuth.js callback URL",
52
+ required: true
53
+ }
54
+ ],
55
+ healthcheck: {
56
+ test: "wget -q --spider http://localhost:3000/ || exit 1",
57
+ interval: "30s",
58
+ timeout: "10s",
59
+ retries: 3,
60
+ startPeriod: "60s"
61
+ },
62
+ dependsOn: ["postgresql"],
63
+ restartPolicy: "unless-stopped",
64
+ networks: ["openclaw-network"],
65
+ skills: [],
66
+ openclawEnvVars: [],
67
+ docsUrl: "https://github.com/boxyhq/saas-starter-kit#readme",
68
+ tags: [
69
+ "saas",
70
+ "boilerplate",
71
+ "nextjs",
72
+ "enterprise",
73
+ "sso",
74
+ "saml",
75
+ "stripe",
76
+ "prisma"
77
+ ],
78
+ maturity: "beta",
79
+ requires: ["postgresql"],
80
+ recommends: [],
81
+ conflictsWith: [],
82
+ minMemoryMB: 512,
83
+ gpuRequired: false
84
+ };
85
+ //#endregion
86
+ exports.boxyhqSaasDefinition = boxyhqSaasDefinition;
87
+
88
+ //# sourceMappingURL=boxyhq-saas.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"boxyhq-saas.cjs","names":[],"sources":["../../../src/services/definitions/boxyhq-saas.ts"],"sourcesContent":["import type { ServiceDefinition } from \"../../types.js\";\n\nexport const boxyhqSaasDefinition: ServiceDefinition = {\n\tid: \"boxyhq-saas\",\n\tname: \"BoxyHQ Enterprise SaaS Starter\",\n\tdescription:\n\t\t\"Enterprise-grade Next.js SaaS starter kit with SSO (SAML/OIDC), directory sync, audit logs, team management, Prisma ORM, Stripe billing, and PostgreSQL.\",\n\tcategory: \"saas-boilerplate\",\n\ticon: \"🚀\",\n\n\tgitSource: {\n\t\trepoUrl: \"https://github.com/boxyhq/saas-starter-kit.git\",\n\t\tbranch: \"main\",\n\t\tpostCloneCommands: [\"cp .env.example .env\"],\n\t},\n\tbuildContext: {\n\t\tdockerfile: \"Dockerfile\",\n\t\tcontext: \".\",\n\t},\n\n\tports: [\n\t\t{\n\t\t\thost: 3102,\n\t\t\tcontainer: 3000,\n\t\t\tdescription: \"BoxyHQ SaaS web application\",\n\t\t\texposed: true,\n\t\t},\n\t],\n\tvolumes: [],\n\tenvironment: [\n\t\t{\n\t\t\tkey: \"BOXYHQ_SAAS_DB_PASSWORD\",\n\t\t\tdefaultValue: \"\",\n\t\t\tsecret: true,\n\t\t\tdescription: \"Database password for BoxyHQ SaaS\",\n\t\t\trequired: true,\n\t\t},\n\t\t{\n\t\t\tkey: \"DATABASE_URL\",\n\t\t\tdefaultValue: \"postgresql://boxyhqsaas:${BOXYHQ_SAAS_DB_PASSWORD}@postgresql:5432/boxyhqsaas\",\n\t\t\tsecret: false,\n\t\t\tdescription: \"PostgreSQL connection string\",\n\t\t\trequired: true,\n\t\t},\n\t\t{\n\t\t\tkey: \"NEXTAUTH_SECRET\",\n\t\t\tdefaultValue: \"\",\n\t\t\tsecret: true,\n\t\t\tdescription: \"NextAuth.js session encryption secret\",\n\t\t\trequired: true,\n\t\t},\n\t\t{\n\t\t\tkey: \"NEXTAUTH_URL\",\n\t\t\tdefaultValue: \"http://localhost:3102\",\n\t\t\tsecret: false,\n\t\t\tdescription: \"NextAuth.js callback URL\",\n\t\t\trequired: true,\n\t\t},\n\t],\n\thealthcheck: {\n\t\ttest: \"wget -q --spider http://localhost:3000/ || exit 1\",\n\t\tinterval: \"30s\",\n\t\ttimeout: \"10s\",\n\t\tretries: 3,\n\t\tstartPeriod: \"60s\",\n\t},\n\tdependsOn: [\"postgresql\"],\n\trestartPolicy: \"unless-stopped\",\n\tnetworks: [\"openclaw-network\"],\n\n\tskills: [],\n\topenclawEnvVars: [],\n\n\tdocsUrl: \"https://github.com/boxyhq/saas-starter-kit#readme\",\n\ttags: [\"saas\", \"boilerplate\", \"nextjs\", \"enterprise\", \"sso\", \"saml\", \"stripe\", \"prisma\"],\n\tmaturity: \"beta\",\n\n\trequires: [\"postgresql\"],\n\trecommends: [],\n\tconflictsWith: [],\n\n\tminMemoryMB: 512,\n\tgpuRequired: false,\n};\n"],"mappings":";;AAEA,MAAa,uBAA0C;CACtD,IAAI;CACJ,MAAM;CACN,aACC;CACD,UAAU;CACV,MAAM;CAEN,WAAW;EACV,SAAS;EACT,QAAQ;EACR,mBAAmB,CAAC,uBAAuB;EAC3C;CACD,cAAc;EACb,YAAY;EACZ,SAAS;EACT;CAED,OAAO,CACN;EACC,MAAM;EACN,WAAW;EACX,aAAa;EACb,SAAS;EACT,CACD;CACD,SAAS,EAAE;CACX,aAAa;EACZ;GACC,KAAK;GACL,cAAc;GACd,QAAQ;GACR,aAAa;GACb,UAAU;GACV;EACD;GACC,KAAK;GACL,cAAc;GACd,QAAQ;GACR,aAAa;GACb,UAAU;GACV;EACD;GACC,KAAK;GACL,cAAc;GACd,QAAQ;GACR,aAAa;GACb,UAAU;GACV;EACD;GACC,KAAK;GACL,cAAc;GACd,QAAQ;GACR,aAAa;GACb,UAAU;GACV;EACD;CACD,aAAa;EACZ,MAAM;EACN,UAAU;EACV,SAAS;EACT,SAAS;EACT,aAAa;EACb;CACD,WAAW,CAAC,aAAa;CACzB,eAAe;CACf,UAAU,CAAC,mBAAmB;CAE9B,QAAQ,EAAE;CACV,iBAAiB,EAAE;CAEnB,SAAS;CACT,MAAM;EAAC;EAAQ;EAAe;EAAU;EAAc;EAAO;EAAQ;EAAU;EAAS;CACxF,UAAU;CAEV,UAAU,CAAC,aAAa;CACxB,YAAY,EAAE;CACd,eAAe,EAAE;CAEjB,aAAa;CACb,aAAa;CACb"}
@@ -0,0 +1,7 @@
1
+ import { ServiceDefinition } from "../../types.cjs";
2
+
3
+ //#region src/services/definitions/boxyhq-saas.d.ts
4
+ declare const boxyhqSaasDefinition: ServiceDefinition;
5
+ //#endregion
6
+ export { boxyhqSaasDefinition };
7
+ //# sourceMappingURL=boxyhq-saas.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"boxyhq-saas.d.cts","names":[],"sources":["../../../src/services/definitions/boxyhq-saas.ts"],"mappings":";;;cAEa,oBAAA,EAAsB,iBAAA"}
@@ -0,0 +1,7 @@
1
+ import { ServiceDefinition } from "../../types.mjs";
2
+
3
+ //#region src/services/definitions/boxyhq-saas.d.ts
4
+ declare const boxyhqSaasDefinition: ServiceDefinition;
5
+ //#endregion
6
+ export { boxyhqSaasDefinition };
7
+ //# sourceMappingURL=boxyhq-saas.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"boxyhq-saas.d.mts","names":[],"sources":["../../../src/services/definitions/boxyhq-saas.ts"],"mappings":";;;cAEa,oBAAA,EAAsB,iBAAA"}
@@ -0,0 +1,87 @@
1
+ //#region src/services/definitions/boxyhq-saas.ts
2
+ const boxyhqSaasDefinition = {
3
+ id: "boxyhq-saas",
4
+ name: "BoxyHQ Enterprise SaaS Starter",
5
+ description: "Enterprise-grade Next.js SaaS starter kit with SSO (SAML/OIDC), directory sync, audit logs, team management, Prisma ORM, Stripe billing, and PostgreSQL.",
6
+ category: "saas-boilerplate",
7
+ icon: "🚀",
8
+ gitSource: {
9
+ repoUrl: "https://github.com/boxyhq/saas-starter-kit.git",
10
+ branch: "main",
11
+ postCloneCommands: ["cp .env.example .env"]
12
+ },
13
+ buildContext: {
14
+ dockerfile: "Dockerfile",
15
+ context: "."
16
+ },
17
+ ports: [{
18
+ host: 3102,
19
+ container: 3e3,
20
+ description: "BoxyHQ SaaS web application",
21
+ exposed: true
22
+ }],
23
+ volumes: [],
24
+ environment: [
25
+ {
26
+ key: "BOXYHQ_SAAS_DB_PASSWORD",
27
+ defaultValue: "",
28
+ secret: true,
29
+ description: "Database password for BoxyHQ SaaS",
30
+ required: true
31
+ },
32
+ {
33
+ key: "DATABASE_URL",
34
+ defaultValue: "postgresql://boxyhqsaas:${BOXYHQ_SAAS_DB_PASSWORD}@postgresql:5432/boxyhqsaas",
35
+ secret: false,
36
+ description: "PostgreSQL connection string",
37
+ required: true
38
+ },
39
+ {
40
+ key: "NEXTAUTH_SECRET",
41
+ defaultValue: "",
42
+ secret: true,
43
+ description: "NextAuth.js session encryption secret",
44
+ required: true
45
+ },
46
+ {
47
+ key: "NEXTAUTH_URL",
48
+ defaultValue: "http://localhost:3102",
49
+ secret: false,
50
+ description: "NextAuth.js callback URL",
51
+ required: true
52
+ }
53
+ ],
54
+ healthcheck: {
55
+ test: "wget -q --spider http://localhost:3000/ || exit 1",
56
+ interval: "30s",
57
+ timeout: "10s",
58
+ retries: 3,
59
+ startPeriod: "60s"
60
+ },
61
+ dependsOn: ["postgresql"],
62
+ restartPolicy: "unless-stopped",
63
+ networks: ["openclaw-network"],
64
+ skills: [],
65
+ openclawEnvVars: [],
66
+ docsUrl: "https://github.com/boxyhq/saas-starter-kit#readme",
67
+ tags: [
68
+ "saas",
69
+ "boilerplate",
70
+ "nextjs",
71
+ "enterprise",
72
+ "sso",
73
+ "saml",
74
+ "stripe",
75
+ "prisma"
76
+ ],
77
+ maturity: "beta",
78
+ requires: ["postgresql"],
79
+ recommends: [],
80
+ conflictsWith: [],
81
+ minMemoryMB: 512,
82
+ gpuRequired: false
83
+ };
84
+ //#endregion
85
+ export { boxyhqSaasDefinition };
86
+
87
+ //# sourceMappingURL=boxyhq-saas.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"boxyhq-saas.mjs","names":[],"sources":["../../../src/services/definitions/boxyhq-saas.ts"],"sourcesContent":["import type { ServiceDefinition } from \"../../types.js\";\n\nexport const boxyhqSaasDefinition: ServiceDefinition = {\n\tid: \"boxyhq-saas\",\n\tname: \"BoxyHQ Enterprise SaaS Starter\",\n\tdescription:\n\t\t\"Enterprise-grade Next.js SaaS starter kit with SSO (SAML/OIDC), directory sync, audit logs, team management, Prisma ORM, Stripe billing, and PostgreSQL.\",\n\tcategory: \"saas-boilerplate\",\n\ticon: \"🚀\",\n\n\tgitSource: {\n\t\trepoUrl: \"https://github.com/boxyhq/saas-starter-kit.git\",\n\t\tbranch: \"main\",\n\t\tpostCloneCommands: [\"cp .env.example .env\"],\n\t},\n\tbuildContext: {\n\t\tdockerfile: \"Dockerfile\",\n\t\tcontext: \".\",\n\t},\n\n\tports: [\n\t\t{\n\t\t\thost: 3102,\n\t\t\tcontainer: 3000,\n\t\t\tdescription: \"BoxyHQ SaaS web application\",\n\t\t\texposed: true,\n\t\t},\n\t],\n\tvolumes: [],\n\tenvironment: [\n\t\t{\n\t\t\tkey: \"BOXYHQ_SAAS_DB_PASSWORD\",\n\t\t\tdefaultValue: \"\",\n\t\t\tsecret: true,\n\t\t\tdescription: \"Database password for BoxyHQ SaaS\",\n\t\t\trequired: true,\n\t\t},\n\t\t{\n\t\t\tkey: \"DATABASE_URL\",\n\t\t\tdefaultValue: \"postgresql://boxyhqsaas:${BOXYHQ_SAAS_DB_PASSWORD}@postgresql:5432/boxyhqsaas\",\n\t\t\tsecret: false,\n\t\t\tdescription: \"PostgreSQL connection string\",\n\t\t\trequired: true,\n\t\t},\n\t\t{\n\t\t\tkey: \"NEXTAUTH_SECRET\",\n\t\t\tdefaultValue: \"\",\n\t\t\tsecret: true,\n\t\t\tdescription: \"NextAuth.js session encryption secret\",\n\t\t\trequired: true,\n\t\t},\n\t\t{\n\t\t\tkey: \"NEXTAUTH_URL\",\n\t\t\tdefaultValue: \"http://localhost:3102\",\n\t\t\tsecret: false,\n\t\t\tdescription: \"NextAuth.js callback URL\",\n\t\t\trequired: true,\n\t\t},\n\t],\n\thealthcheck: {\n\t\ttest: \"wget -q --spider http://localhost:3000/ || exit 1\",\n\t\tinterval: \"30s\",\n\t\ttimeout: \"10s\",\n\t\tretries: 3,\n\t\tstartPeriod: \"60s\",\n\t},\n\tdependsOn: [\"postgresql\"],\n\trestartPolicy: \"unless-stopped\",\n\tnetworks: [\"openclaw-network\"],\n\n\tskills: [],\n\topenclawEnvVars: [],\n\n\tdocsUrl: \"https://github.com/boxyhq/saas-starter-kit#readme\",\n\ttags: [\"saas\", \"boilerplate\", \"nextjs\", \"enterprise\", \"sso\", \"saml\", \"stripe\", \"prisma\"],\n\tmaturity: \"beta\",\n\n\trequires: [\"postgresql\"],\n\trecommends: [],\n\tconflictsWith: [],\n\n\tminMemoryMB: 512,\n\tgpuRequired: false,\n};\n"],"mappings":";AAEA,MAAa,uBAA0C;CACtD,IAAI;CACJ,MAAM;CACN,aACC;CACD,UAAU;CACV,MAAM;CAEN,WAAW;EACV,SAAS;EACT,QAAQ;EACR,mBAAmB,CAAC,uBAAuB;EAC3C;CACD,cAAc;EACb,YAAY;EACZ,SAAS;EACT;CAED,OAAO,CACN;EACC,MAAM;EACN,WAAW;EACX,aAAa;EACb,SAAS;EACT,CACD;CACD,SAAS,EAAE;CACX,aAAa;EACZ;GACC,KAAK;GACL,cAAc;GACd,QAAQ;GACR,aAAa;GACb,UAAU;GACV;EACD;GACC,KAAK;GACL,cAAc;GACd,QAAQ;GACR,aAAa;GACb,UAAU;GACV;EACD;GACC,KAAK;GACL,cAAc;GACd,QAAQ;GACR,aAAa;GACb,UAAU;GACV;EACD;GACC,KAAK;GACL,cAAc;GACd,QAAQ;GACR,aAAa;GACb,UAAU;GACV;EACD;CACD,aAAa;EACZ,MAAM;EACN,UAAU;EACV,SAAS;EACT,SAAS;EACT,aAAa;EACb;CACD,WAAW,CAAC,aAAa;CACzB,eAAe;CACf,UAAU,CAAC,mBAAmB;CAE9B,QAAQ,EAAE;CACV,iBAAiB,EAAE;CAEnB,SAAS;CACT,MAAM;EAAC;EAAQ;EAAe;EAAU;EAAc;EAAO;EAAQ;EAAU;EAAS;CACxF,UAAU;CAEV,UAAU,CAAC,aAAa;CACxB,YAAY,EAAE;CACd,eAAe,EAAE;CAEjB,aAAa;CACb,aAAa;CACb"}
@@ -0,0 +1,86 @@
1
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
2
+ //#region src/services/definitions/cmsaas-starter.ts
3
+ const cmsaasStarterDefinition = {
4
+ id: "cmsaas-starter",
5
+ name: "CMSaasStarter",
6
+ description: "SvelteKit SaaS starter with Supabase backend, Stripe payments, user management, blog engine, SEO optimization, and edge deployment support.",
7
+ category: "saas-boilerplate",
8
+ icon: "🚀",
9
+ gitSource: {
10
+ repoUrl: "https://github.com/CriticalMoments/CMSaasStarter.git",
11
+ branch: "main",
12
+ postCloneCommands: []
13
+ },
14
+ buildContext: {
15
+ dockerfile: "Dockerfile",
16
+ context: "."
17
+ },
18
+ ports: [{
19
+ host: 3104,
20
+ container: 3e3,
21
+ description: "CMSaasStarter web application",
22
+ exposed: true
23
+ }],
24
+ volumes: [],
25
+ environment: [
26
+ {
27
+ key: "PUBLIC_SUPABASE_URL",
28
+ defaultValue: "",
29
+ secret: false,
30
+ description: "Supabase project URL",
31
+ required: true
32
+ },
33
+ {
34
+ key: "PUBLIC_SUPABASE_ANON_KEY",
35
+ defaultValue: "",
36
+ secret: false,
37
+ description: "Supabase anonymous/public key",
38
+ required: true
39
+ },
40
+ {
41
+ key: "PRIVATE_SUPABASE_SERVICE_ROLE",
42
+ defaultValue: "",
43
+ secret: true,
44
+ description: "Supabase service role key (server-side only)",
45
+ required: true
46
+ },
47
+ {
48
+ key: "PRIVATE_STRIPE_API_KEY",
49
+ defaultValue: "",
50
+ secret: true,
51
+ description: "Stripe secret API key",
52
+ required: true
53
+ }
54
+ ],
55
+ healthcheck: {
56
+ test: "wget -q --spider http://localhost:3000/ || exit 1",
57
+ interval: "30s",
58
+ timeout: "10s",
59
+ retries: 3,
60
+ startPeriod: "60s"
61
+ },
62
+ dependsOn: [],
63
+ restartPolicy: "unless-stopped",
64
+ networks: ["openclaw-network"],
65
+ skills: [],
66
+ openclawEnvVars: [],
67
+ docsUrl: "https://github.com/CriticalMoments/CMSaasStarter#readme",
68
+ tags: [
69
+ "saas",
70
+ "boilerplate",
71
+ "sveltekit",
72
+ "supabase",
73
+ "stripe",
74
+ "seo"
75
+ ],
76
+ maturity: "beta",
77
+ requires: [],
78
+ recommends: ["postgresql"],
79
+ conflictsWith: [],
80
+ minMemoryMB: 256,
81
+ gpuRequired: false
82
+ };
83
+ //#endregion
84
+ exports.cmsaasStarterDefinition = cmsaasStarterDefinition;
85
+
86
+ //# sourceMappingURL=cmsaas-starter.cjs.map