@polymorphism-tech/morph-spec 3.0.0 → 3.0.1

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 (160) hide show
  1. package/CLAUDE.md +75 -371
  2. package/LICENSE +72 -72
  3. package/bin/detect-agents.js +225 -225
  4. package/bin/render-template.js +302 -302
  5. package/bin/semantic-detect-agents.js +246 -246
  6. package/bin/validate-agents-skills.js +251 -251
  7. package/bin/validate-agents.js +69 -69
  8. package/bin/validate-phase.js +263 -263
  9. package/content/.azure/README.md +293 -293
  10. package/content/.azure/docs/azure-devops-setup.md +454 -454
  11. package/content/.azure/docs/branch-strategy.md +398 -398
  12. package/content/.azure/docs/local-development.md +515 -515
  13. package/content/.azure/pipelines/pipeline-variables.yml +34 -34
  14. package/content/.azure/pipelines/prod-pipeline.yml +319 -319
  15. package/content/.azure/pipelines/staging-pipeline.yml +234 -234
  16. package/content/.azure/pipelines/templates/build-dotnet.yml +75 -75
  17. package/content/.azure/pipelines/templates/deploy-app-service.yml +94 -94
  18. package/content/.azure/pipelines/templates/deploy-container-app.yml +120 -120
  19. package/content/.azure/pipelines/templates/infra-deploy.yml +90 -90
  20. package/content/.claude/commands/morph-archive.md +79 -79
  21. package/content/.claude/commands/morph-deploy.md +529 -529
  22. package/content/.claude/commands/morph-infra.md +209 -209
  23. package/content/.claude/commands/morph-preflight.md +227 -227
  24. package/content/.claude/commands/morph-troubleshoot.md +122 -122
  25. package/content/.claude/settings.local.json +15 -15
  26. package/content/.claude/skills/{specialists → level-2-domains/architecture}/prompt-engineer.md +189 -189
  27. package/content/.claude/skills/{specialists → level-2-domains/architecture}/seo-growth-hacker.md +320 -320
  28. package/content/.claude/skills/{infra → level-2-domains/infrastructure}/azure-deploy-specialist.md +699 -699
  29. package/content/.morph/.morphversion +5 -5
  30. package/content/.morph/archive/.gitkeep +25 -25
  31. package/content/.morph/config/agents.json +7 -5
  32. package/content/.morph/docs/STORY-DRIVEN-DEVELOPMENT.md +392 -392
  33. package/content/.morph/examples/api-nextjs/README.md +241 -241
  34. package/content/.morph/examples/api-nextjs/contracts.ts +307 -307
  35. package/content/.morph/examples/api-nextjs/spec.md +399 -399
  36. package/content/.morph/examples/api-nextjs/tasks.md +168 -168
  37. package/content/.morph/examples/micro-saas/README.md +125 -125
  38. package/content/.morph/examples/micro-saas/contracts.cs +358 -358
  39. package/content/.morph/examples/micro-saas/decisions.md +246 -246
  40. package/content/.morph/examples/micro-saas/spec.md +236 -236
  41. package/content/.morph/examples/micro-saas/tasks.md +150 -150
  42. package/content/.morph/examples/multi-agent/README.md +309 -309
  43. package/content/.morph/examples/multi-agent/contracts.cs +433 -433
  44. package/content/.morph/examples/multi-agent/spec.md +479 -479
  45. package/content/.morph/examples/multi-agent/tasks.md +185 -185
  46. package/content/.morph/examples/state-v3.json +188 -188
  47. package/content/.morph/features/.gitkeep +25 -25
  48. package/content/.morph/hooks/pre-commit-all.sh +48 -48
  49. package/content/.morph/hooks/pre-commit-specs.sh +49 -49
  50. package/content/.morph/hooks/pre-commit-tests.sh +60 -60
  51. package/content/.morph/project.md +160 -160
  52. package/content/.morph/schemas/agent.schema.json +296 -296
  53. package/content/.morph/specs/.gitkeep +20 -20
  54. package/content/.morph/standards/coding.md +377 -377
  55. package/content/.morph/standards/fluent-ui-setup.md +590 -590
  56. package/content/.morph/standards/migration-guide.md +514 -514
  57. package/content/.morph/standards/passkeys-auth.md +423 -423
  58. package/content/.morph/standards/vector-search-rag.md +536 -536
  59. package/content/.morph/state.json +17 -17
  60. package/content/.morph/templates/FluentDesignTheme.cs +149 -149
  61. package/content/.morph/templates/MudTheme.cs +281 -281
  62. package/content/.morph/templates/component.razor +239 -239
  63. package/content/.morph/templates/contracts.cs +217 -217
  64. package/content/.morph/templates/design-system.css +226 -226
  65. package/content/.morph/templates/infra/.dockerignore.example +89 -89
  66. package/content/.morph/templates/infra/Dockerfile.example +82 -82
  67. package/content/.morph/templates/infra/README.md +286 -286
  68. package/content/.morph/templates/infra/app-insights.bicep +63 -63
  69. package/content/.morph/templates/infra/app-service.bicep +164 -164
  70. package/content/.morph/templates/infra/azure-pipelines-deploy.yml +480 -480
  71. package/content/.morph/templates/infra/container-app-env.bicep +49 -49
  72. package/content/.morph/templates/infra/container-app.bicep +156 -156
  73. package/content/.morph/templates/infra/deploy-checklist.md +426 -426
  74. package/content/.morph/templates/infra/deploy.ps1 +229 -229
  75. package/content/.morph/templates/infra/deploy.sh +208 -208
  76. package/content/.morph/templates/infra/key-vault.bicep +91 -91
  77. package/content/.morph/templates/infra/main.bicep +189 -189
  78. package/content/.morph/templates/infra/parameters.dev.json +29 -29
  79. package/content/.morph/templates/infra/parameters.prod.json +29 -29
  80. package/content/.morph/templates/infra/parameters.staging.json +29 -29
  81. package/content/.morph/templates/infra/sql-database.bicep +103 -103
  82. package/content/.morph/templates/infra/storage.bicep +106 -106
  83. package/content/.morph/templates/integrations/asaas-client.cs +387 -387
  84. package/content/.morph/templates/integrations/asaas-webhook.cs +351 -351
  85. package/content/.morph/templates/integrations/azure-identity-config.cs +288 -288
  86. package/content/.morph/templates/integrations/clerk-config.cs +258 -258
  87. package/content/.morph/templates/job.cs +171 -171
  88. package/content/.morph/templates/migration.cs +83 -83
  89. package/content/.morph/templates/repository.cs +141 -141
  90. package/content/.morph/templates/saas/subscription.cs +347 -347
  91. package/content/.morph/templates/saas/tenant.cs +338 -338
  92. package/content/.morph/templates/service.cs +139 -139
  93. package/content/.morph/templates/sprint-status.yaml +68 -68
  94. package/content/.morph/templates/story.md +143 -143
  95. package/content/.morph/templates/test.cs +239 -239
  96. package/content/.morph/templates/ui-design-system.md +286 -286
  97. package/content/.morph/templates/ui-flows.md +336 -336
  98. package/content/.morph/templates/ui-mockups.md +133 -133
  99. package/content/.morph/test-infra/example.bicep +59 -59
  100. package/content/README.md +79 -79
  101. package/docs/api/fonts/Source-Sans-Pro/sourcesanspro-light-webfont.svg +977 -977
  102. package/docs/api/fonts/Source-Sans-Pro/sourcesanspro-regular-webfont.svg +1048 -1048
  103. package/docs/api/scripts/collapse.js +38 -38
  104. package/docs/api/scripts/commonNav.js +28 -28
  105. package/docs/api/scripts/linenumber.js +25 -25
  106. package/docs/api/scripts/nav.js +12 -12
  107. package/docs/api/scripts/polyfill.js +3 -3
  108. package/docs/api/scripts/prettify/Apache-License-2.0.txt +202 -202
  109. package/docs/api/scripts/prettify/lang-css.js +2 -2
  110. package/docs/api/scripts/prettify/prettify.js +28 -28
  111. package/docs/api/scripts/search.js +98 -98
  112. package/docs/api/styles/jsdoc.css +776 -776
  113. package/docs/api/styles/prettify.css +80 -80
  114. package/docs/examples.md +328 -328
  115. package/docs/templates.md +418 -418
  116. package/package.json +1 -2
  117. package/scripts/postinstall.js +132 -132
  118. package/scripts/reorganize-skills.cjs +175 -0
  119. package/scripts/validate-agents-structure.cjs +52 -0
  120. package/scripts/validate-skills.cjs +180 -0
  121. package/src/commands/analyze-blazor-concurrency.js +193 -193
  122. package/src/commands/create-story.js +351 -351
  123. package/src/commands/deploy.js +780 -780
  124. package/src/commands/detect-agents.js +9 -0
  125. package/src/commands/detect.js +104 -104
  126. package/src/commands/generate.js +149 -149
  127. package/src/commands/lint-fluent.js +352 -352
  128. package/src/commands/rollback-phase.js +185 -185
  129. package/src/commands/session-summary.js +291 -291
  130. package/src/commands/shard-spec.js +224 -224
  131. package/src/commands/sprint-status.js +250 -250
  132. package/src/commands/state.js +334 -333
  133. package/src/commands/sync.js +167 -167
  134. package/src/commands/troubleshoot.js +222 -222
  135. package/src/commands/update.js +13 -1
  136. package/src/commands/validate-blazor-state.js +210 -210
  137. package/src/commands/validate-blazor.js +156 -156
  138. package/src/commands/validate-css.js +84 -84
  139. package/src/commands/validate-phase.js +221 -221
  140. package/src/lib/blazor-concurrency-analyzer.js +288 -288
  141. package/src/lib/blazor-state-validator.js +291 -291
  142. package/src/lib/blazor-validator.js +374 -374
  143. package/src/lib/css-validator.js +352 -352
  144. package/src/lib/design-system-generator.js +298 -298
  145. package/{detectors → src/lib/detectors}/config-detector.js +223 -223
  146. package/{detectors → src/lib/detectors}/conversation-analyzer.js +163 -163
  147. package/{detectors → src/lib/detectors}/index.js +84 -84
  148. package/{detectors → src/lib/detectors}/standards-generator.js +275 -275
  149. package/src/lib/learning-system.js +520 -520
  150. package/src/lib/mockup-generator.js +366 -366
  151. package/src/lib/state-manager.js +21 -4
  152. package/src/lib/troubleshoot-grep.js +194 -194
  153. package/src/lib/troubleshoot-index.js +144 -144
  154. package/src/lib/ui-detector.js +350 -350
  155. package/src/lib/validators/architecture-validator.js +387 -387
  156. package/src/lib/validators/package-validator.js +360 -360
  157. package/src/lib/validators/ui-contrast-validator.js +422 -422
  158. package/src/utils/logger.js +32 -32
  159. package/src/utils/version-checker.js +175 -175
  160. /package/{detectors → src/lib/detectors}/structure-detector.js +0 -0
package/docs/templates.md CHANGED
@@ -1,418 +1,418 @@
1
- # MORPH-SPEC Templates Reference
2
-
3
- Documentação completa de todos os templates disponíveis.
4
-
5
- ---
6
-
7
- ## Feature Templates
8
-
9
- Templates para documentação de features.
10
-
11
- ### spec.md
12
- Template de especificação técnica.
13
-
14
- **Localização**: `.morph/templates/spec.md`
15
-
16
- **Seções**:
17
- - Visão Geral
18
- - Requisitos Funcionais
19
- - Requisitos Não-Funcionais
20
- - Arquitetura
21
- - Modelo de Dados
22
- - APIs
23
- - Segurança
24
-
25
- ### tasks.md
26
- Template de breakdown de tasks.
27
-
28
- **Localização**: `.morph/templates/tasks.md`
29
-
30
- **Estrutura**:
31
- ```markdown
32
- | ID | Task | Dependências | Estimativa |
33
- |----|------|--------------|------------|
34
- | T001 | Descrição | - | S/M/L |
35
- ```
36
-
37
- ### contracts.cs
38
- Template de contratos (interfaces, DTOs).
39
-
40
- **Localização**: `.morph/templates/contracts.cs`
41
-
42
- **Inclui**:
43
- - Interfaces de serviço
44
- - DTOs de request/response
45
- - Enums
46
- - Interfaces de repositório
47
-
48
- ### decisions.md
49
- Template de Architecture Decision Records.
50
-
51
- **Localização**: `.morph/templates/decisions.md`
52
-
53
- **Formato ADR**:
54
- ```markdown
55
- ## ADR-001: Título
56
-
57
- **Status**: Proposed | Accepted | Deprecated
58
-
59
- **Context**: Descrição do contexto
60
-
61
- **Decision**: A decisão tomada
62
-
63
- **Consequences**: Impactos positivos e negativos
64
- ```
65
-
66
- ### recap.md
67
- Template de resumo pós-implementação.
68
-
69
- **Localização**: `.morph/templates/recap.md`
70
-
71
- ---
72
-
73
- ## Code Templates
74
-
75
- Templates para geração de código.
76
-
77
- ### component.razor
78
- Componente Blazor com parâmetros e lifecycle.
79
-
80
- **Localização**: `.morph/templates/component.razor`
81
-
82
- ```razor
83
- @namespace {{Namespace}}.Components
84
-
85
- <div class="{{ComponentName | kebab-case}}">
86
- @* Content *@
87
- </div>
88
-
89
- @code {
90
- [Parameter] public string Title { get; set; }
91
-
92
- protected override async Task OnInitializedAsync()
93
- {
94
- await base.OnInitializedAsync();
95
- }
96
- }
97
- ```
98
-
99
- ### service.cs
100
- Serviço com injeção de dependência.
101
-
102
- **Localização**: `.morph/templates/service.cs`
103
-
104
- ```csharp
105
- public interface I{{ServiceName}}Service
106
- {
107
- Task<Result> ExecuteAsync(Request request, CancellationToken ct);
108
- }
109
-
110
- public class {{ServiceName}}Service : I{{ServiceName}}Service
111
- {
112
- private readonly IRepository _repository;
113
- private readonly ILogger<{{ServiceName}}Service> _logger;
114
-
115
- public {{ServiceName}}Service(
116
- IRepository repository,
117
- ILogger<{{ServiceName}}Service> logger)
118
- {
119
- _repository = repository;
120
- _logger = logger;
121
- }
122
- }
123
- ```
124
-
125
- ### repository.cs
126
- Repositório EF Core.
127
-
128
- **Localização**: `.morph/templates/repository.cs`
129
-
130
- ```csharp
131
- public interface I{{Entity}}Repository
132
- {
133
- Task<{{Entity}}?> GetByIdAsync(int id, CancellationToken ct);
134
- Task<IReadOnlyList<{{Entity}}>> GetAllAsync(CancellationToken ct);
135
- Task AddAsync({{Entity}} entity, CancellationToken ct);
136
- void Update({{Entity}} entity);
137
- void Delete({{Entity}} entity);
138
- }
139
- ```
140
-
141
- ### test.cs
142
- Teste xUnit com FluentAssertions.
143
-
144
- **Localização**: `.morph/templates/test.cs`
145
-
146
- ```csharp
147
- public class {{ServiceName}}ServiceTests
148
- {
149
- private readonly Mock<IRepository> _repositoryMock;
150
- private readonly {{ServiceName}}Service _sut;
151
-
152
- public {{ServiceName}}ServiceTests()
153
- {
154
- _repositoryMock = new Mock<IRepository>();
155
- _sut = new {{ServiceName}}Service(_repositoryMock.Object);
156
- }
157
-
158
- [Fact]
159
- public async Task Method_Should_ReturnExpected_When_Condition()
160
- {
161
- // Arrange
162
- // Act
163
- // Assert
164
- }
165
- }
166
- ```
167
-
168
- ### migration.cs
169
- Migration EF Core.
170
-
171
- **Localização**: `.morph/templates/migration.cs`
172
-
173
- ### agent.cs
174
- Agente AI com Semantic Kernel.
175
-
176
- **Localização**: `.morph/templates/agent.cs`
177
-
178
- ```csharp
179
- public class {{AgentName}}Agent
180
- {
181
- private readonly Kernel _kernel;
182
-
183
- [KernelFunction("function_name")]
184
- [Description("Description of the function")]
185
- public async Task<string> ExecuteAsync(
186
- [Description("Parameter description")] string input)
187
- {
188
- // Implementation
189
- }
190
- }
191
- ```
192
-
193
- ### job.cs
194
- Background job Hangfire.
195
-
196
- **Localização**: `.morph/templates/job.cs`
197
-
198
- ```csharp
199
- public class {{JobName}}Job
200
- {
201
- private readonly IService _service;
202
- private readonly ILogger<{{JobName}}Job> _logger;
203
-
204
- [AutomaticRetry(Attempts = 3)]
205
- public async Task ExecuteAsync(JobParameters parameters)
206
- {
207
- _logger.LogInformation("Starting job {JobName}", nameof({{JobName}}Job));
208
- // Implementation
209
- }
210
- }
211
- ```
212
-
213
- ---
214
-
215
- ## IaC Templates (Bicep)
216
-
217
- Templates de Infrastructure as Code.
218
-
219
- ### main.bicep
220
- Entry point que compõe todos os módulos.
221
-
222
- **Localização**: `.morph/templates/infra/main.bicep`
223
-
224
- **Parâmetros**:
225
- - `appName` - Nome da aplicação
226
- - `environment` - dev/staging/prod
227
- - `location` - Região Azure
228
-
229
- **Módulos incluídos**:
230
- - Container App Environment
231
- - Container App
232
- - SQL Database
233
- - Storage Account
234
- - Key Vault
235
- - Application Insights
236
-
237
- ### container-app.bicep
238
- Azure Container Apps com auto-scaling.
239
-
240
- **Localização**: `.morph/templates/infra/container-app.bicep`
241
-
242
- **Features**:
243
- - Scale-to-zero
244
- - HTTP auto-scaling
245
- - Health probes (liveness + readiness)
246
- - Environment variables
247
- - Secrets integration
248
-
249
- ### container-app-env.bicep
250
- Managed Environment para Container Apps.
251
-
252
- **Localização**: `.morph/templates/infra/container-app-env.bicep`
253
-
254
- **Inclui**:
255
- - Log Analytics workspace
256
- - Internal/External ingress
257
-
258
- ### sql-database.bicep
259
- Azure SQL Database.
260
-
261
- **Localização**: `.morph/templates/infra/sql-database.bicep`
262
-
263
- **Tiers suportados**:
264
- - Free (32GB) - Desenvolvimento
265
- - Basic - Produção pequena
266
- - Standard - Produção
267
-
268
- ### storage.bicep
269
- Storage Account com containers.
270
-
271
- **Localização**: `.morph/templates/infra/storage.bicep`
272
-
273
- **Containers padrão**:
274
- - uploads
275
- - reports
276
- - backups
277
-
278
- ### key-vault.bicep
279
- Azure Key Vault.
280
-
281
- **Localização**: `.morph/templates/infra/key-vault.bicep`
282
-
283
- **Features**:
284
- - RBAC authorization
285
- - Soft delete
286
- - Purge protection (prod)
287
-
288
- ### app-insights.bicep
289
- Application Insights para monitoring.
290
-
291
- **Localização**: `.morph/templates/infra/app-insights.bicep`
292
-
293
- ### parameters.dev.json / parameters.prod.json
294
- Parâmetros por ambiente.
295
-
296
- **Localização**: `.morph/templates/infra/parameters.*.json`
297
-
298
- ---
299
-
300
- ## Integration Templates
301
-
302
- Templates para integrações externas.
303
-
304
- ### asaas-client.cs
305
- Cliente HTTP completo para Asaas.
306
-
307
- **Localização**: `.morph/templates/integrations/asaas-client.cs`
308
-
309
- **Endpoints**:
310
- - Customers (CRUD)
311
- - Payments (PIX, Boleto, Credit Card)
312
- - Subscriptions
313
- - Webhooks validation
314
-
315
- **Uso**:
316
- ```csharp
317
- services.AddAsaasClient(options =>
318
- {
319
- options.ApiKey = configuration["Asaas:ApiKey"];
320
- options.Environment = AsaasEnvironment.Sandbox;
321
- });
322
- ```
323
-
324
- ### asaas-webhook.cs
325
- Controller para webhooks Asaas.
326
-
327
- **Localização**: `.morph/templates/integrations/asaas-webhook.cs`
328
-
329
- **Eventos suportados**:
330
- - PAYMENT_CREATED
331
- - PAYMENT_RECEIVED
332
- - PAYMENT_CONFIRMED
333
- - PAYMENT_OVERDUE
334
- - PAYMENT_REFUNDED
335
- - SUBSCRIPTION_*
336
-
337
- ### clerk-config.cs
338
- Configuração de autenticação Clerk.
339
-
340
- **Localização**: `.morph/templates/integrations/clerk-config.cs`
341
-
342
- **Features**:
343
- - JWT validation
344
- - User claims
345
- - Middleware
346
- - Blazor integration
347
-
348
- ### azure-identity-config.cs
349
- Microsoft Identity Platform.
350
-
351
- **Localização**: `.morph/templates/integrations/azure-identity-config.cs`
352
-
353
- **Modos**:
354
- - Web App (OpenID Connect)
355
- - API (JWT Bearer)
356
- - Blazor Server
357
- - Downstream APIs (Graph)
358
-
359
- ---
360
-
361
- ## SaaS Templates
362
-
363
- Templates para aplicações SaaS.
364
-
365
- ### subscription.cs
366
- Modelo completo de assinaturas.
367
-
368
- **Localização**: `.morph/templates/saas/subscription.cs`
369
-
370
- **Entidades**:
371
- - `Plan` - Planos com limites e features
372
- - `Subscription` - Assinatura do tenant
373
- - `SubscriptionPayment` - Histórico de pagamentos
374
-
375
- **Features**:
376
- - Ciclos mensais e anuais
377
- - Trial period
378
- - Status machine (Trial → Active → PastDue → Canceled)
379
- - Integração Asaas
380
-
381
- ### tenant.cs
382
- Multi-tenancy completo.
383
-
384
- **Localização**: `.morph/templates/saas/tenant.cs`
385
-
386
- **Entidades**:
387
- - `Tenant` - Organização
388
- - `TenantUser` - Usuários do tenant
389
-
390
- **Features**:
391
- - Múltiplas estratégias de resolução:
392
- - Subdomínio (`acme.app.com`)
393
- - Header (`X-Tenant-ID`)
394
- - Route (`/tenant/{slug}`)
395
- - Claim (JWT)
396
- - EF Core query filters
397
- - Status management
398
-
399
- ---
400
-
401
- ## Como Usar
402
-
403
- ### 1. Copiar Template
404
- Os templates são automaticamente aplicados pelo MORPH durante `/morph-apply`.
405
-
406
- ### 2. Substituir Placeholders
407
- Placeholders comuns:
408
- - `{{Namespace}}` - Namespace do projeto
409
- - `{{ServiceName}}` - Nome do serviço
410
- - `{{Entity}}` - Nome da entidade
411
- - `{{ComponentName}}` - Nome do componente
412
-
413
- ### 3. Customizar
414
- Edite os templates em `.morph/templates/` para seu estilo.
415
-
416
- ---
417
-
418
- *MORPH-SPEC by Polymorphism Tech*
1
+ # MORPH-SPEC Templates Reference
2
+
3
+ Documentação completa de todos os templates disponíveis.
4
+
5
+ ---
6
+
7
+ ## Feature Templates
8
+
9
+ Templates para documentação de features.
10
+
11
+ ### spec.md
12
+ Template de especificação técnica.
13
+
14
+ **Localização**: `.morph/templates/spec.md`
15
+
16
+ **Seções**:
17
+ - Visão Geral
18
+ - Requisitos Funcionais
19
+ - Requisitos Não-Funcionais
20
+ - Arquitetura
21
+ - Modelo de Dados
22
+ - APIs
23
+ - Segurança
24
+
25
+ ### tasks.md
26
+ Template de breakdown de tasks.
27
+
28
+ **Localização**: `.morph/templates/tasks.md`
29
+
30
+ **Estrutura**:
31
+ ```markdown
32
+ | ID | Task | Dependências | Estimativa |
33
+ |----|------|--------------|------------|
34
+ | T001 | Descrição | - | S/M/L |
35
+ ```
36
+
37
+ ### contracts.cs
38
+ Template de contratos (interfaces, DTOs).
39
+
40
+ **Localização**: `.morph/templates/contracts.cs`
41
+
42
+ **Inclui**:
43
+ - Interfaces de serviço
44
+ - DTOs de request/response
45
+ - Enums
46
+ - Interfaces de repositório
47
+
48
+ ### decisions.md
49
+ Template de Architecture Decision Records.
50
+
51
+ **Localização**: `.morph/templates/decisions.md`
52
+
53
+ **Formato ADR**:
54
+ ```markdown
55
+ ## ADR-001: Título
56
+
57
+ **Status**: Proposed | Accepted | Deprecated
58
+
59
+ **Context**: Descrição do contexto
60
+
61
+ **Decision**: A decisão tomada
62
+
63
+ **Consequences**: Impactos positivos e negativos
64
+ ```
65
+
66
+ ### recap.md
67
+ Template de resumo pós-implementação.
68
+
69
+ **Localização**: `.morph/templates/recap.md`
70
+
71
+ ---
72
+
73
+ ## Code Templates
74
+
75
+ Templates para geração de código.
76
+
77
+ ### component.razor
78
+ Componente Blazor com parâmetros e lifecycle.
79
+
80
+ **Localização**: `.morph/templates/component.razor`
81
+
82
+ ```razor
83
+ @namespace {{Namespace}}.Components
84
+
85
+ <div class="{{ComponentName | kebab-case}}">
86
+ @* Content *@
87
+ </div>
88
+
89
+ @code {
90
+ [Parameter] public string Title { get; set; }
91
+
92
+ protected override async Task OnInitializedAsync()
93
+ {
94
+ await base.OnInitializedAsync();
95
+ }
96
+ }
97
+ ```
98
+
99
+ ### service.cs
100
+ Serviço com injeção de dependência.
101
+
102
+ **Localização**: `.morph/templates/service.cs`
103
+
104
+ ```csharp
105
+ public interface I{{ServiceName}}Service
106
+ {
107
+ Task<Result> ExecuteAsync(Request request, CancellationToken ct);
108
+ }
109
+
110
+ public class {{ServiceName}}Service : I{{ServiceName}}Service
111
+ {
112
+ private readonly IRepository _repository;
113
+ private readonly ILogger<{{ServiceName}}Service> _logger;
114
+
115
+ public {{ServiceName}}Service(
116
+ IRepository repository,
117
+ ILogger<{{ServiceName}}Service> logger)
118
+ {
119
+ _repository = repository;
120
+ _logger = logger;
121
+ }
122
+ }
123
+ ```
124
+
125
+ ### repository.cs
126
+ Repositório EF Core.
127
+
128
+ **Localização**: `.morph/templates/repository.cs`
129
+
130
+ ```csharp
131
+ public interface I{{Entity}}Repository
132
+ {
133
+ Task<{{Entity}}?> GetByIdAsync(int id, CancellationToken ct);
134
+ Task<IReadOnlyList<{{Entity}}>> GetAllAsync(CancellationToken ct);
135
+ Task AddAsync({{Entity}} entity, CancellationToken ct);
136
+ void Update({{Entity}} entity);
137
+ void Delete({{Entity}} entity);
138
+ }
139
+ ```
140
+
141
+ ### test.cs
142
+ Teste xUnit com FluentAssertions.
143
+
144
+ **Localização**: `.morph/templates/test.cs`
145
+
146
+ ```csharp
147
+ public class {{ServiceName}}ServiceTests
148
+ {
149
+ private readonly Mock<IRepository> _repositoryMock;
150
+ private readonly {{ServiceName}}Service _sut;
151
+
152
+ public {{ServiceName}}ServiceTests()
153
+ {
154
+ _repositoryMock = new Mock<IRepository>();
155
+ _sut = new {{ServiceName}}Service(_repositoryMock.Object);
156
+ }
157
+
158
+ [Fact]
159
+ public async Task Method_Should_ReturnExpected_When_Condition()
160
+ {
161
+ // Arrange
162
+ // Act
163
+ // Assert
164
+ }
165
+ }
166
+ ```
167
+
168
+ ### migration.cs
169
+ Migration EF Core.
170
+
171
+ **Localização**: `.morph/templates/migration.cs`
172
+
173
+ ### agent.cs
174
+ Agente AI com Semantic Kernel.
175
+
176
+ **Localização**: `.morph/templates/agent.cs`
177
+
178
+ ```csharp
179
+ public class {{AgentName}}Agent
180
+ {
181
+ private readonly Kernel _kernel;
182
+
183
+ [KernelFunction("function_name")]
184
+ [Description("Description of the function")]
185
+ public async Task<string> ExecuteAsync(
186
+ [Description("Parameter description")] string input)
187
+ {
188
+ // Implementation
189
+ }
190
+ }
191
+ ```
192
+
193
+ ### job.cs
194
+ Background job Hangfire.
195
+
196
+ **Localização**: `.morph/templates/job.cs`
197
+
198
+ ```csharp
199
+ public class {{JobName}}Job
200
+ {
201
+ private readonly IService _service;
202
+ private readonly ILogger<{{JobName}}Job> _logger;
203
+
204
+ [AutomaticRetry(Attempts = 3)]
205
+ public async Task ExecuteAsync(JobParameters parameters)
206
+ {
207
+ _logger.LogInformation("Starting job {JobName}", nameof({{JobName}}Job));
208
+ // Implementation
209
+ }
210
+ }
211
+ ```
212
+
213
+ ---
214
+
215
+ ## IaC Templates (Bicep)
216
+
217
+ Templates de Infrastructure as Code.
218
+
219
+ ### main.bicep
220
+ Entry point que compõe todos os módulos.
221
+
222
+ **Localização**: `.morph/templates/infra/main.bicep`
223
+
224
+ **Parâmetros**:
225
+ - `appName` - Nome da aplicação
226
+ - `environment` - dev/staging/prod
227
+ - `location` - Região Azure
228
+
229
+ **Módulos incluídos**:
230
+ - Container App Environment
231
+ - Container App
232
+ - SQL Database
233
+ - Storage Account
234
+ - Key Vault
235
+ - Application Insights
236
+
237
+ ### container-app.bicep
238
+ Azure Container Apps com auto-scaling.
239
+
240
+ **Localização**: `.morph/templates/infra/container-app.bicep`
241
+
242
+ **Features**:
243
+ - Scale-to-zero
244
+ - HTTP auto-scaling
245
+ - Health probes (liveness + readiness)
246
+ - Environment variables
247
+ - Secrets integration
248
+
249
+ ### container-app-env.bicep
250
+ Managed Environment para Container Apps.
251
+
252
+ **Localização**: `.morph/templates/infra/container-app-env.bicep`
253
+
254
+ **Inclui**:
255
+ - Log Analytics workspace
256
+ - Internal/External ingress
257
+
258
+ ### sql-database.bicep
259
+ Azure SQL Database.
260
+
261
+ **Localização**: `.morph/templates/infra/sql-database.bicep`
262
+
263
+ **Tiers suportados**:
264
+ - Free (32GB) - Desenvolvimento
265
+ - Basic - Produção pequena
266
+ - Standard - Produção
267
+
268
+ ### storage.bicep
269
+ Storage Account com containers.
270
+
271
+ **Localização**: `.morph/templates/infra/storage.bicep`
272
+
273
+ **Containers padrão**:
274
+ - uploads
275
+ - reports
276
+ - backups
277
+
278
+ ### key-vault.bicep
279
+ Azure Key Vault.
280
+
281
+ **Localização**: `.morph/templates/infra/key-vault.bicep`
282
+
283
+ **Features**:
284
+ - RBAC authorization
285
+ - Soft delete
286
+ - Purge protection (prod)
287
+
288
+ ### app-insights.bicep
289
+ Application Insights para monitoring.
290
+
291
+ **Localização**: `.morph/templates/infra/app-insights.bicep`
292
+
293
+ ### parameters.dev.json / parameters.prod.json
294
+ Parâmetros por ambiente.
295
+
296
+ **Localização**: `.morph/templates/infra/parameters.*.json`
297
+
298
+ ---
299
+
300
+ ## Integration Templates
301
+
302
+ Templates para integrações externas.
303
+
304
+ ### asaas-client.cs
305
+ Cliente HTTP completo para Asaas.
306
+
307
+ **Localização**: `.morph/templates/integrations/asaas-client.cs`
308
+
309
+ **Endpoints**:
310
+ - Customers (CRUD)
311
+ - Payments (PIX, Boleto, Credit Card)
312
+ - Subscriptions
313
+ - Webhooks validation
314
+
315
+ **Uso**:
316
+ ```csharp
317
+ services.AddAsaasClient(options =>
318
+ {
319
+ options.ApiKey = configuration["Asaas:ApiKey"];
320
+ options.Environment = AsaasEnvironment.Sandbox;
321
+ });
322
+ ```
323
+
324
+ ### asaas-webhook.cs
325
+ Controller para webhooks Asaas.
326
+
327
+ **Localização**: `.morph/templates/integrations/asaas-webhook.cs`
328
+
329
+ **Eventos suportados**:
330
+ - PAYMENT_CREATED
331
+ - PAYMENT_RECEIVED
332
+ - PAYMENT_CONFIRMED
333
+ - PAYMENT_OVERDUE
334
+ - PAYMENT_REFUNDED
335
+ - SUBSCRIPTION_*
336
+
337
+ ### clerk-config.cs
338
+ Configuração de autenticação Clerk.
339
+
340
+ **Localização**: `.morph/templates/integrations/clerk-config.cs`
341
+
342
+ **Features**:
343
+ - JWT validation
344
+ - User claims
345
+ - Middleware
346
+ - Blazor integration
347
+
348
+ ### azure-identity-config.cs
349
+ Microsoft Identity Platform.
350
+
351
+ **Localização**: `.morph/templates/integrations/azure-identity-config.cs`
352
+
353
+ **Modos**:
354
+ - Web App (OpenID Connect)
355
+ - API (JWT Bearer)
356
+ - Blazor Server
357
+ - Downstream APIs (Graph)
358
+
359
+ ---
360
+
361
+ ## SaaS Templates
362
+
363
+ Templates para aplicações SaaS.
364
+
365
+ ### subscription.cs
366
+ Modelo completo de assinaturas.
367
+
368
+ **Localização**: `.morph/templates/saas/subscription.cs`
369
+
370
+ **Entidades**:
371
+ - `Plan` - Planos com limites e features
372
+ - `Subscription` - Assinatura do tenant
373
+ - `SubscriptionPayment` - Histórico de pagamentos
374
+
375
+ **Features**:
376
+ - Ciclos mensais e anuais
377
+ - Trial period
378
+ - Status machine (Trial → Active → PastDue → Canceled)
379
+ - Integração Asaas
380
+
381
+ ### tenant.cs
382
+ Multi-tenancy completo.
383
+
384
+ **Localização**: `.morph/templates/saas/tenant.cs`
385
+
386
+ **Entidades**:
387
+ - `Tenant` - Organização
388
+ - `TenantUser` - Usuários do tenant
389
+
390
+ **Features**:
391
+ - Múltiplas estratégias de resolução:
392
+ - Subdomínio (`acme.app.com`)
393
+ - Header (`X-Tenant-ID`)
394
+ - Route (`/tenant/{slug}`)
395
+ - Claim (JWT)
396
+ - EF Core query filters
397
+ - Status management
398
+
399
+ ---
400
+
401
+ ## Como Usar
402
+
403
+ ### 1. Copiar Template
404
+ Os templates são automaticamente aplicados pelo MORPH durante `/morph-apply`.
405
+
406
+ ### 2. Substituir Placeholders
407
+ Placeholders comuns:
408
+ - `{{Namespace}}` - Namespace do projeto
409
+ - `{{ServiceName}}` - Nome do serviço
410
+ - `{{Entity}}` - Nome da entidade
411
+ - `{{ComponentName}}` - Nome do componente
412
+
413
+ ### 3. Customizar
414
+ Edite os templates em `.morph/templates/` para seu estilo.
415
+
416
+ ---
417
+
418
+ *MORPH-SPEC by Polymorphism Tech*