@polymorphism-tech/morph-spec 2.2.0 → 2.4.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.
- package/CLAUDE.md +314 -1673
- package/LICENSE +72 -72
- package/README.md +515 -516
- package/bin/detect-agents.js +225 -225
- package/bin/morph-spec.js +358 -173
- package/bin/render-template.js +302 -302
- package/bin/semantic-detect-agents.js +246 -246
- package/bin/task-manager.js +429 -0
- package/bin/validate-agents-skills.js +251 -251
- package/bin/validate-agents.js +69 -69
- package/bin/validate-phase.js +263 -263
- package/bin/validate.js +369 -0
- package/content/.azure/README.md +293 -293
- package/content/.azure/docs/azure-devops-setup.md +454 -454
- package/content/.azure/docs/branch-strategy.md +398 -398
- package/content/.azure/docs/local-development.md +515 -515
- package/content/.azure/pipelines/pipeline-variables.yml +34 -34
- package/content/.azure/pipelines/prod-pipeline.yml +319 -319
- package/content/.azure/pipelines/staging-pipeline.yml +234 -234
- package/content/.azure/pipelines/templates/build-dotnet.yml +75 -75
- package/content/.azure/pipelines/templates/deploy-app-service.yml +94 -94
- package/content/.azure/pipelines/templates/deploy-container-app.yml +120 -120
- package/content/.azure/pipelines/templates/infra-deploy.yml +90 -90
- package/content/.claude/commands/morph-apply.md +221 -158
- package/content/.claude/commands/morph-archive.md +79 -79
- package/content/.claude/commands/morph-infra.md +209 -209
- package/content/.claude/commands/morph-preflight.md +227 -0
- package/content/.claude/commands/morph-proposal.md +122 -101
- package/content/.claude/commands/morph-status.md +86 -86
- package/content/.claude/commands/morph-troubleshoot.md +122 -0
- package/content/.claude/settings.local.json +15 -15
- package/content/.claude/skills/checklists/code-review.md +226 -0
- package/content/.claude/skills/checklists/morph-checklist.md +117 -0
- package/content/.claude/skills/checklists/simulation-checklist.md +77 -0
- package/content/.claude/skills/infra/bicep-architect.md +126 -419
- package/content/.claude/skills/infra/container-specialist.md +131 -437
- package/content/.claude/skills/infra/devops-engineer.md +119 -405
- package/content/.claude/skills/integrations/asaas-financial.md +130 -333
- package/content/.claude/skills/integrations/azure-identity.md +142 -309
- package/content/.claude/skills/integrations/clerk-auth.md +108 -290
- package/content/.claude/skills/integrations/resend-email.md +119 -0
- package/content/.claude/skills/specialists/ai-system-architect.md +192 -604
- package/content/.claude/skills/specialists/azure-architect.md +142 -142
- package/content/.claude/skills/specialists/code-analyzer.md +235 -0
- package/content/.claude/skills/specialists/dotnet-senior.md +287 -0
- package/content/.claude/skills/specialists/ef-modeler.md +113 -200
- package/content/.claude/skills/specialists/hangfire-orchestrator.md +126 -245
- package/content/.claude/skills/specialists/ms-agent-expert.md +109 -263
- package/content/.claude/skills/specialists/po-pm-advisor.md +197 -197
- package/content/.claude/skills/specialists/standards-architect.md +156 -78
- package/content/.claude/skills/specialists/testing-specialist.md +126 -0
- package/content/.claude/skills/specialists/ui-ux-designer.md +191 -1060
- package/content/.claude/skills/stacks/dotnet-blazor.md +210 -588
- package/content/.claude/skills/stacks/dotnet-nextjs.md +154 -402
- package/content/.claude/skills/workflows/morph-replicate.md +213 -0
- package/content/.claude/{commands/morph-clarify.md → skills/workflows/phase-clarify.md} +5 -58
- package/content/.claude/{commands/morph-design.md → skills/workflows/phase-design.md} +16 -86
- package/content/.claude/{commands/morph-setup.md → skills/workflows/phase-setup.md} +9 -17
- package/content/.claude/skills/workflows/phase-tasks.md +164 -0
- package/content/.claude/{commands/morph-uiux.md → skills/workflows/phase-uiux.md} +15 -88
- package/content/.morph/.morphversion +5 -5
- package/content/.morph/archive/.gitkeep +25 -25
- package/content/.morph/config/agents.json +378 -242
- package/content/.morph/config/config.template.json +89 -108
- package/content/.morph/docs/STORY-DRIVEN-DEVELOPMENT.md +392 -392
- package/content/.morph/docs/workflows/design-impl.md +37 -0
- package/content/.morph/docs/workflows/fast-track.md +29 -0
- package/content/.morph/docs/workflows/full-morph.md +76 -0
- package/content/.morph/docs/workflows/standard.md +44 -0
- package/content/.morph/docs/workflows/ui-refresh.md +39 -0
- package/content/.morph/examples/api-nextjs/README.md +241 -241
- package/content/.morph/examples/api-nextjs/contracts.ts +307 -307
- package/content/.morph/examples/api-nextjs/spec.md +399 -399
- package/content/.morph/examples/api-nextjs/tasks.md +168 -168
- package/content/.morph/examples/micro-saas/README.md +125 -125
- package/content/.morph/examples/micro-saas/contracts.cs +358 -358
- package/content/.morph/examples/micro-saas/decisions.md +246 -246
- package/content/.morph/examples/micro-saas/spec.md +236 -236
- package/content/.morph/examples/micro-saas/tasks.md +150 -150
- package/content/.morph/examples/multi-agent/README.md +309 -309
- package/content/.morph/examples/multi-agent/contracts.cs +433 -433
- package/content/.morph/examples/multi-agent/spec.md +479 -479
- package/content/.morph/examples/multi-agent/tasks.md +185 -185
- package/content/.morph/examples/scheduled-reports/decisions.md +158 -0
- package/content/.morph/examples/scheduled-reports/proposal.md +95 -0
- package/content/.morph/examples/scheduled-reports/spec.md +267 -0
- package/content/.morph/examples/state-v3.json +188 -0
- package/content/.morph/features/.gitkeep +25 -25
- package/content/.morph/hooks/README.md +190 -239
- package/content/.morph/hooks/pre-commit-agents.sh +24 -24
- package/content/.morph/hooks/pre-commit-all.sh +48 -48
- package/content/.morph/hooks/pre-commit-specs.sh +49 -49
- package/content/.morph/hooks/pre-commit-tests.sh +60 -60
- package/content/.morph/project.md +160 -160
- package/content/.morph/schemas/agent.schema.json +296 -296
- package/content/.morph/schemas/tasks.schema.json +220 -0
- package/content/.morph/specs/.gitkeep +20 -20
- package/content/.morph/standards/agent-framework-blazor-ui.md +359 -0
- package/content/.morph/standards/agent-framework-production.md +410 -0
- package/content/.morph/standards/agent-framework-setup.md +413 -453
- package/content/.morph/standards/agent-framework-workflows.md +349 -0
- package/content/.morph/standards/architecture.md +325 -325
- package/content/.morph/standards/azure.md +605 -379
- package/content/.morph/standards/coding.md +377 -377
- package/content/.morph/standards/dotnet10-migration.md +520 -494
- package/content/.morph/standards/fluent-ui-setup.md +590 -590
- package/content/.morph/standards/migration-guide.md +514 -514
- package/content/.morph/standards/passkeys-auth.md +423 -423
- package/content/.morph/standards/vector-search-rag.md +536 -536
- package/content/.morph/state.json +17 -17
- package/content/.morph/templates/FluentDesignTheme.cs +149 -149
- package/content/.morph/templates/MudTheme.cs +281 -281
- package/content/.morph/templates/agent.cs +163 -172
- package/content/.morph/templates/clarify-questions.md +159 -0
- package/content/.morph/templates/component.razor +239 -239
- package/content/.morph/templates/contracts/Commands.cs +74 -0
- package/content/.morph/templates/contracts/Entities.cs +25 -0
- package/content/.morph/templates/contracts/Queries.cs +74 -0
- package/content/.morph/templates/contracts/README.md +74 -0
- package/content/.morph/templates/contracts.cs +217 -217
- package/content/.morph/templates/decisions.md +123 -106
- package/content/.morph/templates/design-system.css +226 -226
- package/content/.morph/templates/infra/.dockerignore.example +89 -89
- package/content/.morph/templates/infra/Dockerfile.example +82 -82
- package/content/.morph/templates/infra/README.md +286 -286
- package/content/.morph/templates/infra/app-insights.bicep +63 -63
- package/content/.morph/templates/infra/app-service.bicep +164 -164
- package/content/.morph/templates/infra/container-app-env.bicep +49 -49
- package/content/.morph/templates/infra/container-app.bicep +156 -156
- package/content/.morph/templates/infra/deploy-checklist.md +426 -0
- package/content/.morph/templates/infra/deploy.ps1 +229 -229
- package/content/.morph/templates/infra/deploy.sh +208 -208
- package/content/.morph/templates/infra/key-vault.bicep +91 -91
- package/content/.morph/templates/infra/main.bicep +189 -189
- package/content/.morph/templates/infra/parameters.dev.json +29 -29
- package/content/.morph/templates/infra/parameters.prod.json +29 -29
- package/content/.morph/templates/infra/parameters.staging.json +29 -29
- package/content/.morph/templates/infra/sql-database.bicep +103 -103
- package/content/.morph/templates/infra/storage.bicep +106 -106
- package/content/.morph/templates/integrations/asaas-client.cs +387 -387
- package/content/.morph/templates/integrations/asaas-webhook.cs +351 -351
- package/content/.morph/templates/integrations/azure-identity-config.cs +288 -288
- package/content/.morph/templates/integrations/clerk-config.cs +258 -258
- package/content/.morph/templates/job.cs +171 -171
- package/content/.morph/templates/migration.cs +83 -83
- package/content/.morph/templates/proposal.md +141 -155
- package/content/.morph/templates/recap.md +94 -105
- package/content/.morph/templates/repository.cs +141 -141
- package/content/.morph/templates/saas/subscription.cs +347 -347
- package/content/.morph/templates/saas/tenant.cs +338 -338
- package/content/.morph/templates/service.cs +139 -139
- package/content/.morph/templates/simulation.md +353 -0
- package/content/.morph/templates/spec.md +149 -148
- package/content/.morph/templates/sprint-status.yaml +68 -68
- package/content/.morph/templates/state.template.json +222 -222
- package/content/.morph/templates/story.md +143 -143
- package/content/.morph/templates/tasks.md +257 -235
- package/content/.morph/templates/test.cs +239 -239
- package/content/.morph/templates/ui-components.md +362 -276
- package/content/.morph/templates/ui-design-system.md +286 -286
- package/content/.morph/templates/ui-flows.md +336 -336
- package/content/.morph/templates/ui-mockups.md +133 -133
- package/content/.morph/test-infra/example.bicep +59 -59
- package/content/CLAUDE.md +150 -442
- package/content/README.md +79 -79
- package/detectors/config-detector.js +223 -223
- package/detectors/conversation-analyzer.js +163 -163
- package/detectors/index.js +84 -84
- package/detectors/standards-generator.js +275 -275
- package/detectors/structure-detector.js +245 -250
- package/docs/README.md +144 -149
- package/docs/api/fonts/Source-Sans-Pro/sourcesanspro-light-webfont.svg +977 -977
- package/docs/api/fonts/Source-Sans-Pro/sourcesanspro-regular-webfont.svg +1048 -1048
- package/docs/api/scripts/collapse.js +38 -38
- package/docs/api/scripts/commonNav.js +28 -28
- package/docs/api/scripts/linenumber.js +25 -25
- package/docs/api/scripts/nav.js +12 -12
- package/docs/api/scripts/polyfill.js +3 -3
- package/docs/api/scripts/prettify/Apache-License-2.0.txt +202 -202
- package/docs/api/scripts/prettify/lang-css.js +2 -2
- package/docs/api/scripts/prettify/prettify.js +28 -28
- package/docs/api/scripts/search.js +98 -98
- package/docs/api/styles/jsdoc.css +776 -776
- package/docs/api/styles/prettify.css +80 -80
- package/docs/examples.md +328 -328
- package/docs/getting-started.md +301 -302
- package/docs/installation.md +361 -361
- package/docs/templates.md +418 -418
- package/docs/validation-checklist.md +265 -266
- package/package.json +80 -80
- package/scripts/postinstall.js +132 -132
- package/src/commands/advance-phase.js +183 -0
- package/src/commands/analyze-blazor-concurrency.js +193 -0
- package/src/commands/create-story.js +351 -351
- package/src/commands/detect-agents.js +139 -0
- package/src/commands/detect.js +104 -104
- package/src/commands/doctor.js +356 -280
- package/src/commands/generate.js +149 -149
- package/src/commands/init.js +258 -245
- package/src/commands/lint-fluent.js +352 -0
- package/src/commands/rollback-phase.js +185 -0
- package/src/commands/session-summary.js +291 -0
- package/src/commands/shard-spec.js +224 -224
- package/src/commands/sprint-status.js +250 -250
- package/src/commands/state.js +333 -333
- package/src/commands/sync.js +167 -167
- package/src/commands/task.js +78 -0
- package/src/commands/troubleshoot.js +222 -0
- package/src/commands/update.js +192 -159
- package/src/commands/validate-blazor-state.js +210 -0
- package/src/commands/validate-blazor.js +156 -0
- package/src/commands/validate-css.js +84 -0
- package/src/commands/validate-phase.js +221 -0
- package/src/lib/blazor-concurrency-analyzer.js +288 -0
- package/src/lib/blazor-state-validator.js +291 -0
- package/src/lib/blazor-validator.js +374 -0
- package/src/lib/complexity-analyzer.js +441 -292
- package/src/lib/continuous-validator.js +421 -0
- package/src/lib/css-validator.js +352 -0
- package/src/lib/decision-constraint-loader.js +109 -0
- package/src/lib/design-system-generator.js +298 -298
- package/src/lib/learning-system.js +520 -0
- package/src/lib/mockup-generator.js +366 -0
- package/src/lib/recap-generator.js +205 -0
- package/src/lib/state-manager.js +397 -340
- package/src/lib/troubleshoot-grep.js +194 -0
- package/src/lib/troubleshoot-index.js +144 -0
- package/src/lib/ui-detector.js +350 -0
- package/src/lib/validation-runner.js +231 -0
- package/src/lib/validators/architecture-validator.js +387 -0
- package/src/lib/validators/contract-compliance-validator.js +273 -0
- package/src/lib/validators/package-validator.js +360 -0
- package/src/lib/validators/ui-contrast-validator.js +422 -0
- package/src/utils/file-copier.js +179 -139
- package/src/utils/logger.js +32 -32
- package/src/utils/version-checker.js +175 -175
- package/content/.claude/commands/morph-costs.md +0 -206
- package/content/.claude/commands/morph-tasks.md +0 -319
- package/content/.claude/skills/specialists/cost-guardian.md +0 -110
- package/content/.claude/skills/stacks/shopify.md +0 -445
- package/content/.morph/config/azure-pricing.json +0 -70
- package/content/.morph/config/azure-pricing.schema.json +0 -50
- package/content/.morph/hooks/pre-commit-costs.sh +0 -91
- package/docs/api/cost-calculator.js.html +0 -513
- package/docs/api/design-system-generator.js.html +0 -382
- package/docs/api/global.html +0 -5263
- package/docs/api/index.html +0 -96
- package/docs/api/state-manager.js.html +0 -423
- package/src/commands/cost.js +0 -181
- package/src/commands/update-pricing.js +0 -206
- package/src/lib/cost-calculator.js +0 -429
|
@@ -1,209 +1,209 @@
|
|
|
1
|
-
# /morph-infra - Infrastructure Management
|
|
2
|
-
|
|
3
|
-
Gerencia infraestrutura Azure usando Bicep templates.
|
|
4
|
-
|
|
5
|
-
## Uso
|
|
6
|
-
|
|
7
|
-
```
|
|
8
|
-
/morph-infra [action] [options]
|
|
9
|
-
```
|
|
10
|
-
|
|
11
|
-
### Actions
|
|
12
|
-
|
|
13
|
-
| Action | Descrição |
|
|
14
|
-
|--------|-----------|
|
|
15
|
-
| `init` | Inicializa estrutura IaC no projeto |
|
|
16
|
-
| `validate` | Valida templates Bicep |
|
|
17
|
-
| `plan` | Mostra what-if de mudanças |
|
|
18
|
-
| `deploy` | Executa deploy dos recursos |
|
|
19
|
-
| `destroy` | Remove todos os recursos |
|
|
20
|
-
|
|
21
|
-
---
|
|
22
|
-
|
|
23
|
-
## Workflow
|
|
24
|
-
|
|
25
|
-
### 1. INIT - Inicializar IaC
|
|
26
|
-
|
|
27
|
-
Quando o usuário solicitar `/morph-infra init`:
|
|
28
|
-
|
|
29
|
-
1. Criar estrutura `infra/` no projeto:
|
|
30
|
-
```
|
|
31
|
-
infra/
|
|
32
|
-
├── main.bicep
|
|
33
|
-
├── parameters.dev.json
|
|
34
|
-
├── parameters.prod.json
|
|
35
|
-
└── modules/
|
|
36
|
-
├── container-app.bicep
|
|
37
|
-
├── container-app-env.bicep
|
|
38
|
-
├── sql-database.bicep
|
|
39
|
-
├── storage.bicep
|
|
40
|
-
├── key-vault.bicep
|
|
41
|
-
└── app-insights.bicep
|
|
42
|
-
```
|
|
43
|
-
|
|
44
|
-
2. Copiar templates de `.morph/templates/infra/`
|
|
45
|
-
|
|
46
|
-
3. Substituir placeholders:
|
|
47
|
-
- `{{APP_NAME}}` → nome do projeto
|
|
48
|
-
- `{{SUBSCRIPTION_ID}}` → solicitar ao usuário
|
|
49
|
-
- `{{RESOURCE_GROUP}}` → sugerir padrão `rg-{app}-{env}`
|
|
50
|
-
|
|
51
|
-
4. Documentar no `decisions.md` a estrutura criada
|
|
52
|
-
|
|
53
|
-
---
|
|
54
|
-
|
|
55
|
-
### 2. VALIDATE - Validar Templates
|
|
56
|
-
|
|
57
|
-
Quando o usuário solicitar `/morph-infra validate`:
|
|
58
|
-
|
|
59
|
-
1. Executar validação Bicep:
|
|
60
|
-
```bash
|
|
61
|
-
az bicep build --file infra/main.bicep
|
|
62
|
-
```
|
|
63
|
-
|
|
64
|
-
2. Verificar parâmetros necessários
|
|
65
|
-
|
|
66
|
-
3. Reportar erros ou sucesso
|
|
67
|
-
|
|
68
|
-
---
|
|
69
|
-
|
|
70
|
-
### 3. PLAN - Preview de Mudanças
|
|
71
|
-
|
|
72
|
-
Quando o usuário solicitar `/morph-infra plan [env]`:
|
|
73
|
-
|
|
74
|
-
1. Verificar se Azure CLI está autenticado:
|
|
75
|
-
```bash
|
|
76
|
-
az account show
|
|
77
|
-
```
|
|
78
|
-
|
|
79
|
-
2. Executar what-if:
|
|
80
|
-
```bash
|
|
81
|
-
az deployment group what-if \
|
|
82
|
-
--resource-group rg-{app}-{env} \
|
|
83
|
-
--template-file infra/main.bicep \
|
|
84
|
-
--parameters @infra/parameters.{env}.json
|
|
85
|
-
```
|
|
86
|
-
|
|
87
|
-
3. Apresentar resumo de mudanças:
|
|
88
|
-
- Recursos a criar
|
|
89
|
-
- Recursos a modificar
|
|
90
|
-
- Recursos a deletar
|
|
91
|
-
- Custos estimados
|
|
92
|
-
|
|
93
|
-
4. ⛔ **PARE e aguarde aprovação** para deploy
|
|
94
|
-
|
|
95
|
-
---
|
|
96
|
-
|
|
97
|
-
### 4. DEPLOY - Executar Deploy
|
|
98
|
-
|
|
99
|
-
Quando o usuário solicitar `/morph-infra deploy [env]`:
|
|
100
|
-
|
|
101
|
-
1. Verificar aprovação do plan
|
|
102
|
-
|
|
103
|
-
2. Criar resource group se não existir:
|
|
104
|
-
```bash
|
|
105
|
-
az group create --name rg-{app}-{env} --location brazilsouth
|
|
106
|
-
```
|
|
107
|
-
|
|
108
|
-
3. Executar deploy:
|
|
109
|
-
```bash
|
|
110
|
-
az deployment group create \
|
|
111
|
-
--resource-group rg-{app}-{env} \
|
|
112
|
-
--template-file infra/main.bicep \
|
|
113
|
-
--parameters @infra/parameters.{env}.json
|
|
114
|
-
```
|
|
115
|
-
|
|
116
|
-
4. Capturar outputs:
|
|
117
|
-
- Container App URL
|
|
118
|
-
- SQL Connection String
|
|
119
|
-
- Key Vault URI
|
|
120
|
-
|
|
121
|
-
5. Atualizar documentação com informações do deploy
|
|
122
|
-
|
|
123
|
-
---
|
|
124
|
-
|
|
125
|
-
### 5. DESTROY - Remover Recursos
|
|
126
|
-
|
|
127
|
-
Quando o usuário solicitar `/morph-infra destroy [env]`:
|
|
128
|
-
|
|
129
|
-
1. ⚠️ **ALERTAR** que esta ação é irreversível
|
|
130
|
-
|
|
131
|
-
2. Listar recursos que serão deletados
|
|
132
|
-
|
|
133
|
-
3. ⛔ **PARE e aguarde confirmação explícita** ("sim, deletar")
|
|
134
|
-
|
|
135
|
-
4. Executar:
|
|
136
|
-
```bash
|
|
137
|
-
az group delete --name rg-{app}-{env} --yes --no-wait
|
|
138
|
-
```
|
|
139
|
-
|
|
140
|
-
---
|
|
141
|
-
|
|
142
|
-
## Regras de Segurança
|
|
143
|
-
|
|
144
|
-
### NUNCA:
|
|
145
|
-
- Expor secrets em logs
|
|
146
|
-
- Commitar arquivos com secrets
|
|
147
|
-
- Deletar recursos de produção sem confirmação explícita
|
|
148
|
-
- Criar recursos fora do Bicep (zero portal)
|
|
149
|
-
|
|
150
|
-
### SEMPRE:
|
|
151
|
-
- Usar Key Vault para secrets
|
|
152
|
-
- Validar Bicep antes de deploy
|
|
153
|
-
- Executar what-if antes de deploy
|
|
154
|
-
- Documentar custos estimados
|
|
155
|
-
- Manter parameters.json separados por ambiente
|
|
156
|
-
|
|
157
|
-
---
|
|
158
|
-
|
|
159
|
-
## Cost Guardian Integration
|
|
160
|
-
|
|
161
|
-
Antes de qualquer deploy, verificar com Cost Guardian:
|
|
162
|
-
|
|
163
|
-
1. Estimar custos mensais dos recursos
|
|
164
|
-
2. Verificar se está dentro dos limites aprovados:
|
|
165
|
-
- Free tier: sem aprovação
|
|
166
|
-
- Até $10/mês: requer confirmação
|
|
167
|
-
- Acima de $10: requer ADR
|
|
168
|
-
|
|
169
|
-
---
|
|
170
|
-
|
|
171
|
-
## Exemplo de Uso
|
|
172
|
-
|
|
173
|
-
```
|
|
174
|
-
Usuário: /morph-infra init
|
|
175
|
-
Claude: Criando estrutura IaC...
|
|
176
|
-
- infra/main.bicep
|
|
177
|
-
- infra/parameters.dev.json
|
|
178
|
-
- infra/modules/*.bicep
|
|
179
|
-
Pronto! Execute /morph-infra validate para verificar.
|
|
180
|
-
|
|
181
|
-
Usuário: /morph-infra plan dev
|
|
182
|
-
Claude: Analisando mudanças para ambiente dev...
|
|
183
|
-
|
|
184
|
-
CRIAR:
|
|
185
|
-
+ Container App Environment
|
|
186
|
-
+ Container App
|
|
187
|
-
+ SQL Server (Free)
|
|
188
|
-
+ Storage Account (LRS)
|
|
189
|
-
+ Key Vault
|
|
190
|
-
+ Application Insights
|
|
191
|
-
|
|
192
|
-
CUSTO ESTIMADO: ~$0/mês (Free tier)
|
|
193
|
-
|
|
194
|
-
Aprovar deploy? (sim/não)
|
|
195
|
-
|
|
196
|
-
Usuário: sim
|
|
197
|
-
Claude: Executando deploy...
|
|
198
|
-
✓ Resource Group criado
|
|
199
|
-
✓ Deploy concluído em 3m 45s
|
|
200
|
-
|
|
201
|
-
OUTPUTS:
|
|
202
|
-
- URL: https://myapp-dev.azurecontainerapps.io
|
|
203
|
-
- SQL: tcp:myapp-dev-sql.database.windows.net
|
|
204
|
-
- Key Vault: https://myapp-dev-kv.vault.azure.net
|
|
205
|
-
```
|
|
206
|
-
|
|
207
|
-
---
|
|
208
|
-
|
|
209
|
-
*MORPH-SPEC by Polymorphism Tech*
|
|
1
|
+
# /morph-infra - Infrastructure Management
|
|
2
|
+
|
|
3
|
+
Gerencia infraestrutura Azure usando Bicep templates.
|
|
4
|
+
|
|
5
|
+
## Uso
|
|
6
|
+
|
|
7
|
+
```
|
|
8
|
+
/morph-infra [action] [options]
|
|
9
|
+
```
|
|
10
|
+
|
|
11
|
+
### Actions
|
|
12
|
+
|
|
13
|
+
| Action | Descrição |
|
|
14
|
+
|--------|-----------|
|
|
15
|
+
| `init` | Inicializa estrutura IaC no projeto |
|
|
16
|
+
| `validate` | Valida templates Bicep |
|
|
17
|
+
| `plan` | Mostra what-if de mudanças |
|
|
18
|
+
| `deploy` | Executa deploy dos recursos |
|
|
19
|
+
| `destroy` | Remove todos os recursos |
|
|
20
|
+
|
|
21
|
+
---
|
|
22
|
+
|
|
23
|
+
## Workflow
|
|
24
|
+
|
|
25
|
+
### 1. INIT - Inicializar IaC
|
|
26
|
+
|
|
27
|
+
Quando o usuário solicitar `/morph-infra init`:
|
|
28
|
+
|
|
29
|
+
1. Criar estrutura `infra/` no projeto:
|
|
30
|
+
```
|
|
31
|
+
infra/
|
|
32
|
+
├── main.bicep
|
|
33
|
+
├── parameters.dev.json
|
|
34
|
+
├── parameters.prod.json
|
|
35
|
+
└── modules/
|
|
36
|
+
├── container-app.bicep
|
|
37
|
+
├── container-app-env.bicep
|
|
38
|
+
├── sql-database.bicep
|
|
39
|
+
├── storage.bicep
|
|
40
|
+
├── key-vault.bicep
|
|
41
|
+
└── app-insights.bicep
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
2. Copiar templates de `.morph/templates/infra/`
|
|
45
|
+
|
|
46
|
+
3. Substituir placeholders:
|
|
47
|
+
- `{{APP_NAME}}` → nome do projeto
|
|
48
|
+
- `{{SUBSCRIPTION_ID}}` → solicitar ao usuário
|
|
49
|
+
- `{{RESOURCE_GROUP}}` → sugerir padrão `rg-{app}-{env}`
|
|
50
|
+
|
|
51
|
+
4. Documentar no `decisions.md` a estrutura criada
|
|
52
|
+
|
|
53
|
+
---
|
|
54
|
+
|
|
55
|
+
### 2. VALIDATE - Validar Templates
|
|
56
|
+
|
|
57
|
+
Quando o usuário solicitar `/morph-infra validate`:
|
|
58
|
+
|
|
59
|
+
1. Executar validação Bicep:
|
|
60
|
+
```bash
|
|
61
|
+
az bicep build --file infra/main.bicep
|
|
62
|
+
```
|
|
63
|
+
|
|
64
|
+
2. Verificar parâmetros necessários
|
|
65
|
+
|
|
66
|
+
3. Reportar erros ou sucesso
|
|
67
|
+
|
|
68
|
+
---
|
|
69
|
+
|
|
70
|
+
### 3. PLAN - Preview de Mudanças
|
|
71
|
+
|
|
72
|
+
Quando o usuário solicitar `/morph-infra plan [env]`:
|
|
73
|
+
|
|
74
|
+
1. Verificar se Azure CLI está autenticado:
|
|
75
|
+
```bash
|
|
76
|
+
az account show
|
|
77
|
+
```
|
|
78
|
+
|
|
79
|
+
2. Executar what-if:
|
|
80
|
+
```bash
|
|
81
|
+
az deployment group what-if \
|
|
82
|
+
--resource-group rg-{app}-{env} \
|
|
83
|
+
--template-file infra/main.bicep \
|
|
84
|
+
--parameters @infra/parameters.{env}.json
|
|
85
|
+
```
|
|
86
|
+
|
|
87
|
+
3. Apresentar resumo de mudanças:
|
|
88
|
+
- Recursos a criar
|
|
89
|
+
- Recursos a modificar
|
|
90
|
+
- Recursos a deletar
|
|
91
|
+
- Custos estimados
|
|
92
|
+
|
|
93
|
+
4. ⛔ **PARE e aguarde aprovação** para deploy
|
|
94
|
+
|
|
95
|
+
---
|
|
96
|
+
|
|
97
|
+
### 4. DEPLOY - Executar Deploy
|
|
98
|
+
|
|
99
|
+
Quando o usuário solicitar `/morph-infra deploy [env]`:
|
|
100
|
+
|
|
101
|
+
1. Verificar aprovação do plan
|
|
102
|
+
|
|
103
|
+
2. Criar resource group se não existir:
|
|
104
|
+
```bash
|
|
105
|
+
az group create --name rg-{app}-{env} --location brazilsouth
|
|
106
|
+
```
|
|
107
|
+
|
|
108
|
+
3. Executar deploy:
|
|
109
|
+
```bash
|
|
110
|
+
az deployment group create \
|
|
111
|
+
--resource-group rg-{app}-{env} \
|
|
112
|
+
--template-file infra/main.bicep \
|
|
113
|
+
--parameters @infra/parameters.{env}.json
|
|
114
|
+
```
|
|
115
|
+
|
|
116
|
+
4. Capturar outputs:
|
|
117
|
+
- Container App URL
|
|
118
|
+
- SQL Connection String
|
|
119
|
+
- Key Vault URI
|
|
120
|
+
|
|
121
|
+
5. Atualizar documentação com informações do deploy
|
|
122
|
+
|
|
123
|
+
---
|
|
124
|
+
|
|
125
|
+
### 5. DESTROY - Remover Recursos
|
|
126
|
+
|
|
127
|
+
Quando o usuário solicitar `/morph-infra destroy [env]`:
|
|
128
|
+
|
|
129
|
+
1. ⚠️ **ALERTAR** que esta ação é irreversível
|
|
130
|
+
|
|
131
|
+
2. Listar recursos que serão deletados
|
|
132
|
+
|
|
133
|
+
3. ⛔ **PARE e aguarde confirmação explícita** ("sim, deletar")
|
|
134
|
+
|
|
135
|
+
4. Executar:
|
|
136
|
+
```bash
|
|
137
|
+
az group delete --name rg-{app}-{env} --yes --no-wait
|
|
138
|
+
```
|
|
139
|
+
|
|
140
|
+
---
|
|
141
|
+
|
|
142
|
+
## Regras de Segurança
|
|
143
|
+
|
|
144
|
+
### NUNCA:
|
|
145
|
+
- Expor secrets em logs
|
|
146
|
+
- Commitar arquivos com secrets
|
|
147
|
+
- Deletar recursos de produção sem confirmação explícita
|
|
148
|
+
- Criar recursos fora do Bicep (zero portal)
|
|
149
|
+
|
|
150
|
+
### SEMPRE:
|
|
151
|
+
- Usar Key Vault para secrets
|
|
152
|
+
- Validar Bicep antes de deploy
|
|
153
|
+
- Executar what-if antes de deploy
|
|
154
|
+
- Documentar custos estimados
|
|
155
|
+
- Manter parameters.json separados por ambiente
|
|
156
|
+
|
|
157
|
+
---
|
|
158
|
+
|
|
159
|
+
## Cost Guardian Integration
|
|
160
|
+
|
|
161
|
+
Antes de qualquer deploy, verificar com Cost Guardian:
|
|
162
|
+
|
|
163
|
+
1. Estimar custos mensais dos recursos
|
|
164
|
+
2. Verificar se está dentro dos limites aprovados:
|
|
165
|
+
- Free tier: sem aprovação
|
|
166
|
+
- Até $10/mês: requer confirmação
|
|
167
|
+
- Acima de $10: requer ADR
|
|
168
|
+
|
|
169
|
+
---
|
|
170
|
+
|
|
171
|
+
## Exemplo de Uso
|
|
172
|
+
|
|
173
|
+
```
|
|
174
|
+
Usuário: /morph-infra init
|
|
175
|
+
Claude: Criando estrutura IaC...
|
|
176
|
+
- infra/main.bicep
|
|
177
|
+
- infra/parameters.dev.json
|
|
178
|
+
- infra/modules/*.bicep
|
|
179
|
+
Pronto! Execute /morph-infra validate para verificar.
|
|
180
|
+
|
|
181
|
+
Usuário: /morph-infra plan dev
|
|
182
|
+
Claude: Analisando mudanças para ambiente dev...
|
|
183
|
+
|
|
184
|
+
CRIAR:
|
|
185
|
+
+ Container App Environment
|
|
186
|
+
+ Container App
|
|
187
|
+
+ SQL Server (Free)
|
|
188
|
+
+ Storage Account (LRS)
|
|
189
|
+
+ Key Vault
|
|
190
|
+
+ Application Insights
|
|
191
|
+
|
|
192
|
+
CUSTO ESTIMADO: ~$0/mês (Free tier)
|
|
193
|
+
|
|
194
|
+
Aprovar deploy? (sim/não)
|
|
195
|
+
|
|
196
|
+
Usuário: sim
|
|
197
|
+
Claude: Executando deploy...
|
|
198
|
+
✓ Resource Group criado
|
|
199
|
+
✓ Deploy concluído em 3m 45s
|
|
200
|
+
|
|
201
|
+
OUTPUTS:
|
|
202
|
+
- URL: https://myapp-dev.azurecontainerapps.io
|
|
203
|
+
- SQL: tcp:myapp-dev-sql.database.windows.net
|
|
204
|
+
- Key Vault: https://myapp-dev-kv.vault.azure.net
|
|
205
|
+
```
|
|
206
|
+
|
|
207
|
+
---
|
|
208
|
+
|
|
209
|
+
*MORPH-SPEC by Polymorphism Tech*
|
|
@@ -0,0 +1,227 @@
|
|
|
1
|
+
# Pre-Flight Check for Azure Deployment
|
|
2
|
+
|
|
3
|
+
Validates project readiness before deploying to Azure.
|
|
4
|
+
|
|
5
|
+
## Uso
|
|
6
|
+
|
|
7
|
+
```
|
|
8
|
+
/morph-preflight azure
|
|
9
|
+
```
|
|
10
|
+
|
|
11
|
+
## Objetivo
|
|
12
|
+
|
|
13
|
+
Detectar problemas **antes** do deploy que causariam falhas em produção. Economiza tempo e evita debugging em ambiente Azure.
|
|
14
|
+
|
|
15
|
+
---
|
|
16
|
+
|
|
17
|
+
## Validações Executadas
|
|
18
|
+
|
|
19
|
+
### 1. Package Version Conflicts
|
|
20
|
+
|
|
21
|
+
**O que verifica:**
|
|
22
|
+
- `Azure.Identity` especificado explicitamente
|
|
23
|
+
- Sem conflitos de versão (NU1605, NU1608)
|
|
24
|
+
- Packages críticos com versões compatíveis
|
|
25
|
+
|
|
26
|
+
**Como verificar:**
|
|
27
|
+
```bash
|
|
28
|
+
dotnet restore --verbosity normal 2>&1 | grep -E "(NU1605|NU1608|warning)"
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
**Fix comum:**
|
|
32
|
+
```xml
|
|
33
|
+
<PackageReference Include="Azure.Identity" Version="1.14.2" />
|
|
34
|
+
```
|
|
35
|
+
|
|
36
|
+
---
|
|
37
|
+
|
|
38
|
+
### 2. EF Core Migrations
|
|
39
|
+
|
|
40
|
+
**O que verifica:**
|
|
41
|
+
- Sem pending model changes
|
|
42
|
+
- Migrations aplicáveis existem
|
|
43
|
+
- Migration scripts são válidos
|
|
44
|
+
|
|
45
|
+
**Como verificar:**
|
|
46
|
+
```bash
|
|
47
|
+
dotnet ef migrations has-pending-model-changes \
|
|
48
|
+
--project src/Infrastructure \
|
|
49
|
+
--startup-project src/Web
|
|
50
|
+
```
|
|
51
|
+
|
|
52
|
+
**Fix comum:**
|
|
53
|
+
```bash
|
|
54
|
+
dotnet ef migrations add <MigrationName> \
|
|
55
|
+
--project src/Infrastructure \
|
|
56
|
+
--startup-project src/Web
|
|
57
|
+
```
|
|
58
|
+
|
|
59
|
+
---
|
|
60
|
+
|
|
61
|
+
### 3. Dockerfile Validation (se Container Apps)
|
|
62
|
+
|
|
63
|
+
**O que verifica:**
|
|
64
|
+
- Dockerfile existe
|
|
65
|
+
- Base image é válida
|
|
66
|
+
- Multi-stage build configurado
|
|
67
|
+
- EXPOSE ports corretos
|
|
68
|
+
- ENTRYPOINT definido
|
|
69
|
+
|
|
70
|
+
**Como verificar:**
|
|
71
|
+
```bash
|
|
72
|
+
docker build --check .
|
|
73
|
+
# Ou validação manual do Dockerfile
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
---
|
|
77
|
+
|
|
78
|
+
### 4. Blazor .NET 10 Assets
|
|
79
|
+
|
|
80
|
+
**O que verifica:**
|
|
81
|
+
- `RequiresAspNetWebAssets` está `true` (se Blazor + .NET 10)
|
|
82
|
+
- Static web assets configurados corretamente
|
|
83
|
+
|
|
84
|
+
**Como verificar:**
|
|
85
|
+
```bash
|
|
86
|
+
grep -r "RequiresAspNetWebAssets" *.csproj
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
**Fix:**
|
|
90
|
+
```xml
|
|
91
|
+
<PropertyGroup>
|
|
92
|
+
<RequiresAspNetWebAssets>true</RequiresAspNetWebAssets>
|
|
93
|
+
</PropertyGroup>
|
|
94
|
+
```
|
|
95
|
+
|
|
96
|
+
---
|
|
97
|
+
|
|
98
|
+
### 5. Bicep Syntax Validation
|
|
99
|
+
|
|
100
|
+
**O que verifica:**
|
|
101
|
+
- Arquivos `.bicep` sem erros de sintaxe
|
|
102
|
+
- Parâmetros obrigatórios definidos
|
|
103
|
+
- Resources com nomes válidos
|
|
104
|
+
|
|
105
|
+
**Como verificar:**
|
|
106
|
+
```bash
|
|
107
|
+
az bicep build --file infra/main.bicep --stdout > /dev/null
|
|
108
|
+
```
|
|
109
|
+
|
|
110
|
+
---
|
|
111
|
+
|
|
112
|
+
### 6. Key Vault Configuration
|
|
113
|
+
|
|
114
|
+
**O que verifica:**
|
|
115
|
+
- Key Vault URI configurado em `appsettings.json` ou environment
|
|
116
|
+
- Não condiciona Key Vault ao ambiente (bug comum)
|
|
117
|
+
- Managed Identity habilitada
|
|
118
|
+
|
|
119
|
+
**Como verificar:**
|
|
120
|
+
```bash
|
|
121
|
+
grep -r "KeyVaultUri\|AzureKeyVault" appsettings*.json
|
|
122
|
+
grep -r "IsDevelopment()" Program.cs | grep -i keyvault
|
|
123
|
+
```
|
|
124
|
+
|
|
125
|
+
**Anti-pattern a detectar:**
|
|
126
|
+
```csharp
|
|
127
|
+
// ❌ ERRADO - Não carrega Key Vault em dev!
|
|
128
|
+
if (!builder.Environment.IsDevelopment())
|
|
129
|
+
{
|
|
130
|
+
builder.Configuration.AddAzureKeyVault(...);
|
|
131
|
+
}
|
|
132
|
+
```
|
|
133
|
+
|
|
134
|
+
---
|
|
135
|
+
|
|
136
|
+
### 7. Connection Strings Security
|
|
137
|
+
|
|
138
|
+
**O que verifica:**
|
|
139
|
+
- Connection strings não hardcoded em código
|
|
140
|
+
- Secrets em Key Vault ou User Secrets
|
|
141
|
+
- Sem credentials em `appsettings.json` (exceto Development)
|
|
142
|
+
|
|
143
|
+
**Como verificar:**
|
|
144
|
+
```bash
|
|
145
|
+
# Detectar passwords em appsettings
|
|
146
|
+
grep -rE "(Password=|Pwd=|Secret=)" appsettings*.json | grep -v Development
|
|
147
|
+
```
|
|
148
|
+
|
|
149
|
+
---
|
|
150
|
+
|
|
151
|
+
## Output Exemplo
|
|
152
|
+
|
|
153
|
+
```
|
|
154
|
+
🔍 MORPH Pre-Flight Check: Azure Deployment
|
|
155
|
+
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
156
|
+
|
|
157
|
+
✅ Packages: No version conflicts detected
|
|
158
|
+
✅ Migrations: No pending model changes
|
|
159
|
+
✅ Dockerfile: Valid multi-stage build
|
|
160
|
+
✅ Blazor Assets: RequiresAspNetWebAssets=true
|
|
161
|
+
✅ Bicep: Syntax valid
|
|
162
|
+
❌ Key Vault: URI not configured in appsettings.Production.json
|
|
163
|
+
⚠️ Connection Strings: Found password in appsettings.Staging.json
|
|
164
|
+
|
|
165
|
+
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
166
|
+
|
|
167
|
+
📋 Summary: 5 passed, 1 failed, 1 warning
|
|
168
|
+
|
|
169
|
+
❌ BLOCKED: Fix Key Vault configuration before deploy!
|
|
170
|
+
|
|
171
|
+
Recommended fixes:
|
|
172
|
+
1. Add KeyVaultUri to appsettings.Production.json
|
|
173
|
+
2. Move password from appsettings.Staging.json to Key Vault
|
|
174
|
+
```
|
|
175
|
+
|
|
176
|
+
---
|
|
177
|
+
|
|
178
|
+
## Workflow de Uso
|
|
179
|
+
|
|
180
|
+
### Antes de criar PR para produção
|
|
181
|
+
|
|
182
|
+
```bash
|
|
183
|
+
/morph-preflight azure
|
|
184
|
+
```
|
|
185
|
+
|
|
186
|
+
### No pipeline CI/CD
|
|
187
|
+
|
|
188
|
+
```yaml
|
|
189
|
+
- script: |
|
|
190
|
+
# Package check
|
|
191
|
+
dotnet restore 2>&1 | grep -E "NU1605|NU1608" && exit 1
|
|
192
|
+
|
|
193
|
+
# Migration check
|
|
194
|
+
dotnet ef migrations has-pending-model-changes \
|
|
195
|
+
--project src/Infrastructure \
|
|
196
|
+
--startup-project src/Web
|
|
197
|
+
if [ $? -ne 0 ]; then exit 1; fi
|
|
198
|
+
|
|
199
|
+
# Bicep check
|
|
200
|
+
az bicep build --file infra/main.bicep --stdout > /dev/null
|
|
201
|
+
if [ $? -ne 0 ]; then exit 1; fi
|
|
202
|
+
|
|
203
|
+
echo "Pre-flight checks passed!"
|
|
204
|
+
displayName: 'Pre-flight validation'
|
|
205
|
+
```
|
|
206
|
+
|
|
207
|
+
---
|
|
208
|
+
|
|
209
|
+
## Validações Futuras (Roadmap)
|
|
210
|
+
|
|
211
|
+
- [ ] Cost estimation validation (dentro do budget)
|
|
212
|
+
- [ ] RBAC permissions check
|
|
213
|
+
- [ ] Network security rules validation
|
|
214
|
+
- [ ] Health probe endpoint exists
|
|
215
|
+
- [ ] Application Insights configured
|
|
216
|
+
|
|
217
|
+
---
|
|
218
|
+
|
|
219
|
+
## Referências
|
|
220
|
+
|
|
221
|
+
- [azure.md](../../standards/azure.md) - Padrões Azure
|
|
222
|
+
- [dotnet10-migration.md](../../standards/dotnet10-migration.md) - Breaking changes .NET 10
|
|
223
|
+
- [blazor-efcore.md](../../../../framework/standards/blazor-efcore.md) - EF Core patterns
|
|
224
|
+
|
|
225
|
+
---
|
|
226
|
+
|
|
227
|
+
*MORPH-SPEC by Polymorphism Tech*
|