@polymorphism-tech/morph-spec 3.2.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 (319) hide show
  1. package/CLAUDE.md +352 -7
  2. package/README.md +1 -14
  3. package/bin/detect-agents.js +1 -1
  4. package/bin/morph-spec.js +122 -34
  5. package/bin/validate.js +1 -1
  6. package/docs/getting-started.md +0 -5
  7. package/docs/v3.0/AGENTS.md +521 -0
  8. package/docs/v3.0/ANALYSIS.md +555 -0
  9. package/docs/v3.0/ARCHITECTURE.md +436 -0
  10. package/docs/v3.0/EXECUTION-FLOW.md +1304 -0
  11. package/docs/v3.0/FEATURES.md +688 -0
  12. package/docs/v3.0/README.md +231 -0
  13. package/docs/v3.0/ROADMAP.md +801 -0
  14. package/docs/validation-checklist.md +0 -1
  15. package/package.json +1 -1
  16. package/src/commands/agents/index.js +4 -0
  17. package/src/commands/{spawn-team.js → agents/spawn-team.js} +172 -172
  18. package/src/commands/{create-story.js → feature/create-story.js} +357 -354
  19. package/src/commands/feature/index.js +6 -0
  20. package/src/commands/{shard-spec.js → feature/shard-spec.js} +2 -2
  21. package/src/commands/{sprint-status.js → feature/sprint-status.js} +1 -1
  22. package/src/commands/{generate-context.js → generation/generate-context.js} +40 -40
  23. package/src/commands/{generate.js → generation/generate.js} +4 -4
  24. package/src/commands/generation/index.js +5 -0
  25. package/src/commands/index.js +16 -0
  26. package/src/commands/{capture-pattern.js → learning/capture-pattern.js} +121 -121
  27. package/src/commands/learning/index.js +5 -0
  28. package/src/commands/{detect-agents.js → project/detect-agents.js} +178 -178
  29. package/src/commands/project/detect-workflow.js +174 -0
  30. package/src/commands/{detect.js → project/detect.js} +104 -104
  31. package/src/commands/{doctor.js → project/doctor.js} +356 -356
  32. package/src/commands/project/index.js +10 -0
  33. package/src/commands/{init.js → project/init.js} +305 -295
  34. package/src/commands/{sync.js → project/sync.js} +167 -167
  35. package/src/commands/{update.js → project/update.js} +240 -240
  36. package/src/commands/{advance-phase.js → state/advance-phase.js} +416 -357
  37. package/src/commands/{approve.js → state/approve.js} +221 -221
  38. package/src/commands/state/index.js +8 -0
  39. package/src/commands/{rollback-phase.js → state/rollback-phase.js} +185 -185
  40. package/src/commands/{state.js → state/state.js} +334 -334
  41. package/src/commands/{validate-phase.js → state/validate-phase.js} +221 -221
  42. package/src/commands/tasks/index.js +4 -0
  43. package/src/commands/{task.js → tasks/task.js} +78 -78
  44. package/src/commands/templates/index.js +8 -0
  45. package/src/commands/templates/template-customize.js +101 -0
  46. package/src/commands/templates/template-list.js +128 -0
  47. package/src/commands/templates/template-render.js +95 -0
  48. package/src/commands/templates/template-show.js +131 -0
  49. package/src/commands/templates/template-validate.js +91 -0
  50. package/src/commands/utils/index.js +7 -0
  51. package/src/commands/{session-summary.js → utils/session-summary.js} +291 -291
  52. package/src/commands/{troubleshoot.js → utils/troubleshoot.js} +222 -222
  53. package/src/commands/{analyze-blazor-concurrency.js → validation/analyze-blazor-concurrency.js} +193 -193
  54. package/src/commands/validation/index.js +8 -0
  55. package/src/commands/{lint-fluent.js → validation/lint-fluent.js} +352 -352
  56. package/src/commands/{validate-blazor-state.js → validation/validate-blazor-state.js} +210 -210
  57. package/src/commands/{validate-blazor.js → validation/validate-blazor.js} +156 -156
  58. package/src/commands/{validate-css.js → validation/validate-css.js} +84 -84
  59. package/src/core/index.js +10 -0
  60. package/src/core/registry/command-registry.js +302 -0
  61. package/src/core/registry/index.js +8 -0
  62. package/src/core/registry/validator-registry.js +204 -0
  63. package/src/core/state/index.js +8 -0
  64. package/src/{lib → core/state}/phase-state-machine.js +214 -214
  65. package/src/{lib → core/state}/state-manager.js +572 -534
  66. package/src/core/templates/index.js +9 -0
  67. package/src/core/templates/template-registry.js +335 -0
  68. package/src/core/templates/template-renderer.js +477 -0
  69. package/src/core/templates/template-validator.js +296 -0
  70. package/src/core/workflows/index.js +7 -0
  71. package/src/core/workflows/workflow-detector.js +354 -0
  72. package/src/lib/{complexity-analyzer.js → analysis/complexity-analyzer.js} +441 -441
  73. package/src/lib/analysis/index.js +7 -0
  74. package/src/lib/{checkpoint-hooks.js → checkpoints/checkpoint-hooks.js} +258 -258
  75. package/src/lib/checkpoints/index.js +7 -0
  76. package/src/lib/detectors/config-detector.js +223 -223
  77. package/src/lib/detectors/conversation-analyzer.js +163 -163
  78. package/src/lib/{design-system-detector.js → detectors/design-system-detector.js} +187 -187
  79. package/src/lib/detectors/index.js +87 -84
  80. package/src/lib/detectors/standards-generator.js +275 -275
  81. package/src/lib/detectors/structure-detector.js +245 -245
  82. package/src/lib/{context-generator.js → generators/context-generator.js} +526 -516
  83. package/src/lib/generators/index.js +10 -0
  84. package/src/lib/{metadata-extractor.js → generators/metadata-extractor.js} +387 -380
  85. package/src/lib/{recap-generator.js → generators/recap-generator.js} +205 -205
  86. package/src/lib/learning/index.js +7 -0
  87. package/src/lib/orchestration/index.js +7 -0
  88. package/src/lib/{team-orchestrator.js → orchestration/team-orchestrator.js} +323 -323
  89. package/src/lib/stacks/index.js +7 -0
  90. package/src/lib/{stack-resolver.js → stacks/stack-resolver.js} +180 -148
  91. package/src/lib/standards/index.js +7 -0
  92. package/src/lib/{standards-context-injector.js → standards/standards-context-injector.js} +298 -288
  93. package/src/lib/troubleshooting/index.js +8 -0
  94. package/src/lib/{troubleshoot-grep.js → troubleshooting/troubleshoot-grep.js} +204 -204
  95. package/src/lib/{troubleshoot-index.js → troubleshooting/troubleshoot-index.js} +144 -144
  96. package/src/lib/validators/architecture/architecture-validator.js +387 -0
  97. package/src/lib/validators/architecture/index.js +7 -0
  98. package/src/lib/validators/architecture-validator.js +40 -367
  99. package/src/lib/{blazor-concurrency-analyzer.js → validators/blazor/blazor-concurrency-analyzer.js} +277 -288
  100. package/src/lib/{blazor-state-validator.js → validators/blazor/blazor-state-validator.js} +279 -291
  101. package/src/lib/{blazor-validator.js → validators/blazor/blazor-validator.js} +369 -374
  102. package/src/lib/validators/blazor/index.js +9 -0
  103. package/src/lib/validators/content/content-validator.js +351 -0
  104. package/src/lib/validators/content/index.js +7 -0
  105. package/src/lib/validators/content-validator.js +164 -351
  106. package/src/lib/validators/{contract-compliance-validator.js → contracts/contract-compliance-validator.js} +273 -273
  107. package/src/lib/validators/contracts/index.js +7 -0
  108. package/src/lib/{css-validator.js → validators/css/css-validator.js} +352 -352
  109. package/src/lib/validators/css/index.js +7 -0
  110. package/src/lib/validators/{design-system-validator.js → design-system/design-system-validator.js} +231 -231
  111. package/src/lib/validators/design-system/index.js +7 -0
  112. package/src/lib/validators/package-validator.js +41 -340
  113. package/src/lib/validators/packages/index.js +7 -0
  114. package/src/lib/validators/packages/package-validator.js +360 -0
  115. package/src/lib/validators/shared/index.js +12 -0
  116. package/src/lib/validators/shared/issue-counter.js +18 -0
  117. package/src/lib/validators/shared/result-formatter.js +124 -0
  118. package/src/lib/{spec-validator.js → validators/spec-validator.js} +258 -258
  119. package/src/lib/validators/ui/index.js +7 -0
  120. package/src/lib/validators/ui/ui-contrast-validator.js +422 -0
  121. package/src/lib/validators/ui-contrast-validator.js +31 -409
  122. package/src/lib/{validation-runner.js → validators/validation-runner.js} +286 -284
  123. package/src/ui/wizard-questions.js +0 -2
  124. package/src/utils/color-utils.js +70 -0
  125. package/src/utils/file-copier.js +188 -189
  126. package/src/utils/process-handler.js +97 -0
  127. package/stacks/blazor-azure/.claude/skills/level-2-domains/ai-agents/ai-system-architect.md +3 -3
  128. package/stacks/blazor-azure/.claude/skills/level-2-domains/backend/api-designer.md +59 -0
  129. package/stacks/blazor-azure/.claude/skills/level-2-domains/backend/dotnet-senior.md +45 -255
  130. package/stacks/blazor-azure/.claude/skills/level-2-domains/backend/ef-modeler.md +33 -88
  131. package/stacks/blazor-azure/.claude/skills/level-2-domains/backend/ms-agent-expert.md +25 -89
  132. package/stacks/blazor-azure/.claude/skills/level-2-domains/integrations/hangfire-orchestrator.md +64 -0
  133. package/stacks/blazor-azure/.morph/config/agents.json +879 -764
  134. package/stacks/blazor-azure/.morph/hooks/{pre-commit-tests.sh → pre-commit/tests-csharp.sh} +3 -2
  135. package/stacks/blazor-azure/.morph/templates/infrastructure/github/workflows/cd-prod.yml.hbs +41 -0
  136. package/stacks/blazor-azure/.morph/templates/infrastructure/github/workflows/cd-staging.yml.hbs +24 -0
  137. package/stacks/blazor-azure/.morph/templates/infrastructure/github/workflows/ci-build.yml.hbs +23 -0
  138. package/stacks/nextjs-supabase/.claude/commands/morph-apply.md +221 -0
  139. package/stacks/nextjs-supabase/.claude/commands/morph-archive.md +79 -0
  140. package/stacks/nextjs-supabase/.claude/commands/morph-deploy.md +529 -0
  141. package/stacks/nextjs-supabase/.claude/commands/morph-infra.md +209 -0
  142. package/stacks/nextjs-supabase/.claude/commands/morph-preflight.md +227 -0
  143. package/stacks/nextjs-supabase/.claude/commands/morph-proposal.md +122 -0
  144. package/stacks/nextjs-supabase/.claude/commands/morph-status.md +86 -0
  145. package/stacks/nextjs-supabase/.claude/commands/morph-troubleshoot.md +122 -0
  146. package/stacks/nextjs-supabase/.claude/settings.local.json +6 -0
  147. package/stacks/nextjs-supabase/.claude/skills/level-2-domains/integrations/supabase-expert.md +30 -150
  148. package/stacks/nextjs-supabase/.morph/config/agents.json +345 -345
  149. package/stacks/nextjs-supabase/.morph/hooks/pre-commit/tests-typescript.sh +61 -0
  150. package/stacks/nextjs-supabase/.morph/templates/infrastructure/github/workflows/cd-prod.yml.hbs +22 -0
  151. package/stacks/nextjs-supabase/.morph/templates/infrastructure/github/workflows/cd-staging.yml.hbs +22 -0
  152. package/stacks/nextjs-supabase/.morph/templates/infrastructure/github/workflows/ci-build.yml.hbs +35 -0
  153. package/stacks/nextjs-supabase/README.md +6 -15
  154. package/bin/render-template.js +0 -349
  155. package/bin/semantic-detect-agents.js +0 -247
  156. package/bin/validate-agents-skills.js +0 -257
  157. package/bin/validate-agents.js +0 -70
  158. package/bin/validate-phase.js +0 -263
  159. package/docs/examples.md +0 -328
  160. package/scripts/reorganize-skills.cjs +0 -175
  161. package/scripts/validate-agents-structure.cjs +0 -52
  162. package/scripts/validate-skills.cjs +0 -180
  163. package/src/commands/deploy.js +0 -780
  164. package/src/lib/continuous-validator.js +0 -421
  165. package/src/lib/decision-constraint-loader.js +0 -109
  166. package/src/lib/design-system-scaffolder.js +0 -299
  167. package/src/lib/hook-executor.js +0 -257
  168. package/src/lib/mockup-generator.js +0 -366
  169. package/src/lib/ui-detector.js +0 -350
  170. package/src/llm/schema-validator.js +0 -121
  171. package/src/sanitizer/.gitkeep +0 -0
  172. package/src/scanner/.gitkeep +0 -0
  173. package/src/types/index.js +0 -477
  174. package/src/ui/.gitkeep +0 -0
  175. package/src/writer/.gitkeep +0 -0
  176. package/stacks/blazor-azure/.azure/README.md +0 -293
  177. package/stacks/blazor-azure/.azure/docs/azure-devops-setup.md +0 -454
  178. package/stacks/blazor-azure/.azure/docs/branch-strategy.md +0 -398
  179. package/stacks/blazor-azure/.azure/docs/local-development.md +0 -515
  180. package/stacks/blazor-azure/.azure/pipelines/pipeline-variables.yml +0 -34
  181. package/stacks/blazor-azure/.azure/pipelines/prod-pipeline.yml +0 -319
  182. package/stacks/blazor-azure/.azure/pipelines/staging-pipeline.yml +0 -234
  183. package/stacks/blazor-azure/.azure/pipelines/templates/build-dotnet.yml +0 -75
  184. package/stacks/blazor-azure/.azure/pipelines/templates/deploy-app-service.yml +0 -94
  185. package/stacks/blazor-azure/.azure/pipelines/templates/deploy-container-app.yml +0 -120
  186. package/stacks/blazor-azure/.azure/pipelines/templates/infra-deploy.yml +0 -90
  187. package/stacks/blazor-azure/.claude/settings.local.json +0 -15
  188. package/stacks/blazor-azure/.morph/docs/STORY-DRIVEN-DEVELOPMENT.md +0 -392
  189. package/stacks/blazor-azure/.morph/docs/workflows/design-impl.md +0 -37
  190. package/stacks/blazor-azure/.morph/docs/workflows/enforcement-pipeline.md +0 -668
  191. package/stacks/blazor-azure/.morph/docs/workflows/fast-track.md +0 -29
  192. package/stacks/blazor-azure/.morph/docs/workflows/full-morph.md +0 -76
  193. package/stacks/blazor-azure/.morph/docs/workflows/standard.md +0 -44
  194. package/stacks/blazor-azure/.morph/docs/workflows/ui-refresh.md +0 -39
  195. package/stacks/blazor-azure/.morph/examples/api-nextjs/README.md +0 -241
  196. package/stacks/blazor-azure/.morph/examples/api-nextjs/contracts.ts +0 -307
  197. package/stacks/blazor-azure/.morph/examples/api-nextjs/spec.md +0 -399
  198. package/stacks/blazor-azure/.morph/examples/api-nextjs/tasks.md +0 -168
  199. package/stacks/blazor-azure/.morph/examples/micro-saas/README.md +0 -125
  200. package/stacks/blazor-azure/.morph/examples/micro-saas/contracts.cs +0 -358
  201. package/stacks/blazor-azure/.morph/examples/micro-saas/decisions.md +0 -246
  202. package/stacks/blazor-azure/.morph/examples/micro-saas/spec.md +0 -236
  203. package/stacks/blazor-azure/.morph/examples/micro-saas/tasks.md +0 -150
  204. package/stacks/blazor-azure/.morph/examples/multi-agent/README.md +0 -309
  205. package/stacks/blazor-azure/.morph/examples/multi-agent/contracts.cs +0 -433
  206. package/stacks/blazor-azure/.morph/examples/multi-agent/spec.md +0 -479
  207. package/stacks/blazor-azure/.morph/examples/multi-agent/tasks.md +0 -185
  208. package/stacks/blazor-azure/.morph/examples/scheduled-reports/decisions.md +0 -158
  209. package/stacks/blazor-azure/.morph/examples/scheduled-reports/proposal.md +0 -95
  210. package/stacks/blazor-azure/.morph/examples/scheduled-reports/spec.md +0 -267
  211. package/stacks/blazor-azure/.morph/examples/state-v3.json +0 -188
  212. package/stacks/blazor-azure/.morph/hooks/README.md +0 -348
  213. package/stacks/blazor-azure/.morph/hooks/pre-commit-agents.sh +0 -24
  214. package/stacks/blazor-azure/.morph/hooks/pre-commit-all.sh +0 -48
  215. package/stacks/blazor-azure/.morph/hooks/pre-commit-specs.sh +0 -49
  216. package/stacks/blazor-azure/.morph/hooks/task-completed.js +0 -73
  217. package/stacks/blazor-azure/.morph/hooks/teammate-idle.js +0 -68
  218. package/stacks/blazor-azure/.morph/standards/agent-framework-blazor-ui.md +0 -359
  219. package/stacks/blazor-azure/.morph/standards/agent-framework-production.md +0 -410
  220. package/stacks/blazor-azure/.morph/standards/agent-framework-setup.md +0 -413
  221. package/stacks/blazor-azure/.morph/standards/agent-framework-workflows.md +0 -349
  222. package/stacks/blazor-azure/.morph/standards/agent-teams-workflow.md +0 -474
  223. package/stacks/blazor-azure/.morph/standards/architecture.md +0 -325
  224. package/stacks/blazor-azure/.morph/standards/azure.md +0 -605
  225. package/stacks/blazor-azure/.morph/standards/coding.md +0 -377
  226. package/stacks/blazor-azure/.morph/standards/dotnet10-migration.md +0 -520
  227. package/stacks/blazor-azure/.morph/standards/fluent-ui-setup.md +0 -590
  228. package/stacks/blazor-azure/.morph/standards/migration-guide.md +0 -514
  229. package/stacks/blazor-azure/.morph/standards/passkeys-auth.md +0 -423
  230. package/stacks/blazor-azure/.morph/standards/vector-search-rag.md +0 -536
  231. package/stacks/blazor-azure/.morph/templates/CONTEXT-FEATURE.md +0 -276
  232. package/stacks/blazor-azure/.morph/templates/CONTEXT.md +0 -170
  233. package/stacks/blazor-azure/.morph/templates/FluentDesignTheme.cs +0 -149
  234. package/stacks/blazor-azure/.morph/templates/MudTheme.cs +0 -281
  235. package/stacks/blazor-azure/.morph/templates/agent.cs +0 -163
  236. package/stacks/blazor-azure/.morph/templates/clarify-questions.md +0 -159
  237. package/stacks/blazor-azure/.morph/templates/component.razor +0 -239
  238. package/stacks/blazor-azure/.morph/templates/contracts/Commands.cs +0 -74
  239. package/stacks/blazor-azure/.morph/templates/contracts/Entities.cs +0 -25
  240. package/stacks/blazor-azure/.morph/templates/contracts/Queries.cs +0 -74
  241. package/stacks/blazor-azure/.morph/templates/contracts/README.md +0 -74
  242. package/stacks/blazor-azure/.morph/templates/contracts.cs +0 -217
  243. package/stacks/blazor-azure/.morph/templates/decisions.md +0 -123
  244. package/stacks/blazor-azure/.morph/templates/design-system.css +0 -226
  245. package/stacks/blazor-azure/.morph/templates/infra/.dockerignore.example +0 -89
  246. package/stacks/blazor-azure/.morph/templates/infra/Dockerfile.example +0 -82
  247. package/stacks/blazor-azure/.morph/templates/infra/README.md +0 -286
  248. package/stacks/blazor-azure/.morph/templates/infra/app-insights.bicep +0 -63
  249. package/stacks/blazor-azure/.morph/templates/infra/app-service.bicep +0 -164
  250. package/stacks/blazor-azure/.morph/templates/infra/azure-pipelines-deploy.yml +0 -480
  251. package/stacks/blazor-azure/.morph/templates/infra/container-app-env.bicep +0 -49
  252. package/stacks/blazor-azure/.morph/templates/infra/container-app.bicep +0 -156
  253. package/stacks/blazor-azure/.morph/templates/infra/deploy-checklist.md +0 -426
  254. package/stacks/blazor-azure/.morph/templates/infra/deploy.ps1 +0 -229
  255. package/stacks/blazor-azure/.morph/templates/infra/deploy.sh +0 -208
  256. package/stacks/blazor-azure/.morph/templates/infra/key-vault.bicep +0 -91
  257. package/stacks/blazor-azure/.morph/templates/infra/main.bicep +0 -189
  258. package/stacks/blazor-azure/.morph/templates/infra/parameters.dev.json +0 -29
  259. package/stacks/blazor-azure/.morph/templates/infra/parameters.prod.json +0 -29
  260. package/stacks/blazor-azure/.morph/templates/infra/parameters.staging.json +0 -29
  261. package/stacks/blazor-azure/.morph/templates/infra/sql-database.bicep +0 -103
  262. package/stacks/blazor-azure/.morph/templates/infra/storage.bicep +0 -106
  263. package/stacks/blazor-azure/.morph/templates/integrations/asaas-client.cs +0 -387
  264. package/stacks/blazor-azure/.morph/templates/integrations/asaas-webhook.cs +0 -351
  265. package/stacks/blazor-azure/.morph/templates/integrations/azure-identity-config.cs +0 -288
  266. package/stacks/blazor-azure/.morph/templates/integrations/clerk-config.cs +0 -258
  267. package/stacks/blazor-azure/.morph/templates/job.cs +0 -171
  268. package/stacks/blazor-azure/.morph/templates/migration.cs +0 -83
  269. package/stacks/blazor-azure/.morph/templates/proposal.md +0 -141
  270. package/stacks/blazor-azure/.morph/templates/recap.md +0 -94
  271. package/stacks/blazor-azure/.morph/templates/repository.cs +0 -141
  272. package/stacks/blazor-azure/.morph/templates/saas/subscription.cs +0 -347
  273. package/stacks/blazor-azure/.morph/templates/saas/tenant.cs +0 -338
  274. package/stacks/blazor-azure/.morph/templates/service.cs +0 -139
  275. package/stacks/blazor-azure/.morph/templates/simulation.md +0 -353
  276. package/stacks/blazor-azure/.morph/templates/spec.md +0 -149
  277. package/stacks/blazor-azure/.morph/templates/sprint-status.yaml +0 -68
  278. package/stacks/blazor-azure/.morph/templates/state.template.json +0 -222
  279. package/stacks/blazor-azure/.morph/templates/story.md +0 -143
  280. package/stacks/blazor-azure/.morph/templates/tasks.md +0 -257
  281. package/stacks/blazor-azure/.morph/templates/test.cs +0 -239
  282. package/stacks/blazor-azure/.morph/templates/ui-components.md +0 -362
  283. package/stacks/blazor-azure/.morph/templates/ui-design-system.md +0 -286
  284. package/stacks/blazor-azure/.morph/templates/ui-flows.md +0 -336
  285. package/stacks/blazor-azure/.morph/templates/ui-mockups.md +0 -133
  286. package/stacks/nextjs-supabase/.morph/docs/easypanel-setup.md +0 -169
  287. package/stacks/nextjs-supabase/.morph/docs/supabase-mcp-setup.md +0 -247
  288. package/stacks/nextjs-supabase/.morph/examples/crud-nextjs-supabase/README.md +0 -697
  289. package/stacks/nextjs-supabase/.morph/examples/crud-nextjs-supabase/spec.md +0 -85
  290. package/stacks/nextjs-supabase/.morph/examples/crud-nextjs-supabase/tasks.md +0 -86
  291. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/README.md +0 -498
  292. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/decisions.md +0 -121
  293. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/spec.md +0 -138
  294. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/tasks.md +0 -162
  295. package/stacks/nextjs-supabase/.morph/standards/easypanel-deploy.md +0 -191
  296. package/stacks/nextjs-supabase/.morph/standards/nextjs-patterns.md +0 -193
  297. package/stacks/nextjs-supabase/.morph/standards/supabase-auth.md +0 -171
  298. package/stacks/nextjs-supabase/.morph/standards/supabase-pgvector.md +0 -164
  299. package/stacks/nextjs-supabase/.morph/standards/supabase-rls.md +0 -179
  300. package/stacks/nextjs-supabase/.morph/standards/supabase-storage.md +0 -148
  301. package/stacks/nextjs-supabase/.morph/templates/contracts.cs +0 -173
  302. package/stacks/nextjs-supabase/.morph/templates/contracts.ts +0 -168
  303. package/stacks/nextjs-supabase/.morph/templates/decisions.md +0 -115
  304. package/stacks/nextjs-supabase/.morph/templates/dockerfile-api.dockerfile +0 -38
  305. package/stacks/nextjs-supabase/.morph/templates/dockerfile-web.dockerfile +0 -48
  306. package/stacks/nextjs-supabase/.morph/templates/proposal.md +0 -145
  307. package/stacks/nextjs-supabase/.morph/templates/recap.md +0 -134
  308. package/stacks/nextjs-supabase/.morph/templates/rls-policy.sql +0 -57
  309. package/stacks/nextjs-supabase/.morph/templates/spec.md +0 -231
  310. package/stacks/nextjs-supabase/.morph/templates/supabase-migration.sql +0 -100
  311. package/stacks/nextjs-supabase/.morph/templates/tasks.md +0 -257
  312. /package/src/commands/{search-patterns.js → learning/search-patterns.js} +0 -0
  313. /package/src/commands/{migrate-state.js → utils/migrate-state.js} +0 -0
  314. /package/src/commands/{upgrade.js → utils/upgrade.js} +0 -0
  315. /package/src/{lib → core/templates}/template-data-sources.js +0 -0
  316. /package/src/lib/{design-system-generator.js → generators/design-system-generator.js} +0 -0
  317. /package/src/lib/{learning-system.js → learning/learning-system.js} +0 -0
  318. /package/{src/generator → stacks/blazor-azure/.morph/templates}/.gitkeep +0 -0
  319. /package/{src/llm → stacks/nextjs-supabase/.morph/templates}/.gitkeep +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*