@polymorphism-tech/morph-spec 4.3.1 → 4.3.3

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 (194) hide show
  1. package/bin/morph-spec.js +1 -1
  2. package/package.json +2 -1
  3. package/src/commands/project/doctor.js +24 -18
  4. package/src/commands/project/init.js +15 -5
  5. package/src/commands/project/update.js +7 -3
  6. package/src/commands/state/state.js +24 -2
  7. package/src/core/templates/template-registry.js +1 -1
  8. package/src/core/workflows/workflow-detector.js +2 -2
  9. package/stacks/blazor-azure/.claude/commands/morph-apply.md +221 -0
  10. package/stacks/blazor-azure/.claude/commands/morph-archive.md +79 -0
  11. package/stacks/blazor-azure/.claude/commands/morph-deploy.md +529 -0
  12. package/stacks/blazor-azure/.claude/commands/morph-infra.md +209 -0
  13. package/stacks/blazor-azure/.claude/commands/morph-preflight.md +227 -0
  14. package/stacks/blazor-azure/.claude/commands/morph-proposal.md +122 -0
  15. package/stacks/blazor-azure/.claude/commands/morph-status.md +86 -0
  16. package/stacks/blazor-azure/.claude/commands/morph-troubleshoot.md +122 -0
  17. package/stacks/blazor-azure/.morph/.morphversion +5 -5
  18. package/stacks/blazor-azure/.morph/config/config.json +9 -0
  19. package/stacks/blazor-azure/.morph/project/context/README.md +17 -0
  20. package/stacks/blazor-azure/.morph/standards/ai-agents/blazor-ui.md +364 -0
  21. package/stacks/blazor-azure/.morph/standards/ai-agents/production.md +415 -0
  22. package/stacks/blazor-azure/.morph/standards/ai-agents/setup.md +418 -0
  23. package/stacks/blazor-azure/.morph/standards/ai-agents/team-orchestration.md +479 -0
  24. package/stacks/blazor-azure/.morph/standards/ai-agents/workflows.md +354 -0
  25. package/stacks/blazor-azure/.morph/standards/architecture/ddd/aggregates.md +120 -0
  26. package/stacks/blazor-azure/.morph/standards/architecture/ddd/entities.md +99 -0
  27. package/stacks/blazor-azure/.morph/standards/architecture/ddd/value-objects.md +124 -0
  28. package/stacks/blazor-azure/.morph/standards/backend/api/minimal-api.md +494 -0
  29. package/stacks/blazor-azure/.morph/standards/backend/api/rest.md +492 -0
  30. package/stacks/blazor-azure/.morph/standards/backend/api/validation.md +88 -0
  31. package/stacks/blazor-azure/.morph/standards/backend/authentication/passkeys.md +428 -0
  32. package/stacks/blazor-azure/.morph/standards/backend/database/ef-core.md +199 -0
  33. package/stacks/blazor-azure/.morph/standards/backend/database/migrations.md +393 -0
  34. package/stacks/blazor-azure/.morph/standards/backend/database/postgresql/database.md +352 -0
  35. package/stacks/blazor-azure/.morph/standards/backend/database/repository-patterns.md +528 -0
  36. package/stacks/blazor-azure/.morph/standards/backend/database/vector-search-rag.md +541 -0
  37. package/stacks/blazor-azure/.morph/standards/backend/dotnet/async.md +366 -0
  38. package/stacks/blazor-azure/.morph/standards/backend/dotnet/core.md +117 -0
  39. package/stacks/blazor-azure/.morph/standards/backend/dotnet/di.md +439 -0
  40. package/stacks/blazor-azure/.morph/standards/backend/dotnet/program-cs-checklist.md +92 -0
  41. package/stacks/blazor-azure/.morph/standards/backend/integrations/asaas/asaas-api.md +216 -0
  42. package/stacks/blazor-azure/.morph/standards/backend/integrations/clerk/clerk-auth.md +290 -0
  43. package/stacks/blazor-azure/.morph/standards/backend/integrations/hangfire/hangfire-jobs.md +350 -0
  44. package/stacks/blazor-azure/.morph/standards/backend/integrations/resend/resend-email.md +385 -0
  45. package/stacks/blazor-azure/.morph/standards/context/analytics.md +96 -0
  46. package/stacks/blazor-azure/.morph/standards/context/bundles.md +110 -0
  47. package/stacks/blazor-azure/.morph/standards/context/priming.md +78 -0
  48. package/stacks/blazor-azure/.morph/standards/core/architecture.md +185 -0
  49. package/stacks/blazor-azure/.morph/standards/core/coding.md +214 -0
  50. package/stacks/blazor-azure/.morph/standards/core/git-branching-strategy.md +403 -0
  51. package/stacks/blazor-azure/.morph/standards/core/git.md +185 -0
  52. package/stacks/blazor-azure/.morph/standards/core/testing.md +295 -0
  53. package/stacks/blazor-azure/.morph/standards/data/nosql/blob-storage.md +102 -0
  54. package/stacks/blazor-azure/.morph/standards/data/nosql/cache/redis.md +97 -0
  55. package/stacks/blazor-azure/.morph/standards/data/nosql/cosmos-db.md +118 -0
  56. package/stacks/blazor-azure/.morph/standards/data/vector-search/azure-ai-search.md +121 -0
  57. package/stacks/blazor-azure/.morph/standards/data/vector-search/rag-chunking.md +104 -0
  58. package/stacks/blazor-azure/.morph/standards/frontend/blazor/design-checklist.md +222 -0
  59. package/stacks/blazor-azure/.morph/standards/frontend/blazor/fluent-ui-setup.md +595 -0
  60. package/stacks/blazor-azure/.morph/standards/frontend/blazor/fluent-ui.md +137 -0
  61. package/stacks/blazor-azure/.morph/standards/frontend/blazor/html-conversion.md +184 -0
  62. package/stacks/blazor-azure/.morph/standards/frontend/blazor/lifecycle.md +195 -0
  63. package/stacks/blazor-azure/.morph/standards/frontend/blazor/pitfalls.md +198 -0
  64. package/stacks/blazor-azure/.morph/standards/frontend/blazor/state.md +191 -0
  65. package/stacks/blazor-azure/.morph/standards/frontend/design-system/animations.md +151 -0
  66. package/stacks/blazor-azure/.morph/standards/frontend/design-system/naming.md +64 -0
  67. package/stacks/blazor-azure/.morph/standards/frontend/nextjs/nextjs-patterns.md +198 -0
  68. package/stacks/blazor-azure/.morph/standards/infrastructure/azure/azure.md +624 -0
  69. package/stacks/blazor-azure/.morph/standards/infrastructure/azure/bicep/bicep-patterns.md +422 -0
  70. package/stacks/blazor-azure/.morph/standards/infrastructure/azure/devops/azure-devops-setup.md +516 -0
  71. package/stacks/blazor-azure/.morph/standards/infrastructure/azure/devops/local-development.md +520 -0
  72. package/stacks/blazor-azure/.morph/standards/infrastructure/azure/services/functions.md +486 -0
  73. package/stacks/blazor-azure/.morph/standards/infrastructure/azure/services/service-bus.md +459 -0
  74. package/stacks/blazor-azure/.morph/standards/infrastructure/azure/services/storage.md +407 -0
  75. package/stacks/blazor-azure/.morph/standards/infrastructure/docker/easypanel-deploy.md +196 -0
  76. package/stacks/blazor-azure/.morph/standards/infrastructure/supabase/mcp-setup.md +252 -0
  77. package/stacks/blazor-azure/.morph/standards/infrastructure/supabase/supabase-auth.md +176 -0
  78. package/stacks/blazor-azure/.morph/standards/infrastructure/supabase/supabase-pgvector.md +169 -0
  79. package/stacks/blazor-azure/.morph/standards/infrastructure/supabase/supabase-rls.md +184 -0
  80. package/stacks/blazor-azure/.morph/standards/infrastructure/supabase/supabase-storage.md +153 -0
  81. package/stacks/blazor-azure/.morph/standards/integration/api/graphql.md +91 -0
  82. package/stacks/blazor-azure/.morph/standards/integration/api/grpc.md +114 -0
  83. package/stacks/blazor-azure/.morph/standards/integration/api/rest-design.md +95 -0
  84. package/stacks/blazor-azure/.morph/standards/integration/event-driven/cqrs.md +101 -0
  85. package/stacks/blazor-azure/.morph/standards/integration/event-driven/event-sourcing.md +124 -0
  86. package/stacks/blazor-azure/.morph/standards/integration/event-driven/service-bus.md +95 -0
  87. package/stacks/blazor-azure/.morph/standards/observability/logging.md +131 -0
  88. package/stacks/blazor-azure/.morph/standards/observability/metrics.md +121 -0
  89. package/stacks/blazor-azure/.morph/standards/observability/monitoring.md +114 -0
  90. package/stacks/blazor-azure/.morph/standards/observability/tracing.md +132 -0
  91. package/stacks/blazor-azure/.morph/standards/workflows/parallel-execution.md +112 -0
  92. package/stacks/blazor-azure/.morph/standards/workflows/thread-management.md +113 -0
  93. package/stacks/blazor-azure/CLAUDE.md +106 -101
  94. package/stacks/nextjs-supabase/.claude/commands/morph-apply.md +221 -0
  95. package/stacks/nextjs-supabase/.claude/commands/morph-archive.md +79 -0
  96. package/stacks/nextjs-supabase/.claude/commands/morph-deploy.md +529 -0
  97. package/stacks/nextjs-supabase/.claude/commands/morph-infra.md +209 -0
  98. package/stacks/nextjs-supabase/.claude/commands/morph-preflight.md +227 -0
  99. package/stacks/nextjs-supabase/.claude/commands/morph-proposal.md +122 -0
  100. package/stacks/nextjs-supabase/.claude/commands/morph-status.md +86 -0
  101. package/stacks/nextjs-supabase/.claude/commands/morph-troubleshoot.md +122 -0
  102. package/stacks/nextjs-supabase/.morph/.morphversion +5 -0
  103. package/stacks/nextjs-supabase/.morph/config/agents.json +345 -345
  104. package/stacks/nextjs-supabase/.morph/config/config.json +9 -0
  105. package/stacks/nextjs-supabase/.morph/project/context/README.md +17 -0
  106. package/stacks/nextjs-supabase/.morph/standards/ai-agents/blazor-ui.md +364 -0
  107. package/stacks/nextjs-supabase/.morph/standards/ai-agents/production.md +415 -0
  108. package/stacks/nextjs-supabase/.morph/standards/ai-agents/setup.md +418 -0
  109. package/stacks/nextjs-supabase/.morph/standards/ai-agents/team-orchestration.md +479 -0
  110. package/stacks/nextjs-supabase/.morph/standards/ai-agents/workflows.md +354 -0
  111. package/stacks/nextjs-supabase/.morph/standards/architecture/ddd/aggregates.md +120 -0
  112. package/stacks/nextjs-supabase/.morph/standards/architecture/ddd/entities.md +99 -0
  113. package/stacks/nextjs-supabase/.morph/standards/architecture/ddd/value-objects.md +124 -0
  114. package/stacks/nextjs-supabase/.morph/standards/backend/api/minimal-api.md +494 -0
  115. package/stacks/nextjs-supabase/.morph/standards/backend/api/rest.md +492 -0
  116. package/stacks/nextjs-supabase/.morph/standards/backend/api/validation.md +88 -0
  117. package/stacks/nextjs-supabase/.morph/standards/backend/authentication/passkeys.md +428 -0
  118. package/stacks/nextjs-supabase/.morph/standards/backend/database/ef-core.md +199 -0
  119. package/stacks/nextjs-supabase/.morph/standards/backend/database/migrations.md +393 -0
  120. package/stacks/nextjs-supabase/.morph/standards/backend/database/postgresql/database.md +352 -0
  121. package/stacks/nextjs-supabase/.morph/standards/backend/database/repository-patterns.md +528 -0
  122. package/stacks/nextjs-supabase/.morph/standards/backend/database/vector-search-rag.md +541 -0
  123. package/stacks/nextjs-supabase/.morph/standards/backend/dotnet/async.md +366 -0
  124. package/stacks/nextjs-supabase/.morph/standards/backend/dotnet/core.md +117 -0
  125. package/stacks/nextjs-supabase/.morph/standards/backend/dotnet/di.md +439 -0
  126. package/stacks/nextjs-supabase/.morph/standards/backend/dotnet/program-cs-checklist.md +92 -0
  127. package/stacks/nextjs-supabase/.morph/standards/backend/integrations/asaas/asaas-api.md +216 -0
  128. package/stacks/nextjs-supabase/.morph/standards/backend/integrations/clerk/clerk-auth.md +290 -0
  129. package/stacks/nextjs-supabase/.morph/standards/backend/integrations/hangfire/hangfire-jobs.md +350 -0
  130. package/stacks/nextjs-supabase/.morph/standards/backend/integrations/resend/resend-email.md +385 -0
  131. package/stacks/nextjs-supabase/.morph/standards/context/analytics.md +96 -0
  132. package/stacks/nextjs-supabase/.morph/standards/context/bundles.md +110 -0
  133. package/stacks/nextjs-supabase/.morph/standards/context/priming.md +78 -0
  134. package/stacks/nextjs-supabase/.morph/standards/core/architecture.md +185 -0
  135. package/stacks/nextjs-supabase/.morph/standards/core/coding.md +214 -0
  136. package/stacks/nextjs-supabase/.morph/standards/core/git-branching-strategy.md +403 -0
  137. package/stacks/nextjs-supabase/.morph/standards/core/git.md +185 -0
  138. package/stacks/nextjs-supabase/.morph/standards/core/testing.md +295 -0
  139. package/stacks/nextjs-supabase/.morph/standards/data/nosql/blob-storage.md +102 -0
  140. package/stacks/nextjs-supabase/.morph/standards/data/nosql/cache/redis.md +97 -0
  141. package/stacks/nextjs-supabase/.morph/standards/data/nosql/cosmos-db.md +118 -0
  142. package/stacks/nextjs-supabase/.morph/standards/data/vector-search/azure-ai-search.md +121 -0
  143. package/stacks/nextjs-supabase/.morph/standards/data/vector-search/rag-chunking.md +104 -0
  144. package/stacks/nextjs-supabase/.morph/standards/frontend/blazor/design-checklist.md +222 -0
  145. package/stacks/nextjs-supabase/.morph/standards/frontend/blazor/fluent-ui-setup.md +595 -0
  146. package/stacks/nextjs-supabase/.morph/standards/frontend/blazor/fluent-ui.md +137 -0
  147. package/stacks/nextjs-supabase/.morph/standards/frontend/blazor/html-conversion.md +184 -0
  148. package/stacks/nextjs-supabase/.morph/standards/frontend/blazor/lifecycle.md +195 -0
  149. package/stacks/nextjs-supabase/.morph/standards/frontend/blazor/pitfalls.md +198 -0
  150. package/stacks/nextjs-supabase/.morph/standards/frontend/blazor/state.md +191 -0
  151. package/stacks/nextjs-supabase/.morph/standards/frontend/design-system/animations.md +151 -0
  152. package/stacks/nextjs-supabase/.morph/standards/frontend/design-system/naming.md +64 -0
  153. package/stacks/nextjs-supabase/.morph/standards/frontend/nextjs/nextjs-patterns.md +198 -0
  154. package/stacks/nextjs-supabase/.morph/standards/infrastructure/azure/azure.md +624 -0
  155. package/stacks/nextjs-supabase/.morph/standards/infrastructure/azure/bicep/bicep-patterns.md +422 -0
  156. package/stacks/nextjs-supabase/.morph/standards/infrastructure/azure/devops/azure-devops-setup.md +516 -0
  157. package/stacks/nextjs-supabase/.morph/standards/infrastructure/azure/devops/local-development.md +520 -0
  158. package/stacks/nextjs-supabase/.morph/standards/infrastructure/azure/services/functions.md +486 -0
  159. package/stacks/nextjs-supabase/.morph/standards/infrastructure/azure/services/service-bus.md +459 -0
  160. package/stacks/nextjs-supabase/.morph/standards/infrastructure/azure/services/storage.md +407 -0
  161. package/stacks/nextjs-supabase/.morph/standards/infrastructure/docker/easypanel-deploy.md +196 -0
  162. package/stacks/nextjs-supabase/.morph/standards/infrastructure/supabase/mcp-setup.md +252 -0
  163. package/stacks/nextjs-supabase/.morph/standards/infrastructure/supabase/supabase-auth.md +176 -0
  164. package/stacks/nextjs-supabase/.morph/standards/infrastructure/supabase/supabase-pgvector.md +169 -0
  165. package/stacks/nextjs-supabase/.morph/standards/infrastructure/supabase/supabase-rls.md +184 -0
  166. package/stacks/nextjs-supabase/.morph/standards/infrastructure/supabase/supabase-storage.md +153 -0
  167. package/stacks/nextjs-supabase/.morph/standards/integration/api/graphql.md +91 -0
  168. package/stacks/nextjs-supabase/.morph/standards/integration/api/grpc.md +114 -0
  169. package/stacks/nextjs-supabase/.morph/standards/integration/api/rest-design.md +95 -0
  170. package/stacks/nextjs-supabase/.morph/standards/integration/event-driven/cqrs.md +101 -0
  171. package/stacks/nextjs-supabase/.morph/standards/integration/event-driven/event-sourcing.md +124 -0
  172. package/stacks/nextjs-supabase/.morph/standards/integration/event-driven/service-bus.md +95 -0
  173. package/stacks/nextjs-supabase/.morph/standards/observability/logging.md +131 -0
  174. package/stacks/nextjs-supabase/.morph/standards/observability/metrics.md +121 -0
  175. package/stacks/nextjs-supabase/.morph/standards/observability/monitoring.md +114 -0
  176. package/stacks/nextjs-supabase/.morph/standards/observability/tracing.md +132 -0
  177. package/stacks/nextjs-supabase/.morph/standards/workflows/parallel-execution.md +112 -0
  178. package/stacks/nextjs-supabase/.morph/standards/workflows/thread-management.md +113 -0
  179. package/stacks/nextjs-supabase/CLAUDE.md +69 -63
  180. package/stacks/blazor-azure/.morph/config/config.template.json +0 -122
  181. package/stacks/blazor-azure/.morph/hooks/pre-commit/tests-csharp.sh +0 -61
  182. package/stacks/blazor-azure/.morph/project.md +0 -160
  183. package/stacks/blazor-azure/.morph/state.json +0 -18
  184. package/stacks/blazor-azure/.morph/templates/.gitkeep +0 -0
  185. package/stacks/blazor-azure/.morph/templates/infrastructure/github/workflows/cd-prod.yml.hbs +0 -41
  186. package/stacks/blazor-azure/.morph/templates/infrastructure/github/workflows/cd-staging.yml.hbs +0 -24
  187. package/stacks/blazor-azure/.morph/templates/infrastructure/github/workflows/ci-build.yml.hbs +0 -23
  188. package/stacks/nextjs-supabase/.morph/config/config.template.json +0 -92
  189. package/stacks/nextjs-supabase/.morph/hooks/pre-commit/tests-typescript.sh +0 -61
  190. package/stacks/nextjs-supabase/.morph/project.md +0 -168
  191. package/stacks/nextjs-supabase/.morph/templates/.gitkeep +0 -0
  192. package/stacks/nextjs-supabase/.morph/templates/infrastructure/github/workflows/cd-prod.yml.hbs +0 -22
  193. package/stacks/nextjs-supabase/.morph/templates/infrastructure/github/workflows/cd-staging.yml.hbs +0 -22
  194. package/stacks/nextjs-supabase/.morph/templates/infrastructure/github/workflows/ci-build.yml.hbs +0 -35
package/bin/morph-spec.js CHANGED
@@ -1,4 +1,4 @@
1
- #!/usr/bin/env node
1
+ #!/usr/bin/env node
2
2
 
3
3
  import { program } from 'commander';
4
4
  import chalk from 'chalk';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@polymorphism-tech/morph-spec",
3
- "version": "4.3.1",
3
+ "version": "4.3.3",
4
4
  "description": "MORPH-SPEC: AI-First development framework with validation pipeline and multi-stack support",
5
5
  "keywords": [
6
6
  "claude-code",
@@ -48,6 +48,7 @@
48
48
  "docs:serve": "npx http-server docs/api -p 8080 -o"
49
49
  },
50
50
  "dependencies": {
51
+ "@polymorphism-tech/morph-spec": "^4.3.1",
51
52
  "ajv": "^8.12.0",
52
53
  "ajv-formats": "^3.0.1",
53
54
  "chalk": "^5.3.0",
@@ -391,24 +391,25 @@ export async function doctorCommand(options = {}) {
391
391
  hasErrors = true;
392
392
  }
393
393
 
394
- // Check standards
394
+ // Check standards (either in project .morph/standards/ or in framework package)
395
395
  const standardsPath = join(morphPath, 'standards');
396
+ const frameworkStdsRoot = join(import.meta.dirname, '..', '..', '..', 'framework', 'standards');
396
397
  if (await pathExists(standardsPath)) {
397
- const codingStd = join(standardsPath, 'coding.md');
398
- const archStd = join(standardsPath, 'architecture.md');
399
- const azureStd = join(standardsPath, 'azure.md');
400
-
401
- const hasAll = await Promise.all([
402
- pathExists(codingStd),
403
- pathExists(archStd),
404
- pathExists(azureStd)
405
- ]).then(results => results.every(Boolean));
406
-
407
- if (hasAll) {
398
+ // Check for core standards in hierarchy (copied by init) or flat layout
399
+ const codingStd = await pathExists(join(standardsPath, 'core', 'coding.md')) ||
400
+ await pathExists(join(standardsPath, 'coding.md'));
401
+ const archStd = await pathExists(join(standardsPath, 'core', 'architecture.md')) ||
402
+ await pathExists(join(standardsPath, 'architecture.md'));
403
+ if (codingStd && archStd) {
408
404
  checks.push({ name: 'standards/', status: 'ok' });
409
405
  } else {
410
- checks.push({ name: 'standards/', status: 'warn', msg: 'some files missing' });
406
+ checks.push({ name: 'standards/', status: 'warn', msg: 'core standards missing — run morph-spec init' });
407
+ hasWarnings = true;
411
408
  }
409
+ } else if (await pathExists(frameworkStdsRoot)) {
410
+ // Framework package has standards (dev/global install mode)
411
+ checks.push({ name: 'standards/', status: 'warn', msg: 'not installed in project (run morph-spec init)' });
412
+ hasWarnings = true;
412
413
  } else {
413
414
  checks.push({ name: 'standards/', status: 'missing' });
414
415
  hasErrors = true;
@@ -487,13 +488,18 @@ export async function doctorCommand(options = {}) {
487
488
  hasWarnings = true;
488
489
  }
489
490
 
490
- // Check key templates exist
491
- const keyTemplates = ['proposal.md', 'spec.md', 'tasks.md', 'decisions.md'];
491
+ // Check key templates exist (in framework package, not project copy)
492
+ const frameworkTemplatesRoot = join(import.meta.dirname, '..', '..', '..', 'framework', 'templates');
493
+ const keyTemplates = [
494
+ { name: 'proposal.md', path: join(frameworkTemplatesRoot, 'docs', 'proposal.md') },
495
+ { name: 'spec.md', path: join(frameworkTemplatesRoot, 'docs', 'spec.md') },
496
+ { name: 'tasks.md', path: join(frameworkTemplatesRoot, 'feature', 'tasks.md') },
497
+ { name: 'decisions.md', path: join(frameworkTemplatesRoot, 'feature', 'decisions.md') }
498
+ ];
492
499
  const missingTemplates = [];
493
500
  for (const template of keyTemplates) {
494
- const templatePath = join(templatesPath, template);
495
- if (!(await pathExists(templatePath))) {
496
- missingTemplates.push(template);
501
+ if (!(await pathExists(template.path))) {
502
+ missingTemplates.push(template.name);
497
503
  }
498
504
  }
499
505
 
@@ -112,8 +112,10 @@ Run \`morph-spec detect\` to analyze your project.
112
112
  const contentDir = getContentDir();
113
113
  const templatesSrc = join(contentDir, '.morph', 'templates');
114
114
  const templatesDest = join(morphPath, 'templates');
115
+ let templatesCopied = false;
115
116
  if (await pathExists(templatesSrc)) {
116
117
  await copyDirectory(templatesSrc, templatesDest);
118
+ templatesCopied = true;
117
119
  }
118
120
 
119
121
  // 6. Copy standards from content (stack-specific)
@@ -126,7 +128,7 @@ Run \`morph-spec detect\` to analyze your project.
126
128
 
127
129
  // 6b. Copy framework standards hierarchy (universal standards)
128
130
  spinner.text = 'Copying framework standards hierarchy...';
129
- const frameworkStandardsSrc = join(import.meta.dirname, '..', '..', 'framework', 'standards');
131
+ const frameworkStandardsSrc = join(import.meta.dirname, '..', '..', '..', 'framework', 'standards');
130
132
  const frameworkStandardsDest = join(morphPath, 'standards');
131
133
  if (await pathExists(frameworkStandardsSrc)) {
132
134
  // Copy entire hierarchy (core/, backend/, frontend/, infrastructure/)
@@ -134,9 +136,9 @@ Run \`morph-spec detect\` to analyze your project.
134
136
  logger.dim(' ✓ Copied framework standards: core/, backend/, frontend/, infrastructure/');
135
137
  }
136
138
 
137
- // 7. Copy agents.json
139
+ // 7. Copy agents.json (sourced from framework root .morph/config/ — canonical single source of truth)
138
140
  spinner.text = 'Copying agents configuration...';
139
- const agentsSrc = join(contentDir, '.morph', 'config', 'agents.json');
141
+ const agentsSrc = join(import.meta.dirname, '..', '..', '..', '.morph', 'config', 'agents.json');
140
142
  const agentsDest = join(configDir, 'agents.json');
141
143
  if (await pathExists(agentsSrc)) {
142
144
  await copyFile(agentsSrc, agentsDest);
@@ -163,6 +165,7 @@ Run \`morph-spec detect\` to analyze your project.
163
165
 
164
166
  let symlinkCount = 0;
165
167
  let copyCount = 0;
168
+ let commandsCopied = false;
166
169
 
167
170
  if (await pathExists(claudeSrc)) {
168
171
  // Copy commands directory (slash commands)
@@ -170,6 +173,9 @@ Run \`morph-spec detect\` to analyze your project.
170
173
  const commandsDest = join(claudeDest, 'commands');
171
174
  if (await pathExists(commandsSrc)) {
172
175
  await copyDirectory(commandsSrc, commandsDest);
176
+ commandsCopied = true;
177
+ } else {
178
+ logger.warn(' ⚠ .claude/commands/ source missing — commands not installed');
173
179
  }
174
180
 
175
181
  // Create directory links for skill categories (or copy if linking fails)
@@ -254,9 +260,13 @@ Run \`morph-spec detect\` to analyze your project.
254
260
  logger.dim(` ✓ CLAUDE.md`);
255
261
  logger.dim(` ✓ .morph/config/ (config.json, agents.json, azure-pricing.json)`);
256
262
  logger.dim(` ✓ .morph/standards/ (coding.md, architecture.md, azure.md, ...)`);
257
- logger.dim(` ✓ .morph/templates/ (Bicep, integrations, saas, ...)`);
263
+ if (templatesCopied) {
264
+ logger.dim(` ✓ .morph/templates/ (Bicep, integrations, saas, ...)`);
265
+ }
258
266
  logger.dim(` ✓ .morph/project/ (context, standards, outputs)`);
259
- logger.dim(` ✓ .claude/commands/ (slash commands)`);
267
+ if (commandsCopied) {
268
+ logger.dim(` ✓ .claude/commands/ (slash commands)`);
269
+ }
260
270
  logger.dim(` ✓ .claude/settings.local.json (agent-teams hooks)`);
261
271
 
262
272
  if (symlinkCount > 0) {
@@ -112,9 +112,9 @@ export async function updateCommand(options) {
112
112
  await copyDirectory(standardsSrc, standardsDest);
113
113
  }
114
114
 
115
- // Update agents.json
115
+ // Update agents.json (sourced from framework root .morph/config/ — canonical single source of truth)
116
116
  updateSpinner.text = 'Updating agents configuration...';
117
- const agentsSrc = join(contentDir, '.morph', 'config', 'agents.json');
117
+ const agentsSrc = join(__dirname, '..', '..', '..', '.morph', 'config', 'agents.json');
118
118
  const agentsDest = join(morphPath, 'config', 'agents.json');
119
119
  if (await pathExists(agentsSrc)) {
120
120
  await copyDirectory(agentsSrc, agentsDest);
@@ -125,12 +125,14 @@ export async function updateCommand(options) {
125
125
  updateSpinner.text = 'Updating Claude commands and skills...';
126
126
  const claudeSrc = join(__dirname, '..', '..', '..', '.claude');
127
127
  const claudeDest = join(targetPath, '.claude');
128
+ let claudeUpdated = false;
128
129
  if (await pathExists(claudeSrc)) {
129
130
  // Copy commands (always copy, these are small)
130
131
  const commandsSrc = join(claudeSrc, 'commands');
131
132
  const commandsDest = join(claudeDest, 'commands');
132
133
  if (await pathExists(commandsSrc)) {
133
134
  await copyDirectory(commandsSrc, commandsDest);
135
+ claudeUpdated = true;
134
136
 
135
137
  // Clean up stale command files moved to skills/workflows/ in v2.4+
136
138
  const staleCommands = [
@@ -143,6 +145,8 @@ export async function updateCommand(options) {
143
145
  await fs.remove(stalePath);
144
146
  }
145
147
  }
148
+ } else {
149
+ logger.warn(' ⚠ .claude/commands/ source missing — commands not updated');
146
150
  }
147
151
 
148
152
  // Update skills using directory links per category
@@ -200,7 +204,7 @@ export async function updateCommand(options) {
200
204
  if (updateTemplates) logger.dim(' ✓ .morph/templates/');
201
205
  if (updateStandards) logger.dim(' ✓ .morph/standards/');
202
206
  logger.dim(' ✓ .morph/config/agents.json');
203
- logger.dim(' ✓ .claude/commands/ and .claude/skills/');
207
+ if (claudeUpdated) logger.dim(' ✓ .claude/commands/ and .claude/skills/');
204
208
  logger.dim(' ✓ .claude/settings.local.json (agent-teams hooks)');
205
209
  logger.dim(' ✓ CLAUDE.md');
206
210
  logger.blank();
@@ -3,6 +3,8 @@
3
3
  * CLI wrapper for state management operations
4
4
  */
5
5
 
6
+ import { join } from 'path';
7
+ import { readFileSync, existsSync } from 'fs';
6
8
  import ora from 'ora';
7
9
  import chalk from 'chalk';
8
10
  import { logger } from '../../utils/logger.js';
@@ -77,10 +79,30 @@ async function initCommand(options) {
77
79
 
78
80
  const spinner = ora('Initializing state.json...').start();
79
81
 
82
+ // Read project name and stack from config.json if not provided via options
83
+ let projectName = options.project;
84
+ let projectType = options.type;
85
+ if (!projectName || !projectType) {
86
+ const configPath = join(process.cwd(), '.morph', 'config', 'config.json');
87
+ if (existsSync(configPath)) {
88
+ try {
89
+ const config = JSON.parse(readFileSync(configPath, 'utf8'));
90
+ projectName = projectName || config.project?.name || 'unknown';
91
+ projectType = projectType || config.project?.stack || 'unknown';
92
+ } catch {
93
+ projectName = projectName || 'unknown';
94
+ projectType = projectType || 'unknown';
95
+ }
96
+ } else {
97
+ projectName = projectName || 'unknown';
98
+ projectType = projectType || 'unknown';
99
+ }
100
+ }
101
+
80
102
  StateManager.initState({
81
103
  force: options.force,
82
- projectName: options.project || '{PROJECT_NAME}',
83
- projectType: options.type || 'blazor-server'
104
+ projectName,
105
+ projectType
84
106
  });
85
107
 
86
108
  spinner.succeed('State initialized!');
@@ -36,7 +36,7 @@ export function loadTemplateRegistry(projectPath = null) {
36
36
  // Default to framework registry
37
37
  const registryPath = projectPath
38
38
  ? join(projectPath, 'framework/templates/REGISTRY.json')
39
- : join(__dirname, '../../framework/templates/REGISTRY.json');
39
+ : join(__dirname, '../../../framework/templates/REGISTRY.json');
40
40
 
41
41
  if (!existsSync(registryPath)) {
42
42
  throw new Error(`Template registry not found: ${registryPath}`);
@@ -22,9 +22,9 @@ const __dirname = dirname(fileURLToPath(import.meta.url));
22
22
  * @returns {string} Framework root path
23
23
  */
24
24
  function getFrameworkRoot(projectPath) {
25
- // Try npm-installed package first
25
+ // Try npm-installed package first (only if it has the workflow configs)
26
26
  const npmPath = join(projectPath, 'node_modules/@polymorphism-tech/morph-spec');
27
- if (existsSync(npmPath)) {
27
+ if (existsSync(npmPath) && existsSync(join(npmPath, 'framework/workflows/configs'))) {
28
28
  return npmPath;
29
29
  }
30
30
 
@@ -0,0 +1,221 @@
1
+ # Apply MORPH Feature Implementation - FASE 5
2
+
3
+ Implemente a feature especificada seguindo as tasks definidas.
4
+
5
+ ## Uso
6
+
7
+ ```
8
+ /morph-apply {feature-name}
9
+ ```
10
+
11
+ ## Pré-requisitos
12
+
13
+ ### CRÍTICO: Validar Fases Anteriores
14
+
15
+ **SEMPRE verifique que fases anteriores foram concluídas:**
16
+
17
+ ```bash
18
+ # Obter estado da feature
19
+ npx morph-spec state get {feature-name}
20
+ ```
21
+
22
+ **Validações obrigatórias:**
23
+
24
+ 1. **FASE 0 (Proposal):**
25
+ - [ ] Output `proposal` criado
26
+ - [ ] Agentes detectados e registrados
27
+
28
+ 2. **FASE 1 (Setup):**
29
+ - [ ] Phase passou por "setup"
30
+ - [ ] Contexto carregado
31
+
32
+ 3. **FASE 1.5 (UI/UX) - SE APLICÁVEL:**
33
+ - [ ] Se `uiux-designer` está nos activeAgents → outputs ui-* devem existir
34
+ - [ ] Se NÃO tem uiux-designer → pode pular
35
+
36
+ 4. **FASE 2 (Design):**
37
+ - [ ] Output `spec` criado
38
+ - [ ] Output `contracts` criado
39
+ - [ ] Output `decisions` criado
40
+
41
+ 5. **FASE 3 (Clarify):**
42
+ - [ ] Phase passou por "clarify"
43
+ - [ ] Spec atualizado com clarificações
44
+
45
+ 6. **FASE 4 (Tasks):**
46
+ - [ ] Output `tasks` criado
47
+ - [ ] `tasks.json` tem array de tasks
48
+ - [ ] `tasks.total` > 0 no state
49
+
50
+ **Se QUALQUER validação falhar:**
51
+ ```
52
+ ❌ ERRO: Fase {X} não foi concluída!
53
+
54
+ Para completar as fases de planejamento, execute:
55
+ /morph-proposal {feature-name}
56
+ (Resume automaticamente da fase atual: {current_phase})
57
+ ```
58
+
59
+ **NÃO prossiga com implementação até todas as fases estarem completas!**
60
+
61
+ ### Arquivos Necessários
62
+
63
+ - [ ] Feature existe em `.morph/project/outputs/{feature}/`
64
+ - [ ] `spec.md` está aprovado
65
+ - [ ] `tasks.json` tem tasks definidas
66
+ - [ ] `contracts.cs` define as interfaces
67
+
68
+ ## Workflow
69
+
70
+ 1. **Carregue o contexto**:
71
+ - Leia `.morph/project/outputs/{feature}/spec.md`
72
+ - Leia `.morph/project/outputs/{feature}/tasks.json`
73
+ - Leia `.morph/project/outputs/{feature}/contracts.cs`
74
+ - Leia framework/standards/ e .morph/project/standards/ para padrões
75
+
76
+ 2. **Inicialize state tracking**:
77
+ ```bash
78
+ # Atualizar fase para implement
79
+ npx morph-spec state set {feature} phase implement
80
+ npx morph-spec state set {feature} status in_progress
81
+
82
+ # Definir total de tasks (baseado em tasks.json)
83
+ npx morph-spec state set {feature} tasks.total {N}
84
+ ```
85
+
86
+ 3. **Execute tasks em ordem**:
87
+ - Marque task como in progress: `npx morph-spec task start {feature} {task-id}`
88
+ - Implemente seguindo os padrões e contracts.cs
89
+ - Complete task: `npx morph-spec task done {feature} {task-id}`
90
+ - **Validators run automatically** on task-done. If validation fails:
91
+ - Read the error messages and fix violations
92
+ - Re-run `task done` — do NOT use `--skip-validation` unless user authorizes
93
+ - Framework auto-manages checkpoints (every 3 tasks, includes validation summary)
94
+
95
+ 4. **Phase advancement**:
96
+ ```bash
97
+ # Advance to next phase (validates → advances → shows next steps)
98
+ npx morph-spec phase advance {feature}
99
+ ```
100
+
101
+ 5. **Marcar outputs criados**:
102
+ Sempre que gerar um arquivo de output:
103
+ ```bash
104
+ npx morph-spec state mark-output {feature} spec
105
+ npx morph-spec state mark-output {feature} contracts
106
+ npx morph-spec state mark-output {feature} tasks
107
+ # etc.
108
+ ```
109
+
110
+ 6. **Ao finalizar**:
111
+ - Generate recap automatically: `npx morph-spec generate recap {feature}`
112
+ - Atualize state: `npx morph-spec state set {feature} status done`
113
+ - Marque recap: `npx morph-spec state mark-output {feature} recap`
114
+ - Liste arquivos criados/modificados
115
+ - Calcule custo real vs estimado
116
+
117
+ ## Padrões Obrigatórios
118
+
119
+ Siga sempre (priorize project/standards/ se houver):
120
+ - `framework/standards/coding.md` - Padrões base do MORPH
121
+ - `.morph/project/standards/coding.md` - Padrões específicos do projeto
122
+ - `.morph/project/standards/architecture.md` - Estrutura de projeto
123
+ - `.morph/project/standards/azure.md` - Recursos e custos
124
+
125
+ ---
126
+
127
+ ## Checklist Pré-Deploy Azure
128
+
129
+ **ANTES de fazer deploy para Azure, execute `/morph-preflight azure` ou verifique manualmente:**
130
+
131
+ ### Packages e Build
132
+
133
+ - [ ] Packages sem conflitos de versão (`dotnet restore` sem warnings NU1605/NU1608)
134
+ - [ ] `Azure.Identity` especificado explicitamente no `.csproj`
135
+ - [ ] Build passa sem erros (`dotnet build`)
136
+
137
+ ### EF Core Migrations
138
+
139
+ - [ ] Sem pending model changes (`dotnet ef migrations has-pending-model-changes`)
140
+ - [ ] Migration criada para todas as mudanças de schema
141
+ - [ ] Migration script revisado (`dotnet ef migrations script --idempotent`)
142
+
143
+ ### Blazor .NET 10 (se aplicável)
144
+
145
+ - [ ] `.csproj` contém `<RequiresAspNetWebAssets>true</RequiresAspNetWebAssets>`
146
+ - [ ] Static assets funcionando localmente
147
+
148
+ ### Container/Docker (se Container Apps)
149
+
150
+ - [ ] Dockerfile válido e testado localmente
151
+ - [ ] `docker build` funciona sem erros
152
+ - [ ] Container roda localmente (`docker run`)
153
+
154
+ ### Infraestrutura Azure
155
+
156
+ - [ ] Bicep sem erros de sintaxe (`az bicep build`)
157
+ - [ ] Key Vault URI configurado em `appsettings.Production.json`
158
+ - [ ] Connection strings em Key Vault (não hardcoded)
159
+ - [ ] Managed Identity habilitada nos recursos
160
+
161
+ ### Segurança
162
+
163
+ - [ ] Sem secrets em código ou `appsettings.json` (exceto Development)
164
+ - [ ] HTTPS enforçado
165
+ - [ ] CORS configurado corretamente
166
+
167
+ ### Comandos de Verificação
168
+
169
+ ```bash
170
+ # 1. Package conflicts
171
+ dotnet restore 2>&1 | grep -E "NU1605|NU1608"
172
+
173
+ # 2. Pending migrations
174
+ dotnet ef migrations has-pending-model-changes \
175
+ --project src/Infrastructure \
176
+ --startup-project src/Web
177
+
178
+ # 3. Bicep validation
179
+ az bicep build --file infra/main.bicep --stdout > /dev/null
180
+
181
+ # 4. Docker build
182
+ docker build -t myapp:test .
183
+
184
+ # 5. Secret scan (basic)
185
+ grep -rE "(Password=|Pwd=|Secret=)" appsettings*.json | grep -v Development
186
+ ```
187
+
188
+ ### Se QUALQUER item falhar
189
+
190
+ ```
191
+ ❌ BLOQUEADO: Não faça deploy até resolver!
192
+
193
+ Use /morph-preflight azure para diagnóstico detalhado.
194
+ ```
195
+
196
+ ## Validações
197
+
198
+ Antes de marcar task como completa:
199
+ - [ ] Código compila
200
+ - [ ] Segue padrões de nomenclatura
201
+ - [ ] Testes unitários (se aplicável)
202
+ - [ ] Sem hardcoded secrets
203
+
204
+ ## Output
205
+
206
+ Ao final de cada task, mostre:
207
+ 1. Task completada
208
+ 2. Arquivos criados/modificados
209
+ 3. Próxima task
210
+ 4. Progresso geral (X/Y tasks) - usar `npx morph-spec state get {feature}`
211
+
212
+ Ao final de cada checkpoint:
213
+ ```bash
214
+ npx morph-spec state list
215
+ ```
216
+
217
+ Isso mostra o progresso atualizado automaticamente.
218
+
219
+ ---
220
+
221
+ **Feature:** $ARGUMENTS
@@ -0,0 +1,79 @@
1
+ # Archive MORPH Feature
2
+
3
+ Arquive uma feature concluída, movendo-a de `project/outputs/` para `project/archive/`.
4
+
5
+ ## Pré-requisitos
6
+
7
+ Verifique antes de arquivar:
8
+ - [ ] Feature existe em `.morph/project/outputs/{feature}/`
9
+ - [ ] Todas as tasks estão completas
10
+ - [ ] `recap.md` está preenchido
11
+ - [ ] Código está em produção (ou staging)
12
+
13
+ ## Workflow
14
+
15
+ 1. **Valide a conclusão**:
16
+ - Leia `.morph/project/outputs/{feature}/tasks.json`
17
+ - Verifique que todas tasks estão completadas
18
+ - Confirme com o usuário se pode arquivar
19
+
20
+ 2. **Complete o recap**:
21
+ - Atualize `.morph/project/outputs/{feature}/recap.md`
22
+ - Preencha métricas finais
23
+ - Documente lições aprendidas
24
+
25
+ 3. **Extraia specs**:
26
+ - Se a feature define comportamento permanente
27
+ - Copie spec relevante para `.morph/project/specs/`
28
+ - Isso vira a "verdade atual" do sistema
29
+
30
+ 4. **Mova para archive**:
31
+ ```
32
+ .morph/project/outputs/{feature}/ → .morph/project/archive/{feature}/
33
+ ```
34
+
35
+ 5. **Atualize métricas do projeto**:
36
+ - Incremente contador de features
37
+ - Atualize custo total
38
+ - Atualize tempo total
39
+
40
+ ## Output
41
+
42
+ Apresente resumo do arquivamento:
43
+
44
+ ```
45
+ ╔════════════════════════════════════════════╗
46
+ ║ FEATURE ARCHIVED ║
47
+ ╠════════════════════════════════════════════╣
48
+ ║ Feature: {name} ║
49
+ ║ Completed: {date} ║
50
+ ╠════════════════════════════════════════════╣
51
+ ║ METRICS ║
52
+ ╠════════════════════════════════════════════╣
53
+ ║ Tasks: {X}/{X} completed ║
54
+ ║ Time: {X}h (estimated: {Y}h) ║
55
+ ║ Cost Impact: +${X}/month ║
56
+ ╠════════════════════════════════════════════╣
57
+ ║ FILES ║
58
+ ╠════════════════════════════════════════════╣
59
+ ║ Created: {X} files ║
60
+ ║ Modified: {Y} files ║
61
+ ║ Tests: {Z} files ({W}% coverage) ║
62
+ ╠════════════════════════════════════════════╣
63
+ ║ ARCHIVED TO ║
64
+ ╠════════════════════════════════════════════╣
65
+ ║ .morph/project/archive/{feature}/ ║
66
+ ╚════════════════════════════════════════════╝
67
+ ```
68
+
69
+ ## Specs Extraídas
70
+
71
+ Se houver specs extraídas:
72
+ ```
73
+ Specs extracted to .morph/project/specs/:
74
+ - {domain}/spec.md - {description}
75
+ ```
76
+
77
+ ---
78
+
79
+ **Feature to archive:** $ARGUMENTS