@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.
Files changed (251) hide show
  1. package/CLAUDE.md +314 -1673
  2. package/LICENSE +72 -72
  3. package/README.md +515 -516
  4. package/bin/detect-agents.js +225 -225
  5. package/bin/morph-spec.js +358 -173
  6. package/bin/render-template.js +302 -302
  7. package/bin/semantic-detect-agents.js +246 -246
  8. package/bin/task-manager.js +429 -0
  9. package/bin/validate-agents-skills.js +251 -251
  10. package/bin/validate-agents.js +69 -69
  11. package/bin/validate-phase.js +263 -263
  12. package/bin/validate.js +369 -0
  13. package/content/.azure/README.md +293 -293
  14. package/content/.azure/docs/azure-devops-setup.md +454 -454
  15. package/content/.azure/docs/branch-strategy.md +398 -398
  16. package/content/.azure/docs/local-development.md +515 -515
  17. package/content/.azure/pipelines/pipeline-variables.yml +34 -34
  18. package/content/.azure/pipelines/prod-pipeline.yml +319 -319
  19. package/content/.azure/pipelines/staging-pipeline.yml +234 -234
  20. package/content/.azure/pipelines/templates/build-dotnet.yml +75 -75
  21. package/content/.azure/pipelines/templates/deploy-app-service.yml +94 -94
  22. package/content/.azure/pipelines/templates/deploy-container-app.yml +120 -120
  23. package/content/.azure/pipelines/templates/infra-deploy.yml +90 -90
  24. package/content/.claude/commands/morph-apply.md +221 -158
  25. package/content/.claude/commands/morph-archive.md +79 -79
  26. package/content/.claude/commands/morph-infra.md +209 -209
  27. package/content/.claude/commands/morph-preflight.md +227 -0
  28. package/content/.claude/commands/morph-proposal.md +122 -101
  29. package/content/.claude/commands/morph-status.md +86 -86
  30. package/content/.claude/commands/morph-troubleshoot.md +122 -0
  31. package/content/.claude/settings.local.json +15 -15
  32. package/content/.claude/skills/checklists/code-review.md +226 -0
  33. package/content/.claude/skills/checklists/morph-checklist.md +117 -0
  34. package/content/.claude/skills/checklists/simulation-checklist.md +77 -0
  35. package/content/.claude/skills/infra/bicep-architect.md +126 -419
  36. package/content/.claude/skills/infra/container-specialist.md +131 -437
  37. package/content/.claude/skills/infra/devops-engineer.md +119 -405
  38. package/content/.claude/skills/integrations/asaas-financial.md +130 -333
  39. package/content/.claude/skills/integrations/azure-identity.md +142 -309
  40. package/content/.claude/skills/integrations/clerk-auth.md +108 -290
  41. package/content/.claude/skills/integrations/resend-email.md +119 -0
  42. package/content/.claude/skills/specialists/ai-system-architect.md +192 -604
  43. package/content/.claude/skills/specialists/azure-architect.md +142 -142
  44. package/content/.claude/skills/specialists/code-analyzer.md +235 -0
  45. package/content/.claude/skills/specialists/dotnet-senior.md +287 -0
  46. package/content/.claude/skills/specialists/ef-modeler.md +113 -200
  47. package/content/.claude/skills/specialists/hangfire-orchestrator.md +126 -245
  48. package/content/.claude/skills/specialists/ms-agent-expert.md +109 -263
  49. package/content/.claude/skills/specialists/po-pm-advisor.md +197 -197
  50. package/content/.claude/skills/specialists/standards-architect.md +156 -78
  51. package/content/.claude/skills/specialists/testing-specialist.md +126 -0
  52. package/content/.claude/skills/specialists/ui-ux-designer.md +191 -1060
  53. package/content/.claude/skills/stacks/dotnet-blazor.md +210 -588
  54. package/content/.claude/skills/stacks/dotnet-nextjs.md +154 -402
  55. package/content/.claude/skills/workflows/morph-replicate.md +213 -0
  56. package/content/.claude/{commands/morph-clarify.md → skills/workflows/phase-clarify.md} +5 -58
  57. package/content/.claude/{commands/morph-design.md → skills/workflows/phase-design.md} +16 -86
  58. package/content/.claude/{commands/morph-setup.md → skills/workflows/phase-setup.md} +9 -17
  59. package/content/.claude/skills/workflows/phase-tasks.md +164 -0
  60. package/content/.claude/{commands/morph-uiux.md → skills/workflows/phase-uiux.md} +15 -88
  61. package/content/.morph/.morphversion +5 -5
  62. package/content/.morph/archive/.gitkeep +25 -25
  63. package/content/.morph/config/agents.json +378 -242
  64. package/content/.morph/config/config.template.json +89 -108
  65. package/content/.morph/docs/STORY-DRIVEN-DEVELOPMENT.md +392 -392
  66. package/content/.morph/docs/workflows/design-impl.md +37 -0
  67. package/content/.morph/docs/workflows/fast-track.md +29 -0
  68. package/content/.morph/docs/workflows/full-morph.md +76 -0
  69. package/content/.morph/docs/workflows/standard.md +44 -0
  70. package/content/.morph/docs/workflows/ui-refresh.md +39 -0
  71. package/content/.morph/examples/api-nextjs/README.md +241 -241
  72. package/content/.morph/examples/api-nextjs/contracts.ts +307 -307
  73. package/content/.morph/examples/api-nextjs/spec.md +399 -399
  74. package/content/.morph/examples/api-nextjs/tasks.md +168 -168
  75. package/content/.morph/examples/micro-saas/README.md +125 -125
  76. package/content/.morph/examples/micro-saas/contracts.cs +358 -358
  77. package/content/.morph/examples/micro-saas/decisions.md +246 -246
  78. package/content/.morph/examples/micro-saas/spec.md +236 -236
  79. package/content/.morph/examples/micro-saas/tasks.md +150 -150
  80. package/content/.morph/examples/multi-agent/README.md +309 -309
  81. package/content/.morph/examples/multi-agent/contracts.cs +433 -433
  82. package/content/.morph/examples/multi-agent/spec.md +479 -479
  83. package/content/.morph/examples/multi-agent/tasks.md +185 -185
  84. package/content/.morph/examples/scheduled-reports/decisions.md +158 -0
  85. package/content/.morph/examples/scheduled-reports/proposal.md +95 -0
  86. package/content/.morph/examples/scheduled-reports/spec.md +267 -0
  87. package/content/.morph/examples/state-v3.json +188 -0
  88. package/content/.morph/features/.gitkeep +25 -25
  89. package/content/.morph/hooks/README.md +190 -239
  90. package/content/.morph/hooks/pre-commit-agents.sh +24 -24
  91. package/content/.morph/hooks/pre-commit-all.sh +48 -48
  92. package/content/.morph/hooks/pre-commit-specs.sh +49 -49
  93. package/content/.morph/hooks/pre-commit-tests.sh +60 -60
  94. package/content/.morph/project.md +160 -160
  95. package/content/.morph/schemas/agent.schema.json +296 -296
  96. package/content/.morph/schemas/tasks.schema.json +220 -0
  97. package/content/.morph/specs/.gitkeep +20 -20
  98. package/content/.morph/standards/agent-framework-blazor-ui.md +359 -0
  99. package/content/.morph/standards/agent-framework-production.md +410 -0
  100. package/content/.morph/standards/agent-framework-setup.md +413 -453
  101. package/content/.morph/standards/agent-framework-workflows.md +349 -0
  102. package/content/.morph/standards/architecture.md +325 -325
  103. package/content/.morph/standards/azure.md +605 -379
  104. package/content/.morph/standards/coding.md +377 -377
  105. package/content/.morph/standards/dotnet10-migration.md +520 -494
  106. package/content/.morph/standards/fluent-ui-setup.md +590 -590
  107. package/content/.morph/standards/migration-guide.md +514 -514
  108. package/content/.morph/standards/passkeys-auth.md +423 -423
  109. package/content/.morph/standards/vector-search-rag.md +536 -536
  110. package/content/.morph/state.json +17 -17
  111. package/content/.morph/templates/FluentDesignTheme.cs +149 -149
  112. package/content/.morph/templates/MudTheme.cs +281 -281
  113. package/content/.morph/templates/agent.cs +163 -172
  114. package/content/.morph/templates/clarify-questions.md +159 -0
  115. package/content/.morph/templates/component.razor +239 -239
  116. package/content/.morph/templates/contracts/Commands.cs +74 -0
  117. package/content/.morph/templates/contracts/Entities.cs +25 -0
  118. package/content/.morph/templates/contracts/Queries.cs +74 -0
  119. package/content/.morph/templates/contracts/README.md +74 -0
  120. package/content/.morph/templates/contracts.cs +217 -217
  121. package/content/.morph/templates/decisions.md +123 -106
  122. package/content/.morph/templates/design-system.css +226 -226
  123. package/content/.morph/templates/infra/.dockerignore.example +89 -89
  124. package/content/.morph/templates/infra/Dockerfile.example +82 -82
  125. package/content/.morph/templates/infra/README.md +286 -286
  126. package/content/.morph/templates/infra/app-insights.bicep +63 -63
  127. package/content/.morph/templates/infra/app-service.bicep +164 -164
  128. package/content/.morph/templates/infra/container-app-env.bicep +49 -49
  129. package/content/.morph/templates/infra/container-app.bicep +156 -156
  130. package/content/.morph/templates/infra/deploy-checklist.md +426 -0
  131. package/content/.morph/templates/infra/deploy.ps1 +229 -229
  132. package/content/.morph/templates/infra/deploy.sh +208 -208
  133. package/content/.morph/templates/infra/key-vault.bicep +91 -91
  134. package/content/.morph/templates/infra/main.bicep +189 -189
  135. package/content/.morph/templates/infra/parameters.dev.json +29 -29
  136. package/content/.morph/templates/infra/parameters.prod.json +29 -29
  137. package/content/.morph/templates/infra/parameters.staging.json +29 -29
  138. package/content/.morph/templates/infra/sql-database.bicep +103 -103
  139. package/content/.morph/templates/infra/storage.bicep +106 -106
  140. package/content/.morph/templates/integrations/asaas-client.cs +387 -387
  141. package/content/.morph/templates/integrations/asaas-webhook.cs +351 -351
  142. package/content/.morph/templates/integrations/azure-identity-config.cs +288 -288
  143. package/content/.morph/templates/integrations/clerk-config.cs +258 -258
  144. package/content/.morph/templates/job.cs +171 -171
  145. package/content/.morph/templates/migration.cs +83 -83
  146. package/content/.morph/templates/proposal.md +141 -155
  147. package/content/.morph/templates/recap.md +94 -105
  148. package/content/.morph/templates/repository.cs +141 -141
  149. package/content/.morph/templates/saas/subscription.cs +347 -347
  150. package/content/.morph/templates/saas/tenant.cs +338 -338
  151. package/content/.morph/templates/service.cs +139 -139
  152. package/content/.morph/templates/simulation.md +353 -0
  153. package/content/.morph/templates/spec.md +149 -148
  154. package/content/.morph/templates/sprint-status.yaml +68 -68
  155. package/content/.morph/templates/state.template.json +222 -222
  156. package/content/.morph/templates/story.md +143 -143
  157. package/content/.morph/templates/tasks.md +257 -235
  158. package/content/.morph/templates/test.cs +239 -239
  159. package/content/.morph/templates/ui-components.md +362 -276
  160. package/content/.morph/templates/ui-design-system.md +286 -286
  161. package/content/.morph/templates/ui-flows.md +336 -336
  162. package/content/.morph/templates/ui-mockups.md +133 -133
  163. package/content/.morph/test-infra/example.bicep +59 -59
  164. package/content/CLAUDE.md +150 -442
  165. package/content/README.md +79 -79
  166. package/detectors/config-detector.js +223 -223
  167. package/detectors/conversation-analyzer.js +163 -163
  168. package/detectors/index.js +84 -84
  169. package/detectors/standards-generator.js +275 -275
  170. package/detectors/structure-detector.js +245 -250
  171. package/docs/README.md +144 -149
  172. package/docs/api/fonts/Source-Sans-Pro/sourcesanspro-light-webfont.svg +977 -977
  173. package/docs/api/fonts/Source-Sans-Pro/sourcesanspro-regular-webfont.svg +1048 -1048
  174. package/docs/api/scripts/collapse.js +38 -38
  175. package/docs/api/scripts/commonNav.js +28 -28
  176. package/docs/api/scripts/linenumber.js +25 -25
  177. package/docs/api/scripts/nav.js +12 -12
  178. package/docs/api/scripts/polyfill.js +3 -3
  179. package/docs/api/scripts/prettify/Apache-License-2.0.txt +202 -202
  180. package/docs/api/scripts/prettify/lang-css.js +2 -2
  181. package/docs/api/scripts/prettify/prettify.js +28 -28
  182. package/docs/api/scripts/search.js +98 -98
  183. package/docs/api/styles/jsdoc.css +776 -776
  184. package/docs/api/styles/prettify.css +80 -80
  185. package/docs/examples.md +328 -328
  186. package/docs/getting-started.md +301 -302
  187. package/docs/installation.md +361 -361
  188. package/docs/templates.md +418 -418
  189. package/docs/validation-checklist.md +265 -266
  190. package/package.json +80 -80
  191. package/scripts/postinstall.js +132 -132
  192. package/src/commands/advance-phase.js +183 -0
  193. package/src/commands/analyze-blazor-concurrency.js +193 -0
  194. package/src/commands/create-story.js +351 -351
  195. package/src/commands/detect-agents.js +139 -0
  196. package/src/commands/detect.js +104 -104
  197. package/src/commands/doctor.js +356 -280
  198. package/src/commands/generate.js +149 -149
  199. package/src/commands/init.js +258 -245
  200. package/src/commands/lint-fluent.js +352 -0
  201. package/src/commands/rollback-phase.js +185 -0
  202. package/src/commands/session-summary.js +291 -0
  203. package/src/commands/shard-spec.js +224 -224
  204. package/src/commands/sprint-status.js +250 -250
  205. package/src/commands/state.js +333 -333
  206. package/src/commands/sync.js +167 -167
  207. package/src/commands/task.js +78 -0
  208. package/src/commands/troubleshoot.js +222 -0
  209. package/src/commands/update.js +192 -159
  210. package/src/commands/validate-blazor-state.js +210 -0
  211. package/src/commands/validate-blazor.js +156 -0
  212. package/src/commands/validate-css.js +84 -0
  213. package/src/commands/validate-phase.js +221 -0
  214. package/src/lib/blazor-concurrency-analyzer.js +288 -0
  215. package/src/lib/blazor-state-validator.js +291 -0
  216. package/src/lib/blazor-validator.js +374 -0
  217. package/src/lib/complexity-analyzer.js +441 -292
  218. package/src/lib/continuous-validator.js +421 -0
  219. package/src/lib/css-validator.js +352 -0
  220. package/src/lib/decision-constraint-loader.js +109 -0
  221. package/src/lib/design-system-generator.js +298 -298
  222. package/src/lib/learning-system.js +520 -0
  223. package/src/lib/mockup-generator.js +366 -0
  224. package/src/lib/recap-generator.js +205 -0
  225. package/src/lib/state-manager.js +397 -340
  226. package/src/lib/troubleshoot-grep.js +194 -0
  227. package/src/lib/troubleshoot-index.js +144 -0
  228. package/src/lib/ui-detector.js +350 -0
  229. package/src/lib/validation-runner.js +231 -0
  230. package/src/lib/validators/architecture-validator.js +387 -0
  231. package/src/lib/validators/contract-compliance-validator.js +273 -0
  232. package/src/lib/validators/package-validator.js +360 -0
  233. package/src/lib/validators/ui-contrast-validator.js +422 -0
  234. package/src/utils/file-copier.js +179 -139
  235. package/src/utils/logger.js +32 -32
  236. package/src/utils/version-checker.js +175 -175
  237. package/content/.claude/commands/morph-costs.md +0 -206
  238. package/content/.claude/commands/morph-tasks.md +0 -319
  239. package/content/.claude/skills/specialists/cost-guardian.md +0 -110
  240. package/content/.claude/skills/stacks/shopify.md +0 -445
  241. package/content/.morph/config/azure-pricing.json +0 -70
  242. package/content/.morph/config/azure-pricing.schema.json +0 -50
  243. package/content/.morph/hooks/pre-commit-costs.sh +0 -91
  244. package/docs/api/cost-calculator.js.html +0 -513
  245. package/docs/api/design-system-generator.js.html +0 -382
  246. package/docs/api/global.html +0 -5263
  247. package/docs/api/index.html +0 -96
  248. package/docs/api/state-manager.js.html +0 -423
  249. package/src/commands/cost.js +0 -181
  250. package/src/commands/update-pricing.js +0 -206
  251. package/src/lib/cost-calculator.js +0 -429
@@ -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*