@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
@@ -1,454 +1,454 @@
1
- # Azure DevOps Setup - Workload Identity Federation
2
-
3
- > **MORPH-SPEC Framework**
4
- > Configuração de CI/CD com autenticação moderna (sem secrets)
5
-
6
- ---
7
-
8
- ## 📋 Índice
9
-
10
- 1. [Pré-requisitos](#pré-requisitos)
11
- 2. [Configurar Workload Identity Federation](#configurar-workload-identity-federation)
12
- 3. [Criar Service Connections](#criar-service-connections)
13
- 4. [Configurar Pipelines](#configurar-pipelines)
14
- 5. [Configurar Environments e Aprovações](#configurar-environments-e-aprovações)
15
- 6. [Troubleshooting](#troubleshooting)
16
-
17
- ---
18
-
19
- ## 🔑 Pré-requisitos
20
-
21
- ### Azure
22
- - ✅ Subscription Azure ativa
23
- - ✅ Permissões de Owner ou User Access Administrator na subscription
24
- - ✅ Azure CLI instalado: https://aka.ms/azure-cli
25
-
26
- ### Azure DevOps
27
- - ✅ Organização Azure DevOps criada
28
- - ✅ Projeto criado
29
- - ✅ Permissões de administrador do projeto
30
-
31
- ###Informações Necessárias
32
- ```bash
33
- # Azure
34
- SUBSCRIPTION_ID="<sua-subscription-id>"
35
- TENANT_ID="<seu-tenant-id>"
36
-
37
- # Azure DevOps
38
- ADO_ORG="<sua-org>" # Ex: polymorphismtech
39
- ADO_PROJECT="<seu-projeto>" # Ex: morph-app
40
-
41
- # Application
42
- APP_NAME="<nome-da-app>" # Ex: myapp
43
- ```
44
-
45
- ---
46
-
47
- ## 🌐 Configurar Workload Identity Federation
48
-
49
- ### Passo 1: Criar App Registration
50
-
51
- ```bash
52
- # Login no Azure
53
- az login
54
- az account set --subscription $SUBSCRIPTION_ID
55
-
56
- # Criar App Registration para Dev
57
- APP_DEV_NAME="${APP_NAME}-dev-pipeline"
58
- APP_DEV_ID=$(az ad app create \
59
- --display-name "$APP_DEV_NAME" \
60
- --query appId -o tsv)
61
-
62
- echo "Dev App ID: $APP_DEV_ID"
63
-
64
- # Criar Service Principal
65
- SP_DEV_ID=$(az ad sp create \
66
- --id $APP_DEV_ID \
67
- --query id -o tsv)
68
-
69
- echo "Dev Service Principal ID: $SP_DEV_ID"
70
-
71
- # Repetir para Staging e Prod
72
- APP_STAGING_NAME="${APP_NAME}-staging-pipeline"
73
- APP_STAGING_ID=$(az ad app create --display-name "$APP_STAGING_NAME" --query appId -o tsv)
74
- SP_STAGING_ID=$(az ad sp create --id $APP_STAGING_ID --query id -o tsv)
75
-
76
- APP_PROD_NAME="${APP_NAME}-prod-pipeline"
77
- APP_PROD_ID=$(az ad app create --display-name "$APP_PROD_NAME" --query appId -o tsv)
78
- SP_PROD_ID=$(az ad sp create --id $APP_PROD_ID --query id -o tsv)
79
- ```
80
-
81
- ### Passo 2: Configurar Federated Credentials
82
-
83
- ```bash
84
- # DEV Environment
85
- cat <<EOF > federated-credential-dev.json
86
- {
87
- "name": "dev-pipeline-federated",
88
- "issuer": "https://vstoken.dev.azure.com/<ADO_ORG_ID>",
89
- "subject": "sc://$ADO_ORG/$ADO_PROJECT/Azure-Dev-Connection",
90
- "description": "Federated credential for dev pipeline",
91
- "audiences": [
92
- "api://AzureADTokenExchange"
93
- ]
94
- }
95
- EOF
96
-
97
- az ad app federated-credential create \
98
- --id $APP_DEV_ID \
99
- --parameters federated-credential-dev.json
100
-
101
- # STAGING Environment
102
- cat <<EOF > federated-credential-staging.json
103
- {
104
- "name": "staging-pipeline-federated",
105
- "issuer": "https://vstoken.dev.azure.com/<ADO_ORG_ID>",
106
- "subject": "sc://$ADO_ORG/$ADO_PROJECT/Azure-Staging-Connection",
107
- "description": "Federated credential for staging pipeline",
108
- "audiences": [
109
- "api://AzureADTokenExchange"
110
- ]
111
- }
112
- EOF
113
-
114
- az ad app federated-credential create \
115
- --id $APP_STAGING_ID \
116
- --parameters federated-credential-staging.json
117
-
118
- # PROD Environment
119
- cat <<EOF > federated-credential-prod.json
120
- {
121
- "name": "prod-pipeline-federated",
122
- "issuer": "https://vstoken.dev.azure.com/<ADO_ORG_ID>",
123
- "subject": "sc://$ADO_ORG/$ADO_PROJECT/Azure-Prod-Connection",
124
- "description": "Federated credential for prod pipeline",
125
- "audiences": [
126
- "api://AzureADTokenExchange"
127
- ]
128
- }
129
- EOF
130
-
131
- az ad app federated-credential create \
132
- --id $APP_PROD_ID \
133
- --parameters federated-credential-prod.json
134
- ```
135
-
136
- **📌 Como obter ADO_ORG_ID:**
137
- ```bash
138
- # Via Azure DevOps UI
139
- # Vá em: Organization Settings → Overview → Organization ID
140
- # Ou via API:
141
- curl -u ":${AZURE_DEVOPS_PAT}" \
142
- "https://dev.azure.com/${ADO_ORG}/_apis/connectionData"
143
- ```
144
-
145
- ### Passo 3: Atribuir Permissões Azure
146
-
147
- ```bash
148
- # DEV - Contributor na resource group
149
- RG_DEV="rg-${APP_NAME}-dev"
150
- az role assignment create \
151
- --assignee $SP_DEV_ID \
152
- --role Contributor \
153
- --scope "/subscriptions/$SUBSCRIPTION_ID/resourceGroups/$RG_DEV"
154
-
155
- # STAGING - Contributor na resource group
156
- RG_STAGING="rg-${APP_NAME}-staging"
157
- az role assignment create \
158
- --assignee $SP_STAGING_ID \
159
- --role Contributor \
160
- --scope "/subscriptions/$SUBSCRIPTION_ID/resourceGroups/$RG_STAGING"
161
-
162
- # PROD - Contributor na resource group
163
- RG_PROD="rg-${APP_NAME}-prod"
164
- az role assignment create \
165
- --assignee $SP_PROD_ID \
166
- --role Contributor \
167
- --scope "/subscriptions/$SUBSCRIPTION_ID/resourceGroups/$RG_PROD"
168
-
169
- # ACR - AcrPush para todos
170
- ACR_ID="/subscriptions/$SUBSCRIPTION_ID/resourceGroups/<rg-acr>/providers/Microsoft.ContainerRegistry/registries/<acr-name>"
171
-
172
- az role assignment create --assignee $SP_DEV_ID --role AcrPush --scope $ACR_ID
173
- az role assignment create --assignee $SP_STAGING_ID --role AcrPush --scope $ACR_ID
174
- az role assignment create --assignee $SP_PROD_ID --role AcrPush --scope $ACR_ID
175
- ```
176
-
177
- ---
178
-
179
- ## 🔗 Criar Service Connections
180
-
181
- ### Via Azure DevOps UI
182
-
183
- #### 1. Service Connection para Azure (Dev)
184
-
185
- 1. Vá em: **Project Settings** → **Service connections** → **New service connection**
186
- 2. Selecione: **Azure Resource Manager**
187
- 3. Authentication method: **Workload Identity federation (automatic)**
188
- 4. Scope level: **Subscription**
189
- 5. Preencha:
190
- - **Subscription ID**: `<sua-subscription-id>`
191
- - **Service connection name**: `Azure-Dev-Connection`
192
- - **Service Principal ID**: `$APP_DEV_ID` (do Passo 1)
193
- 6. Marque: **Grant access permission to all pipelines** (ou configure por pipeline)
194
- 7. Click: **Save**
195
-
196
- #### 2. Repetir para Staging e Prod
197
-
198
- - **Staging**: Nome `Azure-Staging-Connection`, usar `$APP_STAGING_ID`
199
- - **Prod**: Nome `Azure-Prod-Connection`, usar `$APP_PROD_ID`
200
-
201
- #### 3. Service Connection para ACR
202
-
203
- 1. **New service connection** → **Docker Registry**
204
- 2. Registry type: **Azure Container Registry**
205
- 3. Authentication type: **Workload Identity federation**
206
- 4. Preencha:
207
- - **Azure subscription**: Selecione a subscription
208
- - **Azure container registry**: Selecione seu ACR
209
- - **Service connection name**: `ACR-Connection`
210
- 5. **Save**
211
-
212
- ### Via Azure CLI (Alternativa)
213
-
214
- ```bash
215
- # Requer Azure DevOps extension
216
- az extension add --name azure-devops
217
-
218
- # Login
219
- az devops configure --defaults organization=https://dev.azure.com/$ADO_ORG project=$ADO_PROJECT
220
-
221
- # Criar service connection (exemplo simplificado)
222
- # Nota: Workload Identity via CLI é complexo, recomenda-se usar UI
223
- ```
224
-
225
- ---
226
-
227
- ## ⚙️ Configurar Pipelines
228
-
229
- ### Passo 1: Importar Pipelines
230
-
231
- 1. Vá em: **Pipelines** → **New pipeline**
232
- 2. Selecione: **Azure Repos Git** (ou seu SCM)
233
- 3. Selecione seu repositório
234
- 4. **Existing Azure Pipelines YAML file**
235
- 5. Path: `.azure/pipelines/dev-pipeline.yml`
236
- 6. **Continue** → **Save** (não run ainda)
237
-
238
- Repetir para:
239
- - `.azure/pipelines/staging-pipeline.yml`
240
- - `.azure/pipelines/prod-pipeline.yml`
241
-
242
- ### Passo 2: Configurar Variáveis
243
-
244
- #### Variáveis no Pipeline Level
245
-
246
- Para cada pipeline, adicione as variáveis:
247
-
248
- **Dev Pipeline** → **Edit** → **Variables**:
249
- ```
250
- ACR_NAME: <seu-acr-name>
251
- APP_NAME: <seu-app-name>
252
- SUBSCRIPTION_ID: <subscription-id>
253
- ```
254
-
255
- **Staging Pipeline** - mesmas variáveis
256
-
257
- **Prod Pipeline** - mesmas variáveis
258
-
259
- #### Variáveis no Group Level (Opcional)
260
-
261
- 1. **Pipelines** → **Library** → **+ Variable group**
262
- 2. Nome: `morph-common-vars`
263
- 3. Adicionar:
264
- ```
265
- ACR_NAME: <seu-acr>
266
- APP_NAME: <seu-app>
267
- SUBSCRIPTION_ID: <subscription-id>
268
- ```
269
- 4. Linkar aos pipelines:
270
- ```yaml
271
- variables:
272
- - group: morph-common-vars
273
- - template: pipeline-variables.yml
274
- ```
275
-
276
- ---
277
-
278
- ## 🛡️ Configurar Environments e Aprovações
279
-
280
- ### Passo 1: Criar Environments
281
-
282
- 1. **Pipelines** → **Environments** → **New environment**
283
- 2. Criar 3 environments:
284
-
285
- **Dev Environment:**
286
- - Name: `dev`
287
- - Resource: None
288
- - Approvals: **Nenhuma** (deploy automático)
289
-
290
- **Staging Environment:**
291
- - Name: `staging`
292
- - Resource: None
293
- - Approvals: **Opcional** (recomendado nenhuma para deploy rápido)
294
- - Se desejar: Add approver selecione você mesmo
295
- - Timeout: 24 hours
296
-
297
- **Production Environment:**
298
- - Name: `production`
299
- - Resource: None
300
- - Approvals: **OBRIGATÓRIO**
301
- - Add approvers: Selecione você mesmo
302
- - Timeout: 48 hours
303
- - **Checks**: Adicionar "Invoke REST API" para verificações adicionais (opcional)
304
-
305
- ### Passo 2: Configurar Branch Policies (Opcional)
306
-
307
- Para `main` branch:
308
-
309
- 1. **Repos** → **Branches** → `main` → **Branch policies**
310
- 2. Habilitar:
311
- - **Require a minimum number of reviewers**: 0 (self-review via approval gate)
312
- - **Check for linked work items**: Recommended
313
- - **Build validation**: Link prod pipeline
314
-
315
- ---
316
-
317
- ## 🧪 Testar Configuração
318
-
319
- ### Teste 1: Dev Pipeline
320
-
321
- ```bash
322
- # Criar branch develop
323
- git checkout -b develop
324
- git push origin develop
325
-
326
- # Fazer um commit qualquer
327
- echo "test" > test.txt
328
- git add test.txt
329
- git commit -m "test: trigger dev pipeline"
330
- git push origin develop
331
- ```
332
-
333
- **Verificar:**
334
- - Pipeline triggou automaticamente
335
- - Build passou
336
- - Deploy para App Service Free foi bem-sucedido
337
- - Health check passou
338
-
339
- ### Teste 2: Staging Pipeline
340
-
341
- ```bash
342
- # Merge develop em main
343
- git checkout main
344
- git merge develop
345
- git push origin main
346
- ```
347
-
348
- **Verificar:**
349
- - Staging pipeline triggou
350
- - Container foi buildado e pushed para ACR
351
- - Deploy para Container Apps funcionou
352
- - Integration tests passaram
353
-
354
- ### Teste 3: Prod Pipeline (Manual)
355
-
356
- 1. **Pipelines** → **prod-pipeline** → **Run pipeline**
357
- 2. Verificar aprovação manual aparece
358
- 3. Aprovar deploy
359
- 4. Verificar deployment bem-sucedido
360
-
361
- ---
362
-
363
- ## 🆘 Troubleshooting
364
-
365
- ### Erro: "Failed to get federated token"
366
-
367
- **Causa:** Subject no federated credential não match com service connection.
368
-
369
- **Solução:**
370
- ```bash
371
- # Verificar subject correto
372
- # Deve ser: sc://<ORG>/<PROJECT>/<SERVICE_CONNECTION_NAME>
373
-
374
- # Recriar federated credential com subject correto
375
- az ad app federated-credential delete \
376
- --id $APP_ID \
377
- --federated-credential-id <credential-id>
378
-
379
- # Criar novamente com subject correto
380
- az ad app federated-credential create \
381
- --id $APP_ID \
382
- --parameters federated-credential.json
383
- ```
384
-
385
- ### Erro: "Insufficient permissions"
386
-
387
- **Causa:** Service Principal não tem permissões na subscription/resource group.
388
-
389
- **Solução:**
390
- ```bash
391
- # Verificar role assignments
392
- az role assignment list \
393
- --assignee $SP_ID \
394
- --output table
395
-
396
- # Adicionar Contributor se necessário
397
- az role assignment create \
398
- --assignee $SP_ID \
399
- --role Contributor \
400
- --scope "/subscriptions/$SUBSCRIPTION_ID/resourceGroups/$RG_NAME"
401
- ```
402
-
403
- ### Erro: "Container registry not found"
404
-
405
- **Causa:** Service Principal não tem permissão no ACR.
406
-
407
- **Solução:**
408
- ```bash
409
- # Adicionar AcrPush role
410
- az role assignment create \
411
- --assignee $SP_ID \
412
- --role AcrPush \
413
- --scope $ACR_ID
414
- ```
415
-
416
- ### Erro: "Pipeline not authorized to access service connection"
417
-
418
- **Causa:** Pipeline não foi autorizado a usar a service connection.
419
-
420
- **Solução:**
421
- 1. **Project Settings** → **Service connections**
422
- 2. Click na service connection
423
- 3. **Security** → Adicionar pipeline específico ou marcar "Grant access to all pipelines"
424
-
425
- ---
426
-
427
- ## 📚 Referências
428
-
429
- - [Workload Identity Federation](https://learn.microsoft.com/azure/devops/pipelines/library/connect-to-azure)
430
- - [Azure Pipelines YAML Schema](https://learn.microsoft.com/azure/devops/pipelines/yaml-schema)
431
- - [Environments](https://learn.microsoft.com/azure/devops/pipelines/process/environments)
432
- - [Service Connections](https://learn.microsoft.com/azure/devops/pipelines/library/service-endpoints)
433
-
434
- ---
435
-
436
- ## ✅ Checklist Final
437
-
438
- Antes de ir para produção:
439
-
440
- - [ ] Workload Identity configurada para dev/staging/prod
441
- - [ ] Service connections criadas e testadas
442
- - [ ] Variáveis configuradas (ACR_NAME, APP_NAME, SUBSCRIPTION_ID)
443
- - [ ] Environments criados (dev, staging, production)
444
- - [ ] Aprovações configuradas (production requer aprovação manual)
445
- - [ ] Dev pipeline testado com sucesso
446
- - [ ] Staging pipeline testado com sucesso
447
- - [ ] Prod pipeline testado com aprovação
448
- - [ ] Health checks funcionando
449
- - [ ] Monitoring configurado (Application Insights)
450
- - [ ] Rollback plan documentado
451
-
452
- ---
453
-
454
- *MORPH-SPEC by Polymorphism Tech*
1
+ # Azure DevOps Setup - Workload Identity Federation
2
+
3
+ > **MORPH-SPEC Framework**
4
+ > Configuração de CI/CD com autenticação moderna (sem secrets)
5
+
6
+ ---
7
+
8
+ ## 📋 Índice
9
+
10
+ 1. [Pré-requisitos](#pré-requisitos)
11
+ 2. [Configurar Workload Identity Federation](#configurar-workload-identity-federation)
12
+ 3. [Criar Service Connections](#criar-service-connections)
13
+ 4. [Configurar Pipelines](#configurar-pipelines)
14
+ 5. [Configurar Environments e Aprovações](#configurar-environments-e-aprovações)
15
+ 6. [Troubleshooting](#troubleshooting)
16
+
17
+ ---
18
+
19
+ ## 🔑 Pré-requisitos
20
+
21
+ ### Azure
22
+ - ✅ Subscription Azure ativa
23
+ - ✅ Permissões de Owner ou User Access Administrator na subscription
24
+ - ✅ Azure CLI instalado: https://aka.ms/azure-cli
25
+
26
+ ### Azure DevOps
27
+ - ✅ Organização Azure DevOps criada
28
+ - ✅ Projeto criado
29
+ - ✅ Permissões de administrador do projeto
30
+
31
+ ###Informações Necessárias
32
+ ```bash
33
+ # Azure
34
+ SUBSCRIPTION_ID="<sua-subscription-id>"
35
+ TENANT_ID="<seu-tenant-id>"
36
+
37
+ # Azure DevOps
38
+ ADO_ORG="<sua-org>" # Ex: polymorphismtech
39
+ ADO_PROJECT="<seu-projeto>" # Ex: morph-app
40
+
41
+ # Application
42
+ APP_NAME="<nome-da-app>" # Ex: myapp
43
+ ```
44
+
45
+ ---
46
+
47
+ ## 🌐 Configurar Workload Identity Federation
48
+
49
+ ### Passo 1: Criar App Registration
50
+
51
+ ```bash
52
+ # Login no Azure
53
+ az login
54
+ az account set --subscription $SUBSCRIPTION_ID
55
+
56
+ # Criar App Registration para Dev
57
+ APP_DEV_NAME="${APP_NAME}-dev-pipeline"
58
+ APP_DEV_ID=$(az ad app create \
59
+ --display-name "$APP_DEV_NAME" \
60
+ --query appId -o tsv)
61
+
62
+ echo "Dev App ID: $APP_DEV_ID"
63
+
64
+ # Criar Service Principal
65
+ SP_DEV_ID=$(az ad sp create \
66
+ --id $APP_DEV_ID \
67
+ --query id -o tsv)
68
+
69
+ echo "Dev Service Principal ID: $SP_DEV_ID"
70
+
71
+ # Repetir para Staging e Prod
72
+ APP_STAGING_NAME="${APP_NAME}-staging-pipeline"
73
+ APP_STAGING_ID=$(az ad app create --display-name "$APP_STAGING_NAME" --query appId -o tsv)
74
+ SP_STAGING_ID=$(az ad sp create --id $APP_STAGING_ID --query id -o tsv)
75
+
76
+ APP_PROD_NAME="${APP_NAME}-prod-pipeline"
77
+ APP_PROD_ID=$(az ad app create --display-name "$APP_PROD_NAME" --query appId -o tsv)
78
+ SP_PROD_ID=$(az ad sp create --id $APP_PROD_ID --query id -o tsv)
79
+ ```
80
+
81
+ ### Passo 2: Configurar Federated Credentials
82
+
83
+ ```bash
84
+ # DEV Environment
85
+ cat <<EOF > federated-credential-dev.json
86
+ {
87
+ "name": "dev-pipeline-federated",
88
+ "issuer": "https://vstoken.dev.azure.com/<ADO_ORG_ID>",
89
+ "subject": "sc://$ADO_ORG/$ADO_PROJECT/Azure-Dev-Connection",
90
+ "description": "Federated credential for dev pipeline",
91
+ "audiences": [
92
+ "api://AzureADTokenExchange"
93
+ ]
94
+ }
95
+ EOF
96
+
97
+ az ad app federated-credential create \
98
+ --id $APP_DEV_ID \
99
+ --parameters federated-credential-dev.json
100
+
101
+ # STAGING Environment
102
+ cat <<EOF > federated-credential-staging.json
103
+ {
104
+ "name": "staging-pipeline-federated",
105
+ "issuer": "https://vstoken.dev.azure.com/<ADO_ORG_ID>",
106
+ "subject": "sc://$ADO_ORG/$ADO_PROJECT/Azure-Staging-Connection",
107
+ "description": "Federated credential for staging pipeline",
108
+ "audiences": [
109
+ "api://AzureADTokenExchange"
110
+ ]
111
+ }
112
+ EOF
113
+
114
+ az ad app federated-credential create \
115
+ --id $APP_STAGING_ID \
116
+ --parameters federated-credential-staging.json
117
+
118
+ # PROD Environment
119
+ cat <<EOF > federated-credential-prod.json
120
+ {
121
+ "name": "prod-pipeline-federated",
122
+ "issuer": "https://vstoken.dev.azure.com/<ADO_ORG_ID>",
123
+ "subject": "sc://$ADO_ORG/$ADO_PROJECT/Azure-Prod-Connection",
124
+ "description": "Federated credential for prod pipeline",
125
+ "audiences": [
126
+ "api://AzureADTokenExchange"
127
+ ]
128
+ }
129
+ EOF
130
+
131
+ az ad app federated-credential create \
132
+ --id $APP_PROD_ID \
133
+ --parameters federated-credential-prod.json
134
+ ```
135
+
136
+ **📌 Como obter ADO_ORG_ID:**
137
+ ```bash
138
+ # Via Azure DevOps UI
139
+ # Vá em: Organization Settings → Overview → Organization ID
140
+ # Ou via API:
141
+ curl -u ":${AZURE_DEVOPS_PAT}" \
142
+ "https://dev.azure.com/${ADO_ORG}/_apis/connectionData"
143
+ ```
144
+
145
+ ### Passo 3: Atribuir Permissões Azure
146
+
147
+ ```bash
148
+ # DEV - Contributor na resource group
149
+ RG_DEV="rg-${APP_NAME}-dev"
150
+ az role assignment create \
151
+ --assignee $SP_DEV_ID \
152
+ --role Contributor \
153
+ --scope "/subscriptions/$SUBSCRIPTION_ID/resourceGroups/$RG_DEV"
154
+
155
+ # STAGING - Contributor na resource group
156
+ RG_STAGING="rg-${APP_NAME}-staging"
157
+ az role assignment create \
158
+ --assignee $SP_STAGING_ID \
159
+ --role Contributor \
160
+ --scope "/subscriptions/$SUBSCRIPTION_ID/resourceGroups/$RG_STAGING"
161
+
162
+ # PROD - Contributor na resource group
163
+ RG_PROD="rg-${APP_NAME}-prod"
164
+ az role assignment create \
165
+ --assignee $SP_PROD_ID \
166
+ --role Contributor \
167
+ --scope "/subscriptions/$SUBSCRIPTION_ID/resourceGroups/$RG_PROD"
168
+
169
+ # ACR - AcrPush para todos
170
+ ACR_ID="/subscriptions/$SUBSCRIPTION_ID/resourceGroups/<rg-acr>/providers/Microsoft.ContainerRegistry/registries/<acr-name>"
171
+
172
+ az role assignment create --assignee $SP_DEV_ID --role AcrPush --scope $ACR_ID
173
+ az role assignment create --assignee $SP_STAGING_ID --role AcrPush --scope $ACR_ID
174
+ az role assignment create --assignee $SP_PROD_ID --role AcrPush --scope $ACR_ID
175
+ ```
176
+
177
+ ---
178
+
179
+ ## 🔗 Criar Service Connections
180
+
181
+ ### Via Azure DevOps UI
182
+
183
+ #### 1. Service Connection para Azure (Dev)
184
+
185
+ 1. Vá em: **Project Settings** → **Service connections** → **New service connection**
186
+ 2. Selecione: **Azure Resource Manager**
187
+ 3. Authentication method: **Workload Identity federation (automatic)**
188
+ 4. Scope level: **Subscription**
189
+ 5. Preencha:
190
+ - **Subscription ID**: `<sua-subscription-id>`
191
+ - **Service connection name**: `Azure-Dev-Connection`
192
+ - **Service Principal ID**: `$APP_DEV_ID` (do Passo 1)
193
+ 6. Marque: **Grant access permission to all pipelines** (ou configure por pipeline)
194
+ 7. Click: **Save**
195
+
196
+ #### 2. Repetir para Staging e Prod
197
+
198
+ - **Staging**: Nome `Azure-Staging-Connection`, usar `$APP_STAGING_ID`
199
+ - **Prod**: Nome `Azure-Prod-Connection`, usar `$APP_PROD_ID`
200
+
201
+ #### 3. Service Connection para ACR
202
+
203
+ 1. **New service connection** → **Docker Registry**
204
+ 2. Registry type: **Azure Container Registry**
205
+ 3. Authentication type: **Workload Identity federation**
206
+ 4. Preencha:
207
+ - **Azure subscription**: Selecione a subscription
208
+ - **Azure container registry**: Selecione seu ACR
209
+ - **Service connection name**: `ACR-Connection`
210
+ 5. **Save**
211
+
212
+ ### Via Azure CLI (Alternativa)
213
+
214
+ ```bash
215
+ # Requer Azure DevOps extension
216
+ az extension add --name azure-devops
217
+
218
+ # Login
219
+ az devops configure --defaults organization=https://dev.azure.com/$ADO_ORG project=$ADO_PROJECT
220
+
221
+ # Criar service connection (exemplo simplificado)
222
+ # Nota: Workload Identity via CLI é complexo, recomenda-se usar UI
223
+ ```
224
+
225
+ ---
226
+
227
+ ## ⚙️ Configurar Pipelines
228
+
229
+ ### Passo 1: Importar Pipelines
230
+
231
+ 1. Vá em: **Pipelines** → **New pipeline**
232
+ 2. Selecione: **Azure Repos Git** (ou seu SCM)
233
+ 3. Selecione seu repositório
234
+ 4. **Existing Azure Pipelines YAML file**
235
+ 5. Path: `.azure/pipelines/dev-pipeline.yml`
236
+ 6. **Continue** → **Save** (não run ainda)
237
+
238
+ Repetir para:
239
+ - `.azure/pipelines/staging-pipeline.yml`
240
+ - `.azure/pipelines/prod-pipeline.yml`
241
+
242
+ ### Passo 2: Configurar Variáveis
243
+
244
+ #### Variáveis no Pipeline Level
245
+
246
+ Para cada pipeline, adicione as variáveis:
247
+
248
+ **Dev Pipeline** → **Edit** → **Variables**:
249
+ ```
250
+ ACR_NAME: <seu-acr-name>
251
+ APP_NAME: <seu-app-name>
252
+ SUBSCRIPTION_ID: <subscription-id>
253
+ ```
254
+
255
+ **Staging Pipeline** - mesmas variáveis
256
+
257
+ **Prod Pipeline** - mesmas variáveis
258
+
259
+ #### Variáveis no Group Level (Opcional)
260
+
261
+ 1. **Pipelines** → **Library** → **+ Variable group**
262
+ 2. Nome: `morph-common-vars`
263
+ 3. Adicionar:
264
+ ```
265
+ ACR_NAME: <seu-acr>
266
+ APP_NAME: <seu-app>
267
+ SUBSCRIPTION_ID: <subscription-id>
268
+ ```
269
+ 4. Linkar aos pipelines:
270
+ ```yaml
271
+ variables:
272
+ - group: morph-common-vars
273
+ - template: pipeline-variables.yml
274
+ ```
275
+
276
+ ---
277
+
278
+ ## 🛡️ Configurar Environments e Aprovações
279
+
280
+ ### Passo 1: Criar Environments
281
+
282
+ 1. **Pipelines** → **Environments** → **New environment**
283
+ 2. Criar 3 environments:
284
+
285
+ **Dev Environment:**
286
+ - Name: `dev`
287
+ - Resource: None
288
+ - Approvals: **Nenhuma** (deploy automático)
289
+
290
+ **Staging Environment:**
291
+ - Name: `staging`
292
+ - Resource: None
293
+ - Approvals: **Opcional** (recomendado nenhuma para deploy rápido)
294
+ - Se desejar: Add approver selecione você mesmo
295
+ - Timeout: 24 hours
296
+
297
+ **Production Environment:**
298
+ - Name: `production`
299
+ - Resource: None
300
+ - Approvals: **OBRIGATÓRIO**
301
+ - Add approvers: Selecione você mesmo
302
+ - Timeout: 48 hours
303
+ - **Checks**: Adicionar "Invoke REST API" para verificações adicionais (opcional)
304
+
305
+ ### Passo 2: Configurar Branch Policies (Opcional)
306
+
307
+ Para `main` branch:
308
+
309
+ 1. **Repos** → **Branches** → `main` → **Branch policies**
310
+ 2. Habilitar:
311
+ - **Require a minimum number of reviewers**: 0 (self-review via approval gate)
312
+ - **Check for linked work items**: Recommended
313
+ - **Build validation**: Link prod pipeline
314
+
315
+ ---
316
+
317
+ ## 🧪 Testar Configuração
318
+
319
+ ### Teste 1: Dev Pipeline
320
+
321
+ ```bash
322
+ # Criar branch develop
323
+ git checkout -b develop
324
+ git push origin develop
325
+
326
+ # Fazer um commit qualquer
327
+ echo "test" > test.txt
328
+ git add test.txt
329
+ git commit -m "test: trigger dev pipeline"
330
+ git push origin develop
331
+ ```
332
+
333
+ **Verificar:**
334
+ - Pipeline triggou automaticamente
335
+ - Build passou
336
+ - Deploy para App Service Free foi bem-sucedido
337
+ - Health check passou
338
+
339
+ ### Teste 2: Staging Pipeline
340
+
341
+ ```bash
342
+ # Merge develop em main
343
+ git checkout main
344
+ git merge develop
345
+ git push origin main
346
+ ```
347
+
348
+ **Verificar:**
349
+ - Staging pipeline triggou
350
+ - Container foi buildado e pushed para ACR
351
+ - Deploy para Container Apps funcionou
352
+ - Integration tests passaram
353
+
354
+ ### Teste 3: Prod Pipeline (Manual)
355
+
356
+ 1. **Pipelines** → **prod-pipeline** → **Run pipeline**
357
+ 2. Verificar aprovação manual aparece
358
+ 3. Aprovar deploy
359
+ 4. Verificar deployment bem-sucedido
360
+
361
+ ---
362
+
363
+ ## 🆘 Troubleshooting
364
+
365
+ ### Erro: "Failed to get federated token"
366
+
367
+ **Causa:** Subject no federated credential não match com service connection.
368
+
369
+ **Solução:**
370
+ ```bash
371
+ # Verificar subject correto
372
+ # Deve ser: sc://<ORG>/<PROJECT>/<SERVICE_CONNECTION_NAME>
373
+
374
+ # Recriar federated credential com subject correto
375
+ az ad app federated-credential delete \
376
+ --id $APP_ID \
377
+ --federated-credential-id <credential-id>
378
+
379
+ # Criar novamente com subject correto
380
+ az ad app federated-credential create \
381
+ --id $APP_ID \
382
+ --parameters federated-credential.json
383
+ ```
384
+
385
+ ### Erro: "Insufficient permissions"
386
+
387
+ **Causa:** Service Principal não tem permissões na subscription/resource group.
388
+
389
+ **Solução:**
390
+ ```bash
391
+ # Verificar role assignments
392
+ az role assignment list \
393
+ --assignee $SP_ID \
394
+ --output table
395
+
396
+ # Adicionar Contributor se necessário
397
+ az role assignment create \
398
+ --assignee $SP_ID \
399
+ --role Contributor \
400
+ --scope "/subscriptions/$SUBSCRIPTION_ID/resourceGroups/$RG_NAME"
401
+ ```
402
+
403
+ ### Erro: "Container registry not found"
404
+
405
+ **Causa:** Service Principal não tem permissão no ACR.
406
+
407
+ **Solução:**
408
+ ```bash
409
+ # Adicionar AcrPush role
410
+ az role assignment create \
411
+ --assignee $SP_ID \
412
+ --role AcrPush \
413
+ --scope $ACR_ID
414
+ ```
415
+
416
+ ### Erro: "Pipeline not authorized to access service connection"
417
+
418
+ **Causa:** Pipeline não foi autorizado a usar a service connection.
419
+
420
+ **Solução:**
421
+ 1. **Project Settings** → **Service connections**
422
+ 2. Click na service connection
423
+ 3. **Security** → Adicionar pipeline específico ou marcar "Grant access to all pipelines"
424
+
425
+ ---
426
+
427
+ ## 📚 Referências
428
+
429
+ - [Workload Identity Federation](https://learn.microsoft.com/azure/devops/pipelines/library/connect-to-azure)
430
+ - [Azure Pipelines YAML Schema](https://learn.microsoft.com/azure/devops/pipelines/yaml-schema)
431
+ - [Environments](https://learn.microsoft.com/azure/devops/pipelines/process/environments)
432
+ - [Service Connections](https://learn.microsoft.com/azure/devops/pipelines/library/service-endpoints)
433
+
434
+ ---
435
+
436
+ ## ✅ Checklist Final
437
+
438
+ Antes de ir para produção:
439
+
440
+ - [ ] Workload Identity configurada para dev/staging/prod
441
+ - [ ] Service connections criadas e testadas
442
+ - [ ] Variáveis configuradas (ACR_NAME, APP_NAME, SUBSCRIPTION_ID)
443
+ - [ ] Environments criados (dev, staging, production)
444
+ - [ ] Aprovações configuradas (production requer aprovação manual)
445
+ - [ ] Dev pipeline testado com sucesso
446
+ - [ ] Staging pipeline testado com sucesso
447
+ - [ ] Prod pipeline testado com aprovação
448
+ - [ ] Health checks funcionando
449
+ - [ ] Monitoring configurado (Application Insights)
450
+ - [ ] Rollback plan documentado
451
+
452
+ ---
453
+
454
+ *MORPH-SPEC by Polymorphism Tech*