@polymorphism-tech/morph-spec 3.0.0 → 3.1.0

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 (240) hide show
  1. package/CLAUDE.md +68 -400
  2. package/README.md +198 -76
  3. package/bin/detect-agents.js +227 -225
  4. package/bin/morph-spec.js +10 -0
  5. package/bin/render-template.js +303 -302
  6. package/bin/semantic-detect-agents.js +247 -246
  7. package/bin/{task-manager.js → task-manager.cjs} +12 -1
  8. package/bin/validate-agents-skills.js +257 -251
  9. package/bin/validate-agents.js +70 -69
  10. package/bin/validate-phase.js +263 -263
  11. package/docs/getting-started.md +3 -3
  12. package/package.json +3 -4
  13. package/scripts/reorganize-skills.cjs +175 -0
  14. package/scripts/validate-agents-structure.cjs +52 -0
  15. package/scripts/validate-skills.cjs +180 -0
  16. package/src/commands/create-story.js +354 -351
  17. package/src/commands/detect-agents.js +13 -2
  18. package/src/commands/detect.js +104 -104
  19. package/src/commands/state.js +334 -333
  20. package/src/commands/sync.js +167 -167
  21. package/src/commands/task.js +1 -1
  22. package/src/commands/update.js +13 -1
  23. package/src/lib/context-generator.js +7 -4
  24. package/{detectors → src/lib/detectors}/config-detector.js +223 -223
  25. package/{detectors → src/lib/detectors}/conversation-analyzer.js +163 -163
  26. package/{detectors → src/lib/detectors}/index.js +84 -84
  27. package/{detectors → src/lib/detectors}/standards-generator.js +275 -275
  28. package/src/lib/hook-executor.js +2 -1
  29. package/src/lib/stack-resolver.js +148 -0
  30. package/src/lib/standards-context-injector.js +4 -3
  31. package/src/lib/state-manager.js +21 -4
  32. package/src/lib/team-orchestrator.js +2 -1
  33. package/src/lib/troubleshoot-grep.js +13 -3
  34. package/src/lib/validation-runner.js +2 -1
  35. package/src/utils/file-copier.js +3 -1
  36. package/{content → stacks/blazor-azure}/.azure/README.md +293 -293
  37. package/{content → stacks/blazor-azure}/.azure/docs/azure-devops-setup.md +454 -454
  38. package/{content → stacks/blazor-azure}/.azure/docs/branch-strategy.md +398 -398
  39. package/{content → stacks/blazor-azure}/.azure/docs/local-development.md +515 -515
  40. package/{content → stacks/blazor-azure}/.azure/pipelines/pipeline-variables.yml +34 -34
  41. package/{content → stacks/blazor-azure}/.azure/pipelines/prod-pipeline.yml +319 -319
  42. package/{content → stacks/blazor-azure}/.azure/pipelines/staging-pipeline.yml +234 -234
  43. package/{content → stacks/blazor-azure}/.azure/pipelines/templates/build-dotnet.yml +75 -75
  44. package/{content → stacks/blazor-azure}/.azure/pipelines/templates/deploy-app-service.yml +94 -94
  45. package/{content → stacks/blazor-azure}/.azure/pipelines/templates/deploy-container-app.yml +120 -120
  46. package/{content → stacks/blazor-azure}/.azure/pipelines/templates/infra-deploy.yml +90 -90
  47. package/{content → stacks/blazor-azure}/.claude/commands/morph-archive.md +79 -79
  48. package/{content → stacks/blazor-azure}/.claude/commands/morph-deploy.md +529 -529
  49. package/{content → stacks/blazor-azure}/.claude/commands/morph-infra.md +209 -209
  50. package/{content → stacks/blazor-azure}/.claude/commands/morph-troubleshoot.md +1 -1
  51. package/{content → stacks/blazor-azure}/.claude/settings.local.json +15 -15
  52. package/{content → stacks/blazor-azure}/.claude/skills/level-1-workflows/phase-setup.md +1 -1
  53. package/{content/.claude/skills/specialists → stacks/blazor-azure/.claude/skills/level-2-domains/architecture}/prompt-engineer.md +189 -189
  54. package/{content/.claude/skills/specialists → stacks/blazor-azure/.claude/skills/level-2-domains/architecture}/seo-growth-hacker.md +320 -320
  55. package/{content/.claude/skills/infra → stacks/blazor-azure/.claude/skills/level-2-domains/infrastructure}/azure-deploy-specialist.md +699 -699
  56. package/{content → stacks/blazor-azure}/.morph/.morphversion +5 -5
  57. package/{content → stacks/blazor-azure}/.morph/archive/.gitkeep +25 -25
  58. package/{content → stacks/blazor-azure}/.morph/config/agents.json +7 -5
  59. package/{content → stacks/blazor-azure}/.morph/docs/STORY-DRIVEN-DEVELOPMENT.md +392 -392
  60. package/{content → stacks/blazor-azure}/.morph/docs/workflows/enforcement-pipeline.md +3 -3
  61. package/{content → stacks/blazor-azure}/.morph/examples/api-nextjs/README.md +241 -241
  62. package/{content → stacks/blazor-azure}/.morph/examples/api-nextjs/contracts.ts +307 -307
  63. package/{content → stacks/blazor-azure}/.morph/examples/api-nextjs/spec.md +399 -399
  64. package/{content → stacks/blazor-azure}/.morph/examples/api-nextjs/tasks.md +168 -168
  65. package/{content → stacks/blazor-azure}/.morph/examples/micro-saas/README.md +125 -125
  66. package/{content → stacks/blazor-azure}/.morph/examples/micro-saas/contracts.cs +358 -358
  67. package/{content → stacks/blazor-azure}/.morph/examples/micro-saas/decisions.md +246 -246
  68. package/{content → stacks/blazor-azure}/.morph/examples/micro-saas/spec.md +236 -236
  69. package/{content → stacks/blazor-azure}/.morph/examples/micro-saas/tasks.md +150 -150
  70. package/{content → stacks/blazor-azure}/.morph/examples/multi-agent/README.md +309 -309
  71. package/{content → stacks/blazor-azure}/.morph/examples/multi-agent/contracts.cs +433 -433
  72. package/{content → stacks/blazor-azure}/.morph/examples/multi-agent/spec.md +479 -479
  73. package/{content → stacks/blazor-azure}/.morph/examples/multi-agent/tasks.md +185 -185
  74. package/{content → stacks/blazor-azure}/.morph/examples/state-v3.json +188 -188
  75. package/{content → stacks/blazor-azure}/.morph/features/.gitkeep +25 -25
  76. package/{content → stacks/blazor-azure}/.morph/hooks/README.md +12 -12
  77. package/{content → stacks/blazor-azure}/.morph/hooks/pre-commit-all.sh +48 -48
  78. package/{content → stacks/blazor-azure}/.morph/hooks/pre-commit-specs.sh +49 -49
  79. package/{content → stacks/blazor-azure}/.morph/hooks/pre-commit-tests.sh +60 -60
  80. package/{content → stacks/blazor-azure}/.morph/project.md +160 -160
  81. package/{content → stacks/blazor-azure}/.morph/schemas/agent.schema.json +296 -296
  82. package/{content → stacks/blazor-azure}/.morph/specs/.gitkeep +20 -20
  83. package/{content → stacks/blazor-azure}/.morph/standards/agent-teams-workflow.md +2 -2
  84. package/{content → stacks/blazor-azure}/.morph/standards/coding.md +377 -377
  85. package/{content → stacks/blazor-azure}/.morph/standards/fluent-ui-setup.md +590 -590
  86. package/{content → stacks/blazor-azure}/.morph/standards/migration-guide.md +514 -514
  87. package/{content → stacks/blazor-azure}/.morph/standards/passkeys-auth.md +423 -423
  88. package/{content → stacks/blazor-azure}/.morph/standards/vector-search-rag.md +536 -536
  89. package/{content → stacks/blazor-azure}/.morph/state.json +17 -17
  90. package/{content → stacks/blazor-azure}/.morph/templates/FluentDesignTheme.cs +149 -149
  91. package/{content → stacks/blazor-azure}/.morph/templates/MudTheme.cs +281 -281
  92. package/{content → stacks/blazor-azure}/.morph/templates/component.razor +239 -239
  93. package/{content → stacks/blazor-azure}/.morph/templates/contracts.cs +217 -217
  94. package/{content → stacks/blazor-azure}/.morph/templates/design-system.css +226 -226
  95. package/{content → stacks/blazor-azure}/.morph/templates/infra/.dockerignore.example +89 -89
  96. package/{content → stacks/blazor-azure}/.morph/templates/infra/Dockerfile.example +82 -82
  97. package/{content → stacks/blazor-azure}/.morph/templates/infra/README.md +286 -286
  98. package/{content → stacks/blazor-azure}/.morph/templates/infra/app-insights.bicep +63 -63
  99. package/{content → stacks/blazor-azure}/.morph/templates/infra/app-service.bicep +164 -164
  100. package/{content → stacks/blazor-azure}/.morph/templates/infra/azure-pipelines-deploy.yml +480 -480
  101. package/{content → stacks/blazor-azure}/.morph/templates/infra/container-app-env.bicep +49 -49
  102. package/{content → stacks/blazor-azure}/.morph/templates/infra/container-app.bicep +156 -156
  103. package/{content → stacks/blazor-azure}/.morph/templates/infra/deploy.ps1 +229 -229
  104. package/{content → stacks/blazor-azure}/.morph/templates/infra/deploy.sh +208 -208
  105. package/{content → stacks/blazor-azure}/.morph/templates/infra/key-vault.bicep +91 -91
  106. package/{content → stacks/blazor-azure}/.morph/templates/infra/main.bicep +189 -189
  107. package/{content → stacks/blazor-azure}/.morph/templates/infra/parameters.dev.json +29 -29
  108. package/{content → stacks/blazor-azure}/.morph/templates/infra/parameters.prod.json +29 -29
  109. package/{content → stacks/blazor-azure}/.morph/templates/infra/parameters.staging.json +29 -29
  110. package/{content → stacks/blazor-azure}/.morph/templates/infra/sql-database.bicep +103 -103
  111. package/{content → stacks/blazor-azure}/.morph/templates/infra/storage.bicep +106 -106
  112. package/{content → stacks/blazor-azure}/.morph/templates/integrations/asaas-client.cs +387 -387
  113. package/{content → stacks/blazor-azure}/.morph/templates/integrations/asaas-webhook.cs +351 -351
  114. package/{content → stacks/blazor-azure}/.morph/templates/integrations/azure-identity-config.cs +288 -288
  115. package/{content → stacks/blazor-azure}/.morph/templates/integrations/clerk-config.cs +258 -258
  116. package/{content → stacks/blazor-azure}/.morph/templates/job.cs +171 -171
  117. package/{content → stacks/blazor-azure}/.morph/templates/migration.cs +83 -83
  118. package/{content → stacks/blazor-azure}/.morph/templates/repository.cs +141 -141
  119. package/{content → stacks/blazor-azure}/.morph/templates/saas/subscription.cs +347 -347
  120. package/{content → stacks/blazor-azure}/.morph/templates/saas/tenant.cs +338 -338
  121. package/{content → stacks/blazor-azure}/.morph/templates/service.cs +139 -139
  122. package/{content → stacks/blazor-azure}/.morph/templates/sprint-status.yaml +68 -68
  123. package/{content → stacks/blazor-azure}/.morph/templates/story.md +143 -143
  124. package/{content → stacks/blazor-azure}/.morph/templates/test.cs +239 -239
  125. package/{content → stacks/blazor-azure}/.morph/templates/ui-design-system.md +286 -286
  126. package/{content → stacks/blazor-azure}/.morph/templates/ui-flows.md +336 -336
  127. package/{content → stacks/blazor-azure}/.morph/templates/ui-mockups.md +133 -133
  128. package/{content → stacks/blazor-azure}/.morph/test-infra/example.bicep +59 -59
  129. package/{content → stacks/blazor-azure}/README.md +79 -79
  130. package/stacks/nextjs-supabase/.claude/skills/level-2-domains/backend/dotnet-supabase.md +244 -0
  131. package/stacks/nextjs-supabase/.claude/skills/level-2-domains/frontend/nextjs-supabase.md +335 -0
  132. package/stacks/nextjs-supabase/.claude/skills/level-2-domains/infrastructure/easypanel-deployer.md +189 -0
  133. package/stacks/nextjs-supabase/.claude/skills/level-2-domains/integrations/supabase-expert.md +170 -0
  134. package/stacks/nextjs-supabase/.morph/config/agents.json +345 -0
  135. package/stacks/nextjs-supabase/.morph/config/config.template.json +92 -0
  136. package/stacks/nextjs-supabase/.morph/docs/easypanel-setup.md +169 -0
  137. package/stacks/nextjs-supabase/.morph/docs/supabase-mcp-setup.md +247 -0
  138. package/stacks/nextjs-supabase/.morph/examples/crud-nextjs-supabase/README.md +697 -0
  139. package/stacks/nextjs-supabase/.morph/examples/crud-nextjs-supabase/spec.md +85 -0
  140. package/stacks/nextjs-supabase/.morph/examples/crud-nextjs-supabase/tasks.md +86 -0
  141. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/README.md +498 -0
  142. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/decisions.md +121 -0
  143. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/spec.md +138 -0
  144. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/tasks.md +162 -0
  145. package/stacks/nextjs-supabase/.morph/project.md +168 -0
  146. package/stacks/nextjs-supabase/.morph/standards/easypanel-deploy.md +191 -0
  147. package/stacks/nextjs-supabase/.morph/standards/nextjs-patterns.md +193 -0
  148. package/stacks/nextjs-supabase/.morph/standards/supabase-auth.md +171 -0
  149. package/stacks/nextjs-supabase/.morph/standards/supabase-pgvector.md +164 -0
  150. package/stacks/nextjs-supabase/.morph/standards/supabase-rls.md +179 -0
  151. package/stacks/nextjs-supabase/.morph/standards/supabase-storage.md +148 -0
  152. package/stacks/nextjs-supabase/.morph/templates/contracts.cs +173 -0
  153. package/stacks/nextjs-supabase/.morph/templates/contracts.ts +168 -0
  154. package/stacks/nextjs-supabase/.morph/templates/decisions.md +115 -0
  155. package/stacks/nextjs-supabase/.morph/templates/dockerfile-api.dockerfile +38 -0
  156. package/stacks/nextjs-supabase/.morph/templates/dockerfile-web.dockerfile +48 -0
  157. package/stacks/nextjs-supabase/.morph/templates/proposal.md +145 -0
  158. package/stacks/nextjs-supabase/.morph/templates/recap.md +134 -0
  159. package/stacks/nextjs-supabase/.morph/templates/rls-policy.sql +57 -0
  160. package/stacks/nextjs-supabase/.morph/templates/spec.md +231 -0
  161. package/stacks/nextjs-supabase/.morph/templates/supabase-migration.sql +100 -0
  162. package/stacks/nextjs-supabase/.morph/templates/tasks.md +257 -0
  163. package/stacks/nextjs-supabase/CLAUDE.md +149 -0
  164. package/stacks/nextjs-supabase/README.md +112 -0
  165. /package/{detectors → src/lib/detectors}/structure-detector.js +0 -0
  166. /package/{content → stacks/blazor-azure}/.claude/commands/morph-apply.md +0 -0
  167. /package/{content → stacks/blazor-azure}/.claude/commands/morph-preflight.md +0 -0
  168. /package/{content → stacks/blazor-azure}/.claude/commands/morph-proposal.md +0 -0
  169. /package/{content → stacks/blazor-azure}/.claude/commands/morph-status.md +0 -0
  170. /package/{content → stacks/blazor-azure}/.claude/skills/level-0-meta/README.md +0 -0
  171. /package/{content → stacks/blazor-azure}/.claude/skills/level-0-meta/code-review.md +0 -0
  172. /package/{content → stacks/blazor-azure}/.claude/skills/level-0-meta/morph-checklist.md +0 -0
  173. /package/{content → stacks/blazor-azure}/.claude/skills/level-0-meta/simulation-checklist.md +0 -0
  174. /package/{content → stacks/blazor-azure}/.claude/skills/level-1-workflows/README.md +0 -0
  175. /package/{content → stacks/blazor-azure}/.claude/skills/level-1-workflows/morph-replicate.md +0 -0
  176. /package/{content → stacks/blazor-azure}/.claude/skills/level-1-workflows/phase-clarify.md +0 -0
  177. /package/{content → stacks/blazor-azure}/.claude/skills/level-1-workflows/phase-design.md +0 -0
  178. /package/{content → stacks/blazor-azure}/.claude/skills/level-1-workflows/phase-tasks.md +0 -0
  179. /package/{content → stacks/blazor-azure}/.claude/skills/level-1-workflows/phase-uiux.md +0 -0
  180. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/README.md +0 -0
  181. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/ai-agents/ai-system-architect.md +0 -0
  182. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/architecture/po-pm-advisor.md +0 -0
  183. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/architecture/standards-architect.md +0 -0
  184. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/backend/dotnet-senior.md +0 -0
  185. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/backend/ef-modeler.md +0 -0
  186. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/backend/hangfire-orchestrator.md +0 -0
  187. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/backend/ms-agent-expert.md +0 -0
  188. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/frontend/blazor-builder.md +0 -0
  189. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/frontend/nextjs-expert.md +0 -0
  190. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/frontend/ui-ux-designer.md +0 -0
  191. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/infrastructure/azure-architect.md +0 -0
  192. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/infrastructure/bicep-architect.md +0 -0
  193. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/infrastructure/container-specialist.md +0 -0
  194. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/infrastructure/devops-engineer.md +0 -0
  195. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/integrations/asaas-financial.md +0 -0
  196. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/integrations/azure-identity.md +0 -0
  197. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/integrations/clerk-auth.md +0 -0
  198. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/integrations/resend-email.md +0 -0
  199. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/quality/code-analyzer.md +0 -0
  200. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/quality/testing-specialist.md +0 -0
  201. /package/{content → stacks/blazor-azure}/.claude/skills/level-3-technologies/README.md +0 -0
  202. /package/{content → stacks/blazor-azure}/.claude/skills/level-4-patterns/README.md +0 -0
  203. /package/{content → stacks/blazor-azure}/.morph/config/config.template.json +0 -0
  204. /package/{content → stacks/blazor-azure}/.morph/docs/workflows/design-impl.md +0 -0
  205. /package/{content → stacks/blazor-azure}/.morph/docs/workflows/fast-track.md +0 -0
  206. /package/{content → stacks/blazor-azure}/.morph/docs/workflows/full-morph.md +0 -0
  207. /package/{content → stacks/blazor-azure}/.morph/docs/workflows/standard.md +0 -0
  208. /package/{content → stacks/blazor-azure}/.morph/docs/workflows/ui-refresh.md +0 -0
  209. /package/{content → stacks/blazor-azure}/.morph/examples/scheduled-reports/decisions.md +0 -0
  210. /package/{content → stacks/blazor-azure}/.morph/examples/scheduled-reports/proposal.md +0 -0
  211. /package/{content → stacks/blazor-azure}/.morph/examples/scheduled-reports/spec.md +0 -0
  212. /package/{content → stacks/blazor-azure}/.morph/hooks/pre-commit-agents.sh +0 -0
  213. /package/{content → stacks/blazor-azure}/.morph/hooks/task-completed.js +0 -0
  214. /package/{content → stacks/blazor-azure}/.morph/hooks/teammate-idle.js +0 -0
  215. /package/{content → stacks/blazor-azure}/.morph/schemas/tasks.schema.json +0 -0
  216. /package/{content → stacks/blazor-azure}/.morph/standards/agent-framework-blazor-ui.md +0 -0
  217. /package/{content → stacks/blazor-azure}/.morph/standards/agent-framework-production.md +0 -0
  218. /package/{content → stacks/blazor-azure}/.morph/standards/agent-framework-setup.md +0 -0
  219. /package/{content → stacks/blazor-azure}/.morph/standards/agent-framework-workflows.md +0 -0
  220. /package/{content → stacks/blazor-azure}/.morph/standards/architecture.md +0 -0
  221. /package/{content → stacks/blazor-azure}/.morph/standards/azure.md +0 -0
  222. /package/{content → stacks/blazor-azure}/.morph/standards/dotnet10-migration.md +0 -0
  223. /package/{content → stacks/blazor-azure}/.morph/templates/CONTEXT-FEATURE.md +0 -0
  224. /package/{content → stacks/blazor-azure}/.morph/templates/CONTEXT.md +0 -0
  225. /package/{content → stacks/blazor-azure}/.morph/templates/agent.cs +0 -0
  226. /package/{content → stacks/blazor-azure}/.morph/templates/clarify-questions.md +0 -0
  227. /package/{content → stacks/blazor-azure}/.morph/templates/contracts/Commands.cs +0 -0
  228. /package/{content → stacks/blazor-azure}/.morph/templates/contracts/Entities.cs +0 -0
  229. /package/{content → stacks/blazor-azure}/.morph/templates/contracts/Queries.cs +0 -0
  230. /package/{content → stacks/blazor-azure}/.morph/templates/contracts/README.md +0 -0
  231. /package/{content → stacks/blazor-azure}/.morph/templates/decisions.md +0 -0
  232. /package/{content → stacks/blazor-azure}/.morph/templates/infra/deploy-checklist.md +0 -0
  233. /package/{content → stacks/blazor-azure}/.morph/templates/proposal.md +0 -0
  234. /package/{content → stacks/blazor-azure}/.morph/templates/recap.md +0 -0
  235. /package/{content → stacks/blazor-azure}/.morph/templates/simulation.md +0 -0
  236. /package/{content → stacks/blazor-azure}/.morph/templates/spec.md +0 -0
  237. /package/{content → stacks/blazor-azure}/.morph/templates/state.template.json +0 -0
  238. /package/{content → stacks/blazor-azure}/.morph/templates/tasks.md +0 -0
  239. /package/{content → stacks/blazor-azure}/.morph/templates/ui-components.md +0 -0
  240. /package/{content → stacks/blazor-azure}/CLAUDE.md +0 -0
@@ -0,0 +1,345 @@
1
+ {
2
+ "$schema": "./agent-schema.json",
3
+ "version": "3.0.0-hierarchical",
4
+ "stack": "nextjs-supabase",
5
+ "total_agents": 12,
6
+ "tiers": {
7
+ "tier_1_orchestrators": 1,
8
+ "tier_2_leaders": 2,
9
+ "tier_3_specialists": 8,
10
+ "tier_4_validators": 1
11
+ },
12
+
13
+ "agents": {
14
+
15
+ "_comment_tier_1": "=== TIER 1: ORCHESTRATORS (1) ===",
16
+
17
+ "standards-architect": {
18
+ "tier": 1,
19
+ "role": "orchestrator",
20
+ "title": "Chief Architect",
21
+ "domains": ["architecture", "developer-experience"],
22
+ "keywords": [],
23
+ "always_active": true,
24
+ "validators": ["architecture", "packages"],
25
+ "relationships": {
26
+ "reports_to": "user",
27
+ "coordinates": ["dotnet-senior", "supabase-expert", "nextjs-expert", "testing-specialist", "ui-ux-designer"],
28
+ "escalates_to": "user",
29
+ "team_role": "lead"
30
+ },
31
+ "standards": ["coding.md", "architecture.md", "nextjs-patterns.md", "supabase-auth.md", "supabase-rls.md"],
32
+ "teammate": {
33
+ "role": "Team Lead (Delegate Mode)",
34
+ "icon": "T",
35
+ "spawn_prompt": "You are the Chief Architect and Team Lead in delegate mode. Coordinate specialists, resolve conflicts, synthesize results. DO NOT implement code yourself. Escalate conflicts to user when teammates disagree on architecture/tech choices."
36
+ }
37
+ },
38
+
39
+ "_comment_tier_2": "=== TIER 2: DOMAIN LEADERS (2) ===",
40
+
41
+ "dotnet-senior": {
42
+ "tier": 2,
43
+ "role": "domain-leader",
44
+ "title": "Backend Squad Leader",
45
+ "domains": ["backend"],
46
+ "keywords": ["backend", "api", "dotnet", ".net", "csharp", "c#", "minimal api", "endpoint", "dapper", "npgsql"],
47
+ "always_active": true,
48
+ "validators": ["architecture", "packages"],
49
+ "relationships": {
50
+ "reports_to": "standards-architect",
51
+ "coordinates": ["api-designer", "testing-specialist"],
52
+ "escalates_to": "standards-architect",
53
+ "collaborates_with": ["supabase-expert", "nextjs-expert", "container-specialist"],
54
+ "team_role": "domain_leader"
55
+ },
56
+ "standards": ["coding.md", "architecture.md"],
57
+ "teammate": {
58
+ "role": "Backend Squad Leader",
59
+ "icon": "B",
60
+ "spawn_prompt": "You are the Backend Squad Leader. .NET 10 Minimal API with Npgsql + Dapper (NOT EF Core). Coordinate backend specialists. Validate Supabase JWT tokens in API middleware. Assign tasks, review designs, enforce backend standards. Escalate cross-domain conflicts to standards-architect."
61
+ }
62
+ },
63
+
64
+ "ui-ux-designer": {
65
+ "tier": 2,
66
+ "role": "domain-leader",
67
+ "title": "UI/UX Squad Leader",
68
+ "domains": ["frontend-design"],
69
+ "keywords": ["wireframe", "mockup", "user flow", "ux", "design", "interface design", "user experience", "page", "dashboard", "form", "UI", "screen", "panel"],
70
+ "always_active": false,
71
+ "validators": ["design-system", "contrast"],
72
+ "relationships": {
73
+ "reports_to": "standards-architect",
74
+ "coordinates": ["nextjs-expert", "css-specialist"],
75
+ "escalates_to": "standards-architect",
76
+ "collaborates_with": ["dotnet-senior"],
77
+ "team_role": "domain_leader",
78
+ "active_phases": ["uiux"]
79
+ },
80
+ "standards": ["css-naming.md", "nextjs-patterns.md"],
81
+ "teammate": {
82
+ "role": "UI/UX Squad Leader",
83
+ "icon": "U",
84
+ "spawn_prompt": "You are the UI/UX Squad Leader. Create wireframes, mockups, user flows. Define design system (colors, typography, spacing) using Tailwind CSS tokens. Coordinate with nextjs-expert and css-specialist for implementation. Work is AGNOSTIC (no implementation code)."
85
+ }
86
+ },
87
+
88
+ "_comment_tier_3": "=== TIER 3: SPECIALISTS (8) ===",
89
+
90
+ "nextjs-expert": {
91
+ "tier": 3,
92
+ "role": "specialist",
93
+ "title": "Next.js Development Specialist",
94
+ "domains": ["frontend-nextjs"],
95
+ "keywords": ["nextjs", "next.js", "react", "frontend", "shadcn", "server components", "server actions", "app router", "tanstack"],
96
+ "always_active": false,
97
+ "validators": ["packages", "css", "design-system"],
98
+ "relationships": {
99
+ "reports_to": "ui-ux-designer",
100
+ "coordinates": [],
101
+ "escalates_to": "standards-architect",
102
+ "collaborates_with": ["api-designer", "css-specialist", "supabase-expert"],
103
+ "team_role": "specialist",
104
+ "active_phases": ["uiux", "implement"]
105
+ },
106
+ "standards": ["coding.md", "nextjs-patterns.md"],
107
+ "teammate": {
108
+ "role": "Next.js Development Specialist",
109
+ "icon": "N",
110
+ "spawn_prompt": "You are the Next.js 15 Development Specialist. Build App Router pages with shadcn/ui components. Use @supabase/ssr for auth (NOT Clerk). Implement Server Components, Server Actions, Route Handlers. Use TanStack Query for client-side data fetching. Message api-designer for backend endpoints."
111
+ }
112
+ },
113
+
114
+ "api-designer": {
115
+ "tier": 3,
116
+ "role": "specialist",
117
+ "title": "API Design Specialist",
118
+ "domains": ["backend-api"],
119
+ "keywords": ["rest", "api", "openapi", "swagger", "endpoint", "minimal api", "route", "versioning", "rate limiting"],
120
+ "always_active": false,
121
+ "validators": ["architecture"],
122
+ "relationships": {
123
+ "reports_to": "dotnet-senior",
124
+ "coordinates": [],
125
+ "escalates_to": "dotnet-senior",
126
+ "collaborates_with": ["supabase-expert", "nextjs-expert"],
127
+ "team_role": "specialist"
128
+ },
129
+ "standards": ["coding.md", "architecture.md"],
130
+ "teammate": {
131
+ "role": "API Design Specialist",
132
+ "icon": "A",
133
+ "spawn_prompt": "You are the API Design Specialist. Design REST APIs using .NET 10 Minimal API (MapGet, MapPost, etc.). Use endpoint groups, typed results, OpenAPI annotations. Implement API versioning, rate limiting. Validate Supabase JWT in middleware."
134
+ }
135
+ },
136
+
137
+ "supabase-expert": {
138
+ "tier": 3,
139
+ "role": "specialist",
140
+ "title": "Supabase Platform Specialist",
141
+ "domains": ["platform-supabase"],
142
+ "keywords": ["supabase", "postgres", "postgresql", "rls", "row level security", "auth", "storage", "realtime", "pgvector", "migration", "database", "policy"],
143
+ "always_active": true,
144
+ "validators": ["architecture"],
145
+ "relationships": {
146
+ "reports_to": "standards-architect",
147
+ "coordinates": [],
148
+ "escalates_to": "standards-architect",
149
+ "collaborates_with": ["dotnet-senior", "nextjs-expert", "security-expert"],
150
+ "team_role": "specialist"
151
+ },
152
+ "standards": ["supabase-auth.md", "supabase-rls.md", "supabase-storage.md", "supabase-pgvector.md"],
153
+ "teammate": {
154
+ "role": "Supabase Platform Specialist",
155
+ "icon": "S",
156
+ "spawn_prompt": "You are the Supabase Platform Specialist. Design PostgreSQL schemas (snake_case), write SQL migrations, create RLS policies for multi-tenant security. Configure Supabase Auth (Google + GitHub OAuth), Storage buckets with policies, Realtime subscriptions. Implement pgvector for vector search when needed. Collaborate with security-expert for RLS audit."
157
+ }
158
+ },
159
+
160
+ "easypanel-deployer": {
161
+ "tier": 3,
162
+ "role": "specialist",
163
+ "title": "EasyPanel Deployment Specialist",
164
+ "domains": ["infrastructure-deploy"],
165
+ "keywords": ["easypanel", "deploy", "deployment", "hosting", "ssl", "domain", "vps", "production"],
166
+ "always_active": false,
167
+ "validators": ["architecture"],
168
+ "relationships": {
169
+ "reports_to": "standards-architect",
170
+ "coordinates": [],
171
+ "escalates_to": "standards-architect",
172
+ "collaborates_with": ["container-specialist", "devops-engineer"],
173
+ "team_role": "specialist"
174
+ },
175
+ "standards": ["easypanel-deploy.md"],
176
+ "teammate": {
177
+ "role": "EasyPanel Deployment Specialist",
178
+ "icon": "E",
179
+ "spawn_prompt": "You are the EasyPanel Deployment Specialist. Configure EasyPanel services (API + Web), set up GitHub integration for auto-deploy, manage SSL certificates and custom domains. Define environment variables, health check endpoints, resource limits."
180
+ }
181
+ },
182
+
183
+ "container-specialist": {
184
+ "tier": 3,
185
+ "role": "specialist",
186
+ "title": "Containerization Specialist",
187
+ "domains": ["infrastructure-containers"],
188
+ "keywords": ["docker", "container", "dockerfile", "multi-stage", "docker compose", "health check", "image"],
189
+ "always_active": true,
190
+ "validators": ["architecture"],
191
+ "relationships": {
192
+ "reports_to": "standards-architect",
193
+ "coordinates": [],
194
+ "escalates_to": "standards-architect",
195
+ "collaborates_with": ["easypanel-deployer", "devops-engineer", "dotnet-senior", "nextjs-expert"],
196
+ "team_role": "specialist"
197
+ },
198
+ "standards": ["easypanel-deploy.md"],
199
+ "teammate": {
200
+ "role": "Containerization Specialist",
201
+ "icon": "D",
202
+ "spawn_prompt": "You are the Containerization Specialist for EasyPanel deployments. Write multi-stage Dockerfiles (.NET API + Next.js), docker-compose.yml for local dev, .dockerignore files. Optimize image sizes, configure health checks (/health endpoint). Target EasyPanel container service format."
203
+ }
204
+ },
205
+
206
+ "devops-engineer": {
207
+ "tier": 3,
208
+ "role": "specialist",
209
+ "title": "CI/CD Specialist",
210
+ "domains": ["infrastructure-cicd"],
211
+ "keywords": ["pipeline", "ci/cd", "github actions", "auto-deploy", "workflow", "continuous integration"],
212
+ "always_active": false,
213
+ "validators": ["architecture"],
214
+ "relationships": {
215
+ "reports_to": "standards-architect",
216
+ "coordinates": [],
217
+ "escalates_to": "standards-architect",
218
+ "collaborates_with": ["container-specialist", "easypanel-deployer"],
219
+ "team_role": "specialist"
220
+ },
221
+ "standards": ["easypanel-deploy.md"],
222
+ "teammate": {
223
+ "role": "CI/CD Specialist",
224
+ "icon": "C",
225
+ "spawn_prompt": "You are the CI/CD Specialist. Build GitHub Actions workflows for .NET build/test + Next.js build/test. Configure auto-deploy to EasyPanel via GitHub webhook or API. Implement environment-based deployments (staging, production)."
226
+ }
227
+ },
228
+
229
+ "css-specialist": {
230
+ "tier": 3,
231
+ "role": "specialist",
232
+ "title": "CSS & Design System Specialist",
233
+ "domains": ["frontend-css"],
234
+ "keywords": ["css", "tailwind", "design system", "styling", "theme", "design tokens", "shadcn"],
235
+ "always_active": false,
236
+ "validators": ["css", "contrast", "design-system"],
237
+ "relationships": {
238
+ "reports_to": "ui-ux-designer",
239
+ "coordinates": [],
240
+ "escalates_to": "ui-ux-designer",
241
+ "collaborates_with": ["nextjs-expert"],
242
+ "team_role": "specialist",
243
+ "active_phases": ["implement"]
244
+ },
245
+ "standards": ["css-naming.md", "nextjs-patterns.md"],
246
+ "teammate": {
247
+ "role": "CSS & Design System Specialist",
248
+ "icon": "P",
249
+ "spawn_prompt": "You are the CSS & Design System Specialist. Validate Tailwind CSS follows design system tokens (no off-palette colors), review component styling with shadcn/ui conventions. Ensure no inline styles with hardcoded values. Run design-system, css, contrast validators."
250
+ }
251
+ },
252
+
253
+ "testing-specialist": {
254
+ "tier": 3,
255
+ "role": "specialist",
256
+ "title": "Testing Specialist",
257
+ "domains": ["quality-testing"],
258
+ "keywords": ["test", "testing", "unit", "integration", "e2e", "xunit", "vitest", "testing library", "playwright"],
259
+ "always_active": false,
260
+ "validators": ["architecture"],
261
+ "relationships": {
262
+ "reports_to": "standards-architect",
263
+ "coordinates": [],
264
+ "escalates_to": "standards-architect",
265
+ "collaborates_with": ["dotnet-senior", "nextjs-expert"],
266
+ "team_role": "specialist"
267
+ },
268
+ "standards": ["coding.md"],
269
+ "teammate": {
270
+ "role": "Testing Specialist",
271
+ "icon": "Q",
272
+ "spawn_prompt": "You are the Testing Specialist. Write .NET unit tests (xUnit, Moq/NSubstitute, FluentAssertions), .NET integration tests. Write frontend tests with Vitest + Testing Library. E2E with Playwright. Follow Arrange-Act-Assert (AAA) pattern."
273
+ }
274
+ },
275
+
276
+ "_comment_tier_4": "=== TIER 4: VALIDATORS (1) ===",
277
+
278
+ "security-expert": {
279
+ "tier": 4,
280
+ "role": "validator",
281
+ "title": "Security Validator",
282
+ "domains": ["security"],
283
+ "keywords": ["sql injection", "xss", "rls", "secrets", "security scan", "vulnerability", "csrf", "owasp", "jwt"],
284
+ "always_active": true,
285
+ "validators": ["architecture"],
286
+ "relationships": {
287
+ "reports_to": "standards-architect",
288
+ "coordinates": [],
289
+ "runs_in": "hooks",
290
+ "hook_triggers": ["TeammateIdle", "TaskCompleted"],
291
+ "team_role": "validator"
292
+ },
293
+ "standards": ["coding.md", "supabase-auth.md", "supabase-rls.md"],
294
+ "teammate": null,
295
+ "hook_behavior": {
296
+ "validates": [
297
+ "SQL injection (string concatenation in Dapper queries)",
298
+ "Hardcoded secrets (API keys, Supabase keys in client code)",
299
+ "XSS (dangerouslySetInnerHTML in React)",
300
+ "RLS bypass (missing or permissive RLS policies)",
301
+ "JWT validation (Supabase JWT not verified in API)"
302
+ ],
303
+ "severity": "error",
304
+ "blocks_on_fail": true
305
+ }
306
+ }
307
+ },
308
+
309
+ "squads": {
310
+ "backend_squad": {
311
+ "leader": "dotnet-senior",
312
+ "members": ["api-designer", "supabase-expert"],
313
+ "domains": ["backend", "backend-api", "platform-supabase"]
314
+ },
315
+ "frontend_squad": {
316
+ "leader": "ui-ux-designer",
317
+ "members": ["nextjs-expert", "css-specialist"],
318
+ "domains": ["frontend-design", "frontend-nextjs", "frontend-css"],
319
+ "active_phases": {
320
+ "design": ["ui-ux-designer"],
321
+ "implement": ["nextjs-expert", "css-specialist"]
322
+ }
323
+ },
324
+ "infrastructure_squad": {
325
+ "leader": "container-specialist",
326
+ "members": ["easypanel-deployer", "devops-engineer"],
327
+ "domains": ["infrastructure-containers", "infrastructure-deploy", "infrastructure-cicd"]
328
+ },
329
+ "quality_squad": {
330
+ "leader": "standards-architect",
331
+ "members": ["testing-specialist", "security-expert"],
332
+ "domains": ["quality-testing", "security"],
333
+ "note": "No permanent leader -- standards-architect coordinates directly"
334
+ }
335
+ },
336
+
337
+ "relationship_types": {
338
+ "reports_to": "Hierarchical manager relationship",
339
+ "coordinates": "Manages/leads these agents",
340
+ "escalates_to": "Where to escalate unresolved issues",
341
+ "collaborates_with": "Peer agents for cross-domain work",
342
+ "runs_in": "Execution context (hooks, not teammates)",
343
+ "team_role": "Role in Agent Teams (lead, domain_leader, specialist, validator)"
344
+ }
345
+ }
@@ -0,0 +1,92 @@
1
+ {
2
+ "project": {
3
+ "name": "MyProject",
4
+ "description": "Project description",
5
+ "type": "nextjs-supabase",
6
+ "repository": "https://github.com/org/repo"
7
+ },
8
+ "supabase": {
9
+ "projectId": "your-project-id",
10
+ "url": "https://xxx.supabase.co",
11
+ "region": "us-east-1",
12
+ "resources": {
13
+ "database": {
14
+ "enabled": true,
15
+ "tier": "Free",
16
+ "extensions": ["pgvector", "pg_trgm"]
17
+ },
18
+ "auth": {
19
+ "enabled": true,
20
+ "providers": ["email", "google", "github"],
21
+ "mfa": false
22
+ },
23
+ "storage": {
24
+ "enabled": true,
25
+ "maxFileSizeMB": 50
26
+ },
27
+ "realtime": {
28
+ "enabled": false
29
+ }
30
+ }
31
+ },
32
+ "easypanel": {
33
+ "domain": "yourdomain.com",
34
+ "ssl": "letsencrypt",
35
+ "services": {
36
+ "api": {
37
+ "dockerfile": "Dockerfile.api",
38
+ "port": 8080,
39
+ "healthCheck": "/health"
40
+ },
41
+ "web": {
42
+ "dockerfile": "Dockerfile.web",
43
+ "port": 3000,
44
+ "healthCheck": "/api/health"
45
+ }
46
+ },
47
+ "autoDeploy": {
48
+ "enabled": true,
49
+ "branch": "main"
50
+ }
51
+ },
52
+ "github": {
53
+ "organization": "your-org",
54
+ "repository": "your-repo",
55
+ "defaultBranch": "main",
56
+ "featureBranchPrefix": "feature/"
57
+ },
58
+ "agents": {
59
+ "core": {
60
+ "standardsArchitect": { "enabled": true },
61
+ "supabaseExpert": { "enabled": true },
62
+ "containerSpecialist": { "enabled": true }
63
+ },
64
+ "stack": {
65
+ "dotnetSenior": { "enabled": true },
66
+ "nextjsExpert": { "enabled": true },
67
+ "apiDesigner": { "enabled": true }
68
+ },
69
+ "specialists": {
70
+ "easypanelDeployer": { "enabled": true },
71
+ "cssSpecialist": { "enabled": true },
72
+ "securityExpert": { "enabled": true }
73
+ }
74
+ },
75
+ "checkpoints": {
76
+ "afterDesign": true,
77
+ "afterTasks": true,
78
+ "everyNTasks": 3,
79
+ "beforeDeploy": true
80
+ },
81
+ "costs": {
82
+ "limits": {
83
+ "noApproval": "free-tier",
84
+ "withApproval": "$25/month",
85
+ "requiresADR": "above $25/month"
86
+ },
87
+ "estimates": {
88
+ "dev": "$6/month (Supabase Free + VPS $5)",
89
+ "prod": "$31/month (Supabase Pro $25 + VPS $6)"
90
+ }
91
+ }
92
+ }
@@ -0,0 +1,169 @@
1
+ # EasyPanel Setup Guide
2
+
3
+ > Deploy .NET API + Next.js to VPS via EasyPanel
4
+
5
+ ## Prerequisites
6
+
7
+ - VPS with EasyPanel installed (Ubuntu 22.04+ recommended)
8
+ - GitHub repository with Dockerfiles
9
+ - Domain name (optional, EasyPanel provides subdomains)
10
+
11
+ ## 1. GitHub Integration
12
+
13
+ ### Create Personal Access Token (PAT)
14
+
15
+ 1. GitHub > Settings > Developer Settings > Personal Access Tokens > Fine-grained
16
+ 2. Repository access: select your repo
17
+ 3. Permissions: Contents (read), Metadata (read)
18
+ 4. Copy token for EasyPanel
19
+
20
+ ### Connect in EasyPanel
21
+
22
+ 1. EasyPanel Dashboard > Settings > Git
23
+ 2. Add GitHub provider with PAT
24
+ 3. Test connection
25
+
26
+ ## 2. Create Project
27
+
28
+ ```
29
+ EasyPanel Dashboard > Projects > Create Project
30
+ Name: my-saas-app
31
+ ```
32
+
33
+ ## 3. Configure Services
34
+
35
+ ### API Service (.NET)
36
+
37
+ | Setting | Value |
38
+ |---------|-------|
39
+ | Type | App |
40
+ | Source | GitHub |
41
+ | Repository | your-org/your-repo |
42
+ | Branch | main |
43
+ | Build Path | . |
44
+ | Dockerfile | Dockerfile.api |
45
+ | Port | 8080 |
46
+
47
+ ### Web Service (Next.js)
48
+
49
+ | Setting | Value |
50
+ |---------|-------|
51
+ | Type | App |
52
+ | Source | GitHub |
53
+ | Repository | your-org/your-repo |
54
+ | Branch | main |
55
+ | Build Path | . |
56
+ | Dockerfile | Dockerfile.web |
57
+ | Port | 3000 |
58
+
59
+ ## 4. Environment Variables
60
+
61
+ ### API (.NET)
62
+
63
+ ```
64
+ ASPNETCORE_ENVIRONMENT=Production
65
+ SUPABASE_URL=https://xxx.supabase.co
66
+ SUPABASE_SERVICE_ROLE_KEY=eyJ...
67
+ SUPABASE_JWT_SECRET=your-jwt-secret
68
+ ASPNETCORE_URLS=http://+:8080
69
+ ```
70
+
71
+ ### Web (Next.js)
72
+
73
+ ```
74
+ NODE_ENV=production
75
+ NEXT_PUBLIC_SUPABASE_URL=https://xxx.supabase.co
76
+ NEXT_PUBLIC_SUPABASE_ANON_KEY=eyJ...
77
+ NEXT_PUBLIC_API_URL=https://api.yourdomain.com
78
+ ```
79
+
80
+ CRITICAL: Never commit secrets. Use EasyPanel env vars panel only.
81
+
82
+ ## 5. Domain + SSL
83
+
84
+ ### Custom Domain
85
+
86
+ 1. Service > Domains > Add Domain
87
+ 2. Enter: `api.yourdomain.com` (for API) or `app.yourdomain.com` (for web)
88
+ 3. DNS: Add A record pointing to VPS IP
89
+ 4. SSL: Enable "Let's Encrypt" (auto-renews)
90
+
91
+ ### EasyPanel Subdomain (free)
92
+
93
+ Format: `service-project.server.easypanel.host`
94
+ SSL included automatically.
95
+
96
+ ## 6. Auto-Deploy
97
+
98
+ ### GitHub Webhook
99
+
100
+ 1. Service > Settings > Enable "Auto Deploy"
101
+ 2. EasyPanel generates webhook URL
102
+ 3. GitHub repo > Settings > Webhooks > Add webhook
103
+ 4. Payload URL: (from EasyPanel)
104
+ 5. Content type: application/json
105
+ 6. Events: Push events only
106
+ 7. Branch filter: main
107
+
108
+ Pushes to `main` now trigger automatic builds.
109
+
110
+ ## 7. Health Checks
111
+
112
+ ### API Health Check
113
+
114
+ ```
115
+ Path: /health
116
+ Port: 8080
117
+ Interval: 30s
118
+ Timeout: 5s
119
+ Retries: 3
120
+ ```
121
+
122
+ .NET endpoint:
123
+ ```csharp
124
+ app.MapGet("/health", () => Results.Ok(new { status = "healthy" }));
125
+ ```
126
+
127
+ ### Web Health Check
128
+
129
+ ```
130
+ Path: /api/health
131
+ Port: 3000
132
+ Interval: 30s
133
+ ```
134
+
135
+ Next.js route handler:
136
+ ```typescript
137
+ // app/api/health/route.ts
138
+ export function GET() {
139
+ return Response.json({ status: 'healthy' });
140
+ }
141
+ ```
142
+
143
+ ## 8. Monitoring
144
+
145
+ ### Logs
146
+
147
+ EasyPanel Dashboard > Service > Logs (real-time streaming)
148
+
149
+ ### Resource Usage
150
+
151
+ EasyPanel Dashboard > Service > Metrics (CPU, Memory, Network)
152
+
153
+ ### Recommended VPS Sizing
154
+
155
+ | Workload | RAM | CPU | Storage |
156
+ |----------|-----|-----|---------|
157
+ | Dev/MVP | 2GB | 1 vCPU | 40GB |
158
+ | Small prod | 4GB | 2 vCPU | 80GB |
159
+ | Medium prod | 8GB | 4 vCPU | 160GB |
160
+
161
+ ## Troubleshooting
162
+
163
+ | Issue | Solution |
164
+ |-------|----------|
165
+ | Build fails | Check Dockerfile paths, ensure multi-stage layers correct |
166
+ | Port conflict | Verify service ports don't overlap |
167
+ | SSL not working | Wait 5 min for Let's Encrypt propagation, check DNS |
168
+ | Auto-deploy not triggering | Verify webhook URL and branch filter |
169
+ | Container OOM | Increase VPS RAM or optimize app memory usage |