@polymorphism-tech/morph-spec 3.1.0 → 4.2.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 (333) hide show
  1. package/CLAUDE.md +882 -3
  2. package/README.md +79 -18
  3. package/bin/detect-agents.js +1 -1
  4. package/bin/morph-spec.js +163 -26
  5. package/bin/task-manager.cjs +101 -7
  6. package/bin/validate.js +1 -1
  7. package/docs/cli-auto-detection.md +219 -0
  8. package/docs/getting-started.md +0 -5
  9. package/docs/llm-interaction-config.md +735 -0
  10. package/docs/troubleshooting.md +269 -0
  11. package/docs/v3.0/AGENTS.md +521 -0
  12. package/docs/v3.0/ANALYSIS.md +555 -0
  13. package/docs/v3.0/ARCHITECTURE.md +436 -0
  14. package/docs/v3.0/EXECUTION-FLOW.md +1304 -0
  15. package/docs/v3.0/FEATURES.md +688 -0
  16. package/docs/v3.0/README.md +231 -0
  17. package/docs/v3.0/ROADMAP.md +801 -0
  18. package/docs/validation-checklist.md +0 -1
  19. package/package.json +5 -1
  20. package/src/commands/agents/index.js +4 -0
  21. package/src/commands/agents/spawn-team.js +172 -0
  22. package/src/commands/{create-story.js → feature/create-story.js} +357 -354
  23. package/src/commands/feature/index.js +6 -0
  24. package/src/commands/{shard-spec.js → feature/shard-spec.js} +2 -2
  25. package/src/commands/{sprint-status.js → feature/sprint-status.js} +1 -1
  26. package/src/commands/{generate-context.js → generation/generate-context.js} +40 -40
  27. package/src/commands/{generate.js → generation/generate.js} +130 -3
  28. package/src/commands/generation/index.js +5 -0
  29. package/src/commands/index.js +16 -0
  30. package/src/commands/learning/capture-pattern.js +121 -0
  31. package/src/commands/learning/index.js +5 -0
  32. package/src/commands/learning/search-patterns.js +126 -0
  33. package/src/commands/{detect-agents.js → project/detect-agents.js} +178 -178
  34. package/src/commands/project/detect-workflow.js +174 -0
  35. package/src/commands/{detect.js → project/detect.js} +104 -104
  36. package/src/commands/{doctor.js → project/doctor.js} +356 -356
  37. package/src/commands/project/index.js +10 -0
  38. package/src/commands/{init.js → project/init.js} +305 -258
  39. package/src/commands/{sync.js → project/sync.js} +167 -167
  40. package/src/commands/{update.js → project/update.js} +240 -204
  41. package/src/commands/{advance-phase.js → state/advance-phase.js} +416 -266
  42. package/src/commands/state/approve.js +221 -0
  43. package/src/commands/state/index.js +8 -0
  44. package/src/commands/{rollback-phase.js → state/rollback-phase.js} +185 -185
  45. package/src/commands/{state.js → state/state.js} +334 -334
  46. package/src/commands/{validate-phase.js → state/validate-phase.js} +221 -221
  47. package/src/commands/tasks/index.js +4 -0
  48. package/src/commands/{task.js → tasks/task.js} +78 -78
  49. package/src/commands/templates/index.js +8 -0
  50. package/src/commands/templates/template-customize.js +101 -0
  51. package/src/commands/templates/template-list.js +128 -0
  52. package/src/commands/templates/template-render.js +95 -0
  53. package/src/commands/templates/template-show.js +131 -0
  54. package/src/commands/templates/template-validate.js +91 -0
  55. package/src/commands/utils/index.js +7 -0
  56. package/src/commands/utils/migrate-state.js +158 -0
  57. package/src/commands/{session-summary.js → utils/session-summary.js} +291 -291
  58. package/src/commands/{troubleshoot.js → utils/troubleshoot.js} +222 -222
  59. package/src/commands/utils/upgrade.js +346 -0
  60. package/src/commands/{analyze-blazor-concurrency.js → validation/analyze-blazor-concurrency.js} +193 -193
  61. package/src/commands/validation/index.js +8 -0
  62. package/src/commands/{lint-fluent.js → validation/lint-fluent.js} +352 -352
  63. package/src/commands/{validate-blazor-state.js → validation/validate-blazor-state.js} +210 -210
  64. package/src/commands/{validate-blazor.js → validation/validate-blazor.js} +156 -156
  65. package/src/commands/{validate-css.js → validation/validate-css.js} +84 -84
  66. package/src/core/index.js +10 -0
  67. package/src/core/registry/command-registry.js +302 -0
  68. package/src/core/registry/index.js +8 -0
  69. package/src/core/registry/validator-registry.js +204 -0
  70. package/src/core/state/index.js +8 -0
  71. package/src/core/state/phase-state-machine.js +214 -0
  72. package/src/{lib → core/state}/state-manager.js +572 -414
  73. package/src/core/templates/index.js +9 -0
  74. package/src/core/templates/template-data-sources.js +325 -0
  75. package/src/core/templates/template-registry.js +335 -0
  76. package/src/core/templates/template-renderer.js +477 -0
  77. package/src/core/templates/template-validator.js +296 -0
  78. package/src/core/workflows/index.js +7 -0
  79. package/src/core/workflows/workflow-detector.js +354 -0
  80. package/src/generator/config-generator.js +206 -0
  81. package/src/generator/templates/config.json.template +40 -0
  82. package/src/generator/templates/project.md.template +67 -0
  83. package/src/lib/{complexity-analyzer.js → analysis/complexity-analyzer.js} +441 -441
  84. package/src/lib/analysis/index.js +7 -0
  85. package/src/lib/checkpoints/checkpoint-hooks.js +258 -0
  86. package/src/lib/checkpoints/index.js +7 -0
  87. package/src/lib/detectors/config-detector.js +223 -223
  88. package/src/lib/detectors/conversation-analyzer.js +163 -163
  89. package/src/lib/{design-system-detector.js → detectors/design-system-detector.js} +187 -187
  90. package/src/lib/detectors/index.js +87 -84
  91. package/src/lib/detectors/standards-generator.js +275 -275
  92. package/src/lib/detectors/structure-detector.js +245 -245
  93. package/src/lib/{context-generator.js → generators/context-generator.js} +526 -516
  94. package/src/lib/generators/index.js +10 -0
  95. package/src/lib/generators/metadata-extractor.js +387 -0
  96. package/src/lib/{recap-generator.js → generators/recap-generator.js} +205 -205
  97. package/src/lib/learning/index.js +7 -0
  98. package/src/lib/orchestration/index.js +7 -0
  99. package/src/lib/{team-orchestrator.js → orchestration/team-orchestrator.js} +323 -323
  100. package/src/lib/stacks/index.js +7 -0
  101. package/src/lib/{stack-resolver.js → stacks/stack-resolver.js} +180 -148
  102. package/src/lib/standards/index.js +7 -0
  103. package/src/lib/{standards-context-injector.js → standards/standards-context-injector.js} +298 -288
  104. package/src/lib/troubleshooting/index.js +8 -0
  105. package/src/lib/{troubleshoot-grep.js → troubleshooting/troubleshoot-grep.js} +204 -204
  106. package/src/lib/{troubleshoot-index.js → troubleshooting/troubleshoot-index.js} +144 -144
  107. package/src/lib/validators/architecture/architecture-validator.js +387 -0
  108. package/src/lib/validators/architecture/index.js +7 -0
  109. package/src/lib/validators/architecture-validator.js +40 -367
  110. package/src/lib/{blazor-concurrency-analyzer.js → validators/blazor/blazor-concurrency-analyzer.js} +277 -288
  111. package/src/lib/{blazor-state-validator.js → validators/blazor/blazor-state-validator.js} +279 -291
  112. package/src/lib/{blazor-validator.js → validators/blazor/blazor-validator.js} +369 -374
  113. package/src/lib/validators/blazor/index.js +9 -0
  114. package/src/lib/validators/content/content-validator.js +351 -0
  115. package/src/lib/validators/content/index.js +7 -0
  116. package/src/lib/validators/content-validator.js +164 -0
  117. package/src/lib/validators/{contract-compliance-validator.js → contracts/contract-compliance-validator.js} +273 -273
  118. package/src/lib/validators/contracts/index.js +7 -0
  119. package/src/lib/{css-validator.js → validators/css/css-validator.js} +352 -352
  120. package/src/lib/validators/css/index.js +7 -0
  121. package/src/lib/validators/{design-system-validator.js → design-system/design-system-validator.js} +231 -231
  122. package/src/lib/validators/design-system/index.js +7 -0
  123. package/src/lib/validators/package-validator.js +41 -340
  124. package/src/lib/validators/packages/index.js +7 -0
  125. package/src/lib/validators/packages/package-validator.js +360 -0
  126. package/src/lib/validators/shared/index.js +12 -0
  127. package/src/lib/validators/shared/issue-counter.js +18 -0
  128. package/src/lib/validators/shared/result-formatter.js +124 -0
  129. package/src/lib/{spec-validator.js → validators/spec-validator.js} +258 -258
  130. package/src/lib/validators/ui/index.js +7 -0
  131. package/src/lib/validators/ui/ui-contrast-validator.js +422 -0
  132. package/src/lib/validators/ui-contrast-validator.js +31 -409
  133. package/src/lib/{validation-runner.js → validators/validation-runner.js} +286 -284
  134. package/src/llm/analyzer.js +215 -0
  135. package/src/llm/environment-detector.js +43 -0
  136. package/src/llm/few-shot-examples.js +216 -0
  137. package/src/llm/project-config-schema.json +188 -0
  138. package/src/llm/prompt-builder.js +96 -0
  139. package/src/orchestrator.js +206 -0
  140. package/src/sanitizer/context-sanitizer.js +221 -0
  141. package/src/sanitizer/patterns.js +163 -0
  142. package/src/scanner/project-scanner.js +242 -0
  143. package/src/ui/diff-display.js +91 -0
  144. package/src/ui/interactive-wizard.js +96 -0
  145. package/src/ui/user-review.js +211 -0
  146. package/src/ui/wizard-questions.js +188 -0
  147. package/src/utils/color-utils.js +70 -0
  148. package/src/utils/file-copier.js +188 -189
  149. package/src/utils/process-handler.js +97 -0
  150. package/src/writer/file-writer.js +86 -0
  151. package/stacks/blazor-azure/.claude/skills/level-2-domains/ai-agents/ai-system-architect.md +3 -3
  152. package/stacks/blazor-azure/.claude/skills/level-2-domains/backend/api-designer.md +59 -0
  153. package/stacks/blazor-azure/.claude/skills/level-2-domains/backend/dotnet-senior.md +45 -255
  154. package/stacks/blazor-azure/.claude/skills/level-2-domains/backend/ef-modeler.md +33 -88
  155. package/stacks/blazor-azure/.claude/skills/level-2-domains/backend/ms-agent-expert.md +25 -89
  156. package/stacks/blazor-azure/.claude/skills/level-2-domains/integrations/hangfire-orchestrator.md +64 -0
  157. package/stacks/blazor-azure/.morph/config/agents.json +879 -764
  158. package/stacks/blazor-azure/.morph/hooks/{pre-commit-tests.sh → pre-commit/tests-csharp.sh} +3 -2
  159. package/stacks/blazor-azure/.morph/templates/.gitkeep +0 -0
  160. package/stacks/blazor-azure/.morph/templates/infrastructure/github/workflows/cd-prod.yml.hbs +41 -0
  161. package/stacks/blazor-azure/.morph/templates/infrastructure/github/workflows/cd-staging.yml.hbs +24 -0
  162. package/stacks/blazor-azure/.morph/templates/infrastructure/github/workflows/ci-build.yml.hbs +23 -0
  163. package/stacks/nextjs-supabase/.claude/commands/morph-apply.md +221 -0
  164. package/stacks/nextjs-supabase/.claude/commands/morph-archive.md +79 -0
  165. package/stacks/nextjs-supabase/.claude/commands/morph-deploy.md +529 -0
  166. package/stacks/nextjs-supabase/.claude/commands/morph-infra.md +209 -0
  167. package/stacks/nextjs-supabase/.claude/commands/morph-preflight.md +227 -0
  168. package/stacks/nextjs-supabase/.claude/commands/morph-proposal.md +122 -0
  169. package/stacks/nextjs-supabase/.claude/commands/morph-status.md +86 -0
  170. package/stacks/nextjs-supabase/.claude/commands/morph-troubleshoot.md +122 -0
  171. package/stacks/nextjs-supabase/.claude/settings.local.json +6 -0
  172. package/stacks/nextjs-supabase/.claude/skills/level-2-domains/integrations/supabase-expert.md +30 -150
  173. package/stacks/nextjs-supabase/.morph/config/agents.json +345 -345
  174. package/stacks/nextjs-supabase/.morph/hooks/pre-commit/tests-typescript.sh +61 -0
  175. package/stacks/nextjs-supabase/.morph/templates/.gitkeep +0 -0
  176. package/stacks/nextjs-supabase/.morph/templates/infrastructure/github/workflows/cd-prod.yml.hbs +22 -0
  177. package/stacks/nextjs-supabase/.morph/templates/infrastructure/github/workflows/cd-staging.yml.hbs +22 -0
  178. package/stacks/nextjs-supabase/.morph/templates/infrastructure/github/workflows/ci-build.yml.hbs +35 -0
  179. package/stacks/nextjs-supabase/README.md +6 -15
  180. package/bin/render-template.js +0 -303
  181. package/bin/semantic-detect-agents.js +0 -247
  182. package/bin/validate-agents-skills.js +0 -257
  183. package/bin/validate-agents.js +0 -70
  184. package/bin/validate-phase.js +0 -263
  185. package/docs/examples.md +0 -328
  186. package/scripts/reorganize-skills.cjs +0 -175
  187. package/scripts/validate-agents-structure.cjs +0 -52
  188. package/scripts/validate-skills.cjs +0 -180
  189. package/src/commands/deploy.js +0 -780
  190. package/src/lib/continuous-validator.js +0 -421
  191. package/src/lib/decision-constraint-loader.js +0 -109
  192. package/src/lib/design-system-scaffolder.js +0 -299
  193. package/src/lib/hook-executor.js +0 -257
  194. package/src/lib/mockup-generator.js +0 -366
  195. package/src/lib/ui-detector.js +0 -350
  196. package/stacks/blazor-azure/.azure/README.md +0 -293
  197. package/stacks/blazor-azure/.azure/docs/azure-devops-setup.md +0 -454
  198. package/stacks/blazor-azure/.azure/docs/branch-strategy.md +0 -398
  199. package/stacks/blazor-azure/.azure/docs/local-development.md +0 -515
  200. package/stacks/blazor-azure/.azure/pipelines/pipeline-variables.yml +0 -34
  201. package/stacks/blazor-azure/.azure/pipelines/prod-pipeline.yml +0 -319
  202. package/stacks/blazor-azure/.azure/pipelines/staging-pipeline.yml +0 -234
  203. package/stacks/blazor-azure/.azure/pipelines/templates/build-dotnet.yml +0 -75
  204. package/stacks/blazor-azure/.azure/pipelines/templates/deploy-app-service.yml +0 -94
  205. package/stacks/blazor-azure/.azure/pipelines/templates/deploy-container-app.yml +0 -120
  206. package/stacks/blazor-azure/.azure/pipelines/templates/infra-deploy.yml +0 -90
  207. package/stacks/blazor-azure/.claude/settings.local.json +0 -15
  208. package/stacks/blazor-azure/.morph/docs/STORY-DRIVEN-DEVELOPMENT.md +0 -392
  209. package/stacks/blazor-azure/.morph/docs/workflows/design-impl.md +0 -37
  210. package/stacks/blazor-azure/.morph/docs/workflows/enforcement-pipeline.md +0 -668
  211. package/stacks/blazor-azure/.morph/docs/workflows/fast-track.md +0 -29
  212. package/stacks/blazor-azure/.morph/docs/workflows/full-morph.md +0 -76
  213. package/stacks/blazor-azure/.morph/docs/workflows/standard.md +0 -44
  214. package/stacks/blazor-azure/.morph/docs/workflows/ui-refresh.md +0 -39
  215. package/stacks/blazor-azure/.morph/examples/api-nextjs/README.md +0 -241
  216. package/stacks/blazor-azure/.morph/examples/api-nextjs/contracts.ts +0 -307
  217. package/stacks/blazor-azure/.morph/examples/api-nextjs/spec.md +0 -399
  218. package/stacks/blazor-azure/.morph/examples/api-nextjs/tasks.md +0 -168
  219. package/stacks/blazor-azure/.morph/examples/micro-saas/README.md +0 -125
  220. package/stacks/blazor-azure/.morph/examples/micro-saas/contracts.cs +0 -358
  221. package/stacks/blazor-azure/.morph/examples/micro-saas/decisions.md +0 -246
  222. package/stacks/blazor-azure/.morph/examples/micro-saas/spec.md +0 -236
  223. package/stacks/blazor-azure/.morph/examples/micro-saas/tasks.md +0 -150
  224. package/stacks/blazor-azure/.morph/examples/multi-agent/README.md +0 -309
  225. package/stacks/blazor-azure/.morph/examples/multi-agent/contracts.cs +0 -433
  226. package/stacks/blazor-azure/.morph/examples/multi-agent/spec.md +0 -479
  227. package/stacks/blazor-azure/.morph/examples/multi-agent/tasks.md +0 -185
  228. package/stacks/blazor-azure/.morph/examples/scheduled-reports/decisions.md +0 -158
  229. package/stacks/blazor-azure/.morph/examples/scheduled-reports/proposal.md +0 -95
  230. package/stacks/blazor-azure/.morph/examples/scheduled-reports/spec.md +0 -267
  231. package/stacks/blazor-azure/.morph/examples/state-v3.json +0 -188
  232. package/stacks/blazor-azure/.morph/hooks/README.md +0 -348
  233. package/stacks/blazor-azure/.morph/hooks/pre-commit-agents.sh +0 -24
  234. package/stacks/blazor-azure/.morph/hooks/pre-commit-all.sh +0 -48
  235. package/stacks/blazor-azure/.morph/hooks/pre-commit-specs.sh +0 -49
  236. package/stacks/blazor-azure/.morph/hooks/task-completed.js +0 -73
  237. package/stacks/blazor-azure/.morph/hooks/teammate-idle.js +0 -68
  238. package/stacks/blazor-azure/.morph/standards/agent-framework-blazor-ui.md +0 -359
  239. package/stacks/blazor-azure/.morph/standards/agent-framework-production.md +0 -410
  240. package/stacks/blazor-azure/.morph/standards/agent-framework-setup.md +0 -413
  241. package/stacks/blazor-azure/.morph/standards/agent-framework-workflows.md +0 -349
  242. package/stacks/blazor-azure/.morph/standards/agent-teams-workflow.md +0 -474
  243. package/stacks/blazor-azure/.morph/standards/architecture.md +0 -325
  244. package/stacks/blazor-azure/.morph/standards/azure.md +0 -605
  245. package/stacks/blazor-azure/.morph/standards/coding.md +0 -377
  246. package/stacks/blazor-azure/.morph/standards/dotnet10-migration.md +0 -520
  247. package/stacks/blazor-azure/.morph/standards/fluent-ui-setup.md +0 -590
  248. package/stacks/blazor-azure/.morph/standards/migration-guide.md +0 -514
  249. package/stacks/blazor-azure/.morph/standards/passkeys-auth.md +0 -423
  250. package/stacks/blazor-azure/.morph/standards/vector-search-rag.md +0 -536
  251. package/stacks/blazor-azure/.morph/templates/CONTEXT-FEATURE.md +0 -276
  252. package/stacks/blazor-azure/.morph/templates/CONTEXT.md +0 -170
  253. package/stacks/blazor-azure/.morph/templates/FluentDesignTheme.cs +0 -149
  254. package/stacks/blazor-azure/.morph/templates/MudTheme.cs +0 -281
  255. package/stacks/blazor-azure/.morph/templates/agent.cs +0 -163
  256. package/stacks/blazor-azure/.morph/templates/clarify-questions.md +0 -159
  257. package/stacks/blazor-azure/.morph/templates/component.razor +0 -239
  258. package/stacks/blazor-azure/.morph/templates/contracts/Commands.cs +0 -74
  259. package/stacks/blazor-azure/.morph/templates/contracts/Entities.cs +0 -25
  260. package/stacks/blazor-azure/.morph/templates/contracts/Queries.cs +0 -74
  261. package/stacks/blazor-azure/.morph/templates/contracts/README.md +0 -74
  262. package/stacks/blazor-azure/.morph/templates/contracts.cs +0 -217
  263. package/stacks/blazor-azure/.morph/templates/decisions.md +0 -123
  264. package/stacks/blazor-azure/.morph/templates/design-system.css +0 -226
  265. package/stacks/blazor-azure/.morph/templates/infra/.dockerignore.example +0 -89
  266. package/stacks/blazor-azure/.morph/templates/infra/Dockerfile.example +0 -82
  267. package/stacks/blazor-azure/.morph/templates/infra/README.md +0 -286
  268. package/stacks/blazor-azure/.morph/templates/infra/app-insights.bicep +0 -63
  269. package/stacks/blazor-azure/.morph/templates/infra/app-service.bicep +0 -164
  270. package/stacks/blazor-azure/.morph/templates/infra/azure-pipelines-deploy.yml +0 -480
  271. package/stacks/blazor-azure/.morph/templates/infra/container-app-env.bicep +0 -49
  272. package/stacks/blazor-azure/.morph/templates/infra/container-app.bicep +0 -156
  273. package/stacks/blazor-azure/.morph/templates/infra/deploy-checklist.md +0 -426
  274. package/stacks/blazor-azure/.morph/templates/infra/deploy.ps1 +0 -229
  275. package/stacks/blazor-azure/.morph/templates/infra/deploy.sh +0 -208
  276. package/stacks/blazor-azure/.morph/templates/infra/key-vault.bicep +0 -91
  277. package/stacks/blazor-azure/.morph/templates/infra/main.bicep +0 -189
  278. package/stacks/blazor-azure/.morph/templates/infra/parameters.dev.json +0 -29
  279. package/stacks/blazor-azure/.morph/templates/infra/parameters.prod.json +0 -29
  280. package/stacks/blazor-azure/.morph/templates/infra/parameters.staging.json +0 -29
  281. package/stacks/blazor-azure/.morph/templates/infra/sql-database.bicep +0 -103
  282. package/stacks/blazor-azure/.morph/templates/infra/storage.bicep +0 -106
  283. package/stacks/blazor-azure/.morph/templates/integrations/asaas-client.cs +0 -387
  284. package/stacks/blazor-azure/.morph/templates/integrations/asaas-webhook.cs +0 -351
  285. package/stacks/blazor-azure/.morph/templates/integrations/azure-identity-config.cs +0 -288
  286. package/stacks/blazor-azure/.morph/templates/integrations/clerk-config.cs +0 -258
  287. package/stacks/blazor-azure/.morph/templates/job.cs +0 -171
  288. package/stacks/blazor-azure/.morph/templates/migration.cs +0 -83
  289. package/stacks/blazor-azure/.morph/templates/proposal.md +0 -141
  290. package/stacks/blazor-azure/.morph/templates/recap.md +0 -94
  291. package/stacks/blazor-azure/.morph/templates/repository.cs +0 -141
  292. package/stacks/blazor-azure/.morph/templates/saas/subscription.cs +0 -347
  293. package/stacks/blazor-azure/.morph/templates/saas/tenant.cs +0 -338
  294. package/stacks/blazor-azure/.morph/templates/service.cs +0 -139
  295. package/stacks/blazor-azure/.morph/templates/simulation.md +0 -353
  296. package/stacks/blazor-azure/.morph/templates/spec.md +0 -149
  297. package/stacks/blazor-azure/.morph/templates/sprint-status.yaml +0 -68
  298. package/stacks/blazor-azure/.morph/templates/state.template.json +0 -222
  299. package/stacks/blazor-azure/.morph/templates/story.md +0 -143
  300. package/stacks/blazor-azure/.morph/templates/tasks.md +0 -257
  301. package/stacks/blazor-azure/.morph/templates/test.cs +0 -239
  302. package/stacks/blazor-azure/.morph/templates/ui-components.md +0 -362
  303. package/stacks/blazor-azure/.morph/templates/ui-design-system.md +0 -286
  304. package/stacks/blazor-azure/.morph/templates/ui-flows.md +0 -336
  305. package/stacks/blazor-azure/.morph/templates/ui-mockups.md +0 -133
  306. package/stacks/nextjs-supabase/.morph/docs/easypanel-setup.md +0 -169
  307. package/stacks/nextjs-supabase/.morph/docs/supabase-mcp-setup.md +0 -247
  308. package/stacks/nextjs-supabase/.morph/examples/crud-nextjs-supabase/README.md +0 -697
  309. package/stacks/nextjs-supabase/.morph/examples/crud-nextjs-supabase/spec.md +0 -85
  310. package/stacks/nextjs-supabase/.morph/examples/crud-nextjs-supabase/tasks.md +0 -86
  311. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/README.md +0 -498
  312. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/decisions.md +0 -121
  313. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/spec.md +0 -138
  314. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/tasks.md +0 -162
  315. package/stacks/nextjs-supabase/.morph/standards/easypanel-deploy.md +0 -191
  316. package/stacks/nextjs-supabase/.morph/standards/nextjs-patterns.md +0 -193
  317. package/stacks/nextjs-supabase/.morph/standards/supabase-auth.md +0 -171
  318. package/stacks/nextjs-supabase/.morph/standards/supabase-pgvector.md +0 -164
  319. package/stacks/nextjs-supabase/.morph/standards/supabase-rls.md +0 -179
  320. package/stacks/nextjs-supabase/.morph/standards/supabase-storage.md +0 -148
  321. package/stacks/nextjs-supabase/.morph/templates/contracts.cs +0 -173
  322. package/stacks/nextjs-supabase/.morph/templates/contracts.ts +0 -168
  323. package/stacks/nextjs-supabase/.morph/templates/decisions.md +0 -115
  324. package/stacks/nextjs-supabase/.morph/templates/dockerfile-api.dockerfile +0 -38
  325. package/stacks/nextjs-supabase/.morph/templates/dockerfile-web.dockerfile +0 -48
  326. package/stacks/nextjs-supabase/.morph/templates/proposal.md +0 -145
  327. package/stacks/nextjs-supabase/.morph/templates/recap.md +0 -134
  328. package/stacks/nextjs-supabase/.morph/templates/rls-policy.sql +0 -57
  329. package/stacks/nextjs-supabase/.morph/templates/spec.md +0 -231
  330. package/stacks/nextjs-supabase/.morph/templates/supabase-migration.sql +0 -100
  331. package/stacks/nextjs-supabase/.morph/templates/tasks.md +0 -257
  332. /package/src/lib/{design-system-generator.js → generators/design-system-generator.js} +0 -0
  333. /package/src/lib/{learning-system.js → learning/learning-system.js} +0 -0
@@ -1,514 +0,0 @@
1
- # Guia de Migração: App Service → Container Apps
2
-
3
- > **MORPH-SPEC Framework**
4
- > Quando seu projeto crescer além do Free Tier
5
-
6
- ---
7
-
8
- ## 📊 Quando Migrar?
9
-
10
- ### Sinais de que é hora de migrar
11
-
12
- | Indicador | Descrição | Ação |
13
- |-----------|-----------|------|
14
- | 🔴 **CPU Quota Esgotada** | Erro `CPU quota exceeded` frequente | Migrar imediatamente |
15
- | 🔴 **Cold Starts Críticos** | App dormindo afeta UX/negócio | Avaliar impacto → Migrar |
16
- | 🟡 **Tráfego Crescente** | >500 req/dia consistente | Planejar migração |
17
- | 🟡 **SSL Customizado** | Necessita domínio próprio com SSL | Avaliar alternativas |
18
- | 🟢 **Background Jobs** | Precisa rodar Hangfire 24/7 | Migrar ou separar worker |
19
-
20
- ### Matriz de Decisão
21
-
22
- ```
23
- Tráfego < 100 req/dia → App Service Free F1
24
- Tráfego 100-1000 req/dia → App Service B1 ($13/mês)
25
- Tráfego > 1000 req/dia → Container Apps (~$5-15/mês)
26
- Background Jobs 24/7 → Container Apps com minReplicas: 1
27
- SSL Customizado → Container Apps ou App Service B1+
28
- ```
29
-
30
- ---
31
-
32
- ## 🗺️ Roadmap de Migração
33
-
34
- ### Fase 1: Preparação (1-2 dias)
35
-
36
- #### 1.1. Auditoria do Código
37
-
38
- **Checklist:**
39
- - [ ] App usa configuração via `IConfiguration`
40
- - [ ] Não há paths hardcoded (usar `IWebHostEnvironment`)
41
- - [ ] Logging para stdout/stderr (não arquivos locais)
42
- - [ ] Health checks implementados (`/health`, `/health/ready`)
43
- - [ ] Secrets em Key Vault (não `appsettings.json`)
44
-
45
- **Verificar:**
46
- ```csharp
47
- // ✅ BOM: Configuração via IConfiguration
48
- var connectionString = configuration["ConnectionStrings:Default"];
49
-
50
- // ❌ RUIM: Hardcoded
51
- var path = "C:\\Data\\uploads";
52
-
53
- // ✅ BOM: Usar IWebHostEnvironment
54
- var path = Path.Combine(webHostEnv.ContentRootPath, "uploads");
55
- ```
56
-
57
- #### 1.2. Criar Dockerfile
58
-
59
- ```dockerfile
60
- # ============================================
61
- # MORPH-SPEC - .NET 8 Blazor Container
62
- # ============================================
63
-
64
- FROM mcr.microsoft.com/dotnet/aspnet:8.0 AS base
65
- WORKDIR /app
66
- EXPOSE 8080
67
- EXPOSE 8081
68
-
69
- # Create non-root user
70
- RUN adduser --disabled-password --gecos '' appuser && chown -R appuser /app
71
- USER appuser
72
-
73
- FROM mcr.microsoft.com/dotnet/sdk:8.0 AS build
74
- WORKDIR /src
75
- COPY ["YourApp/YourApp.csproj", "YourApp/"]
76
- RUN dotnet restore "YourApp/YourApp.csproj"
77
- COPY . .
78
- WORKDIR "/src/YourApp"
79
- RUN dotnet build "YourApp.csproj" -c Release -o /app/build
80
-
81
- FROM build AS publish
82
- RUN dotnet publish "YourApp.csproj" -c Release -o /app/publish /p:UseAppHost=false
83
-
84
- FROM base AS final
85
- WORKDIR /app
86
- COPY --from=publish /app/publish .
87
-
88
- # Health check
89
- HEALTHCHECK --interval=30s --timeout=3s --start-period=5s --retries=3 \
90
- CMD curl -f http://localhost:8080/health || exit 1
91
-
92
- ENTRYPOINT ["dotnet", "YourApp.dll"]
93
- ```
94
-
95
- #### 1.3. Implementar Health Checks
96
-
97
- ```csharp
98
- // Program.cs
99
- builder.Services.AddHealthChecks()
100
- .AddSqlServer(
101
- connectionString: builder.Configuration["ConnectionStrings:Default"],
102
- name: "sql",
103
- timeout: TimeSpan.FromSeconds(3))
104
- .AddCheck("self", () => HealthCheckResult.Healthy());
105
-
106
- var app = builder.Build();
107
-
108
- app.MapHealthChecks("/health", new HealthCheckOptions
109
- {
110
- Predicate = _ => true,
111
- ResponseWriter = UIResponseWriter.WriteHealthCheckUIResponse
112
- });
113
-
114
- app.MapHealthChecks("/health/ready", new HealthCheckOptions
115
- {
116
- Predicate = check => check.Tags.Contains("ready")
117
- });
118
-
119
- app.MapHealthChecks("/health/live", new HealthCheckOptions
120
- {
121
- Predicate = _ => false
122
- });
123
- ```
124
-
125
- ---
126
-
127
- ### Fase 2: Setup Azure Container Registry (ACR)
128
-
129
- #### 2.1. Criar ACR via Bicep
130
-
131
- ```bicep
132
- // acr.bicep
133
- resource acr 'Microsoft.ContainerRegistry/registries@2023-01-01-preview' = {
134
- name: 'acr${uniqueString(resourceGroup().id)}'
135
- location: location
136
- sku: {
137
- name: 'Basic' // $5/mês
138
- }
139
- properties: {
140
- adminUserEnabled: false // Usar Managed Identity
141
- }
142
- }
143
- ```
144
-
145
- #### 2.2. Deploy ACR
146
-
147
- ```bash
148
- # Via Azure CLI
149
- az deployment group create \
150
- --resource-group rg-myapp-dev \
151
- --template-file acr.bicep
152
-
153
- # Obter ACR login server
154
- ACR_NAME=$(az acr list -g rg-myapp-dev --query "[0].name" -o tsv)
155
- ACR_LOGIN_SERVER=$(az acr show -n $ACR_NAME --query loginServer -o tsv)
156
- ```
157
-
158
- #### 2.3. Build e Push Imagem
159
-
160
- **Via Azure DevOps Pipeline:**
161
- ```yaml
162
- # staging-pipeline.yml
163
- - task: Docker@2
164
- displayName: 'Build and push container'
165
- inputs:
166
- containerRegistry: 'ACR-Connection'
167
- repository: 'myapp'
168
- command: 'buildAndPush'
169
- Dockerfile: 'Dockerfile'
170
- tags: |
171
- v1.0.0
172
- staging-latest
173
- ```
174
-
175
- **Via Azure CLI (local):**
176
- ```bash
177
- # Build local e push para ACR
178
- az acr build \
179
- --registry $ACR_NAME \
180
- --image myapp:latest \
181
- --image myapp:v1.0.0 \
182
- --file Dockerfile \
183
- .
184
- ```
185
-
186
- ---
187
-
188
- ### Fase 3: Deploy Container Apps
189
-
190
- #### 3.1. Atualizar Parameters
191
-
192
- **parameters.dev.json**
193
- ```json
194
- {
195
- "hostingType": {
196
- "value": "containerapp"
197
- },
198
- "containerImage": {
199
- "value": "acrXXXX.azurecr.io/myapp:latest"
200
- }
201
- }
202
- ```
203
-
204
- #### 3.2. Deploy Infraestrutura
205
-
206
- **Via Azure DevOps Pipeline:**
207
- ```yaml
208
- # Use o template pronto
209
- - template: templates/infra-deploy.yml
210
- parameters:
211
- azureSubscription: 'Azure-Staging-Connection'
212
- resourceGroupName: 'rg-myapp-staging'
213
- bicepTemplateFile: '.morph/templates/infra/main.bicep'
214
- parametersFile: '.morph/templates/infra/parameters.staging.json'
215
- ```
216
-
217
- **Via Azure CLI (local):**
218
- ```bash
219
- # Deploy via Azure CLI
220
- az deployment group create \
221
- --resource-group rg-myapp-dev \
222
- --template-file main.bicep \
223
- --parameters @parameters.dev.json
224
- ```
225
-
226
- #### 3.3. Configurar Managed Identity para ACR
227
-
228
- ```bash
229
- # Obter Container App Managed Identity
230
- CA_PRINCIPAL_ID=$(az containerapp show \
231
- -n ca-myapp-dev \
232
- -g rg-myapp-dev \
233
- --query identity.principalId -o tsv)
234
-
235
- # Dar permissão AcrPull
236
- az role assignment create \
237
- --assignee $CA_PRINCIPAL_ID \
238
- --role AcrPull \
239
- --scope $(az acr show -n $ACR_NAME --query id -o tsv)
240
- ```
241
-
242
- ---
243
-
244
- ### Fase 4: Teste e Validação
245
-
246
- #### 4.1. Smoke Tests
247
-
248
- ```bash
249
- # Obter URL do Container App
250
- CA_URL=$(az containerapp show \
251
- -n ca-myapp-dev \
252
- -g rg-myapp-dev \
253
- --query properties.configuration.ingress.fqdn -o tsv)
254
-
255
- # Testar health checks
256
- curl https://$CA_URL/health
257
- curl https://$CA_URL/health/ready
258
-
259
- # Testar funcionalidade principal
260
- curl https://$CA_URL/api/status
261
- ```
262
-
263
- #### 4.2. Load Test (opcional)
264
-
265
- ```bash
266
- # Instalar hey (HTTP load generator)
267
- go install github.com/rakyll/hey@latest
268
-
269
- # Simular carga
270
- hey -z 30s -c 10 https://$CA_URL/
271
- ```
272
-
273
- #### 4.3. Validar Auto-Scaling
274
-
275
- ```bash
276
- # Gerar carga
277
- hey -z 2m -c 50 https://$CA_URL/
278
-
279
- # Monitorar réplicas
280
- watch -n 2 "az containerapp revision list \
281
- -n ca-myapp-dev \
282
- -g rg-myapp-dev \
283
- --query '[0].properties.replicas' -o tsv"
284
- ```
285
-
286
- ---
287
-
288
- ### Fase 5: Cutover (Mudança de DNS)
289
-
290
- #### 5.1. Estratégia Blue-Green
291
-
292
- ```bash
293
- # Manter App Service rodando (blue)
294
- # Container Apps já rodando (green)
295
-
296
- # Testar green profundamente
297
- # Quando confiante, mudar DNS para green
298
- # Aguardar 24h
299
- # Se OK, desligar blue (App Service)
300
- ```
301
-
302
- #### 5.2. Atualizar DNS
303
-
304
- Se usando domínio customizado:
305
-
306
- ```
307
- # Old (App Service)
308
- myapp.azurewebsites.net → CNAME → myapp.com
309
-
310
- # New (Container Apps)
311
- myapp.region.azurecontainerapps.io → CNAME → myapp.com
312
- ```
313
-
314
- ---
315
-
316
- ## 💰 Comparativo de Custos
317
-
318
- ### Antes (App Service Free F1)
319
- ```
320
- App Service F1: $0/mês
321
- Azure SQL Free: $0/mês
322
- App Insights Free: $0/mês
323
- ────────────────────────────
324
- TOTAL: $0/mês
325
- ```
326
-
327
- ### Depois (Container Apps)
328
- ```
329
- Container Apps: $0-8/mês (scale-to-zero, uso variável)
330
- ACR Basic: $5/mês
331
- Azure SQL Free: $0/mês
332
- App Insights Free: $0/mês
333
- ────────────────────────────
334
- TOTAL: $5-13/mês
335
- ```
336
-
337
- ### Alternativa (App Service B1)
338
- ```
339
- App Service B1: $13/mês (always-on)
340
- Azure SQL Free: $0/mês
341
- App Insights Free: $0/mês
342
- ────────────────────────────
343
- TOTAL: $13/mês
344
- ```
345
-
346
- **Análise:**
347
- - Container Apps mais econômico que B1 para tráfego variável
348
- - Container Apps melhor auto-scaling que App Service
349
- - Container Apps suporta múltiplos containers (arquitetura futura)
350
-
351
- ---
352
-
353
- ## 🔄 Rollback Plan
354
-
355
- ### Se algo der errado
356
-
357
- #### Opção 1: Rollback via DNS (mais rápido)
358
- ```bash
359
- # Reverter CNAME para App Service
360
- # Tempo: ~5 minutos (propagação DNS)
361
- ```
362
-
363
- #### Opção 2: Rollback via código
364
- ```bash
365
- # Atualizar parameters.dev.json
366
- {
367
- "hostingType": {
368
- "value": "appservice"
369
- }
370
- }
371
-
372
- # Redeploy
373
- az deployment group create \
374
- --resource-group rg-myapp-dev \
375
- --template-file main.bicep \
376
- --parameters @parameters.dev.json
377
- ```
378
-
379
- ---
380
-
381
- ## ✅ Checklist Final
382
-
383
- ### Antes de Desligar App Service
384
-
385
- - [ ] Container Apps rodando estável por 7+ dias
386
- - [ ] Todos os health checks passando
387
- - [ ] Monitoramento no App Insights funcionando
388
- - [ ] Logs sendo coletados corretamente
389
- - [ ] Performance igual ou melhor que App Service
390
- - [ ] Custo dentro do esperado
391
- - [ ] Backup do código e configuração
392
- - [ ] Equipe treinada no novo ambiente
393
-
394
- ### Pós-Migração
395
-
396
- - [ ] Deletar App Service Plan (economizar recursos)
397
- - [ ] Deletar deployment slots antigos
398
- - [ ] Atualizar documentação interna
399
- - [ ] Atualizar `.morph/project.md` com nova infra
400
- - [ ] Arquivar configurações antigas
401
-
402
- ---
403
-
404
- ## 🔄 Automatizar com CI/CD
405
-
406
- ### Azure DevOps Pipelines
407
-
408
- Após migração manual bem-sucedida, automatize com pipelines:
409
-
410
- **1. Configurar Workload Identity:**
411
- ```bash
412
- # Ver guia completo em: .azure/docs/azure-devops-setup.md
413
-
414
- # Criar App Registration
415
- az ad app create --display-name "myapp-staging-pipeline"
416
-
417
- # Configurar federated credential
418
- az ad app federated-credential create \
419
- --id <APP_ID> \
420
- --parameters @federated-credential.json
421
- ```
422
-
423
- **2. Usar Pipeline Pronto:**
424
- ```bash
425
- # Copiar pipeline para seu projeto
426
- cp .azure/pipelines/staging-pipeline.yml azure-pipelines.yml
427
-
428
- # Configurar variáveis no Azure DevOps:
429
- # - ACR_NAME
430
- # - APP_NAME
431
- # - SUBSCRIPTION_ID
432
-
433
- # Commit e push
434
- git add azure-pipelines.yml
435
- git commit -m "ci: add staging pipeline"
436
- git push origin main
437
- ```
438
-
439
- **3. Deploy Automático:**
440
- - Dev: Triggado automaticamente em push para `develop`
441
- - Staging: Triggado automaticamente em push para `main`
442
- - Prod: Manual ou via tag `v*`
443
-
444
- **Pipelines inclusos no framework:**
445
- - `.azure/pipelines/dev-pipeline.yml` - App Service Free F1
446
- - `.azure/pipelines/staging-pipeline.yml` - Container Apps (scale-to-zero)
447
- - `.azure/pipelines/prod-pipeline.yml` - Container Apps (always-on, com approval)
448
-
449
- ---
450
-
451
- ## 📚 Referências
452
-
453
- - [Azure Container Apps Docs](https://learn.microsoft.com/azure/container-apps/)
454
- - [ACR Best Practices](https://learn.microsoft.com/azure/container-registry/container-registry-best-practices)
455
- - [Dockerfile Best Practices](https://docs.docker.com/develop/dev-best-practices/)
456
- - [Health Checks ASP.NET](https://learn.microsoft.com/aspnet/core/host-and-deploy/health-checks)
457
- - [Azure DevOps Workload Identity](https://learn.microsoft.com/azure/devops/pipelines/library/connect-to-azure)
458
- - [MORPH-SPEC Azure DevOps Setup](.azure/docs/azure-devops-setup.md)
459
-
460
- ---
461
-
462
- ## 🆘 Troubleshooting
463
-
464
- ### Container não inicia
465
-
466
- ```bash
467
- # Ver logs do container
468
- az containerapp logs show \
469
- -n ca-myapp-dev \
470
- -g rg-myapp-dev \
471
- --follow
472
-
473
- # Ver eventos do container
474
- az containerapp revision list \
475
- -n ca-myapp-dev \
476
- -g rg-myapp-dev \
477
- --query '[0].properties.provisioningState'
478
- ```
479
-
480
- ### Erro de autenticação ACR
481
-
482
- ```bash
483
- # Verificar permissões Managed Identity
484
- az role assignment list \
485
- --assignee $CA_PRINCIPAL_ID \
486
- --scope $(az acr show -n $ACR_NAME --query id -o tsv)
487
-
488
- # Recriar permissão se necessário
489
- az role assignment create \
490
- --assignee $CA_PRINCIPAL_ID \
491
- --role AcrPull \
492
- --scope $(az acr show -n $ACR_NAME --query id -o tsv)
493
- ```
494
-
495
- ### App lento ou timeout
496
-
497
- ```bash
498
- # Verificar recursos
499
- az containerapp show \
500
- -n ca-myapp-dev \
501
- -g rg-myapp-dev \
502
- --query 'properties.template.containers[0].resources'
503
-
504
- # Aumentar CPU/memória se necessário
505
- az containerapp update \
506
- -n ca-myapp-dev \
507
- -g rg-myapp-dev \
508
- --cpu 0.5 \
509
- --memory 1Gi
510
- ```
511
-
512
- ---
513
-
514
- *MORPH-SPEC by Polymorphism Tech*