@polymorphism-tech/morph-spec 4.6.0 → 4.7.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 (239) hide show
  1. package/README.md +414 -700
  2. package/docs/ARCHITECTURE.md +331 -0
  3. package/docs/CHEATSHEET.md +221 -0
  4. package/docs/COMMAND-FLOWS.md +368 -0
  5. package/docs/QUICKSTART.md +212 -0
  6. package/docs/examples/order-management/contracts.cs +84 -0
  7. package/docs/examples/order-management/proposal.md +24 -0
  8. package/docs/examples/order-management/spec.md +162 -0
  9. package/docs/plans/2026-02-23-ddd-architecture-refactor.md +1153 -0
  10. package/docs/plans/2026-02-23-ddd-nextsteps.md +682 -0
  11. package/docs/plans/2026-02-23-infra-architect-refactor.md +437 -0
  12. package/docs/plans/2026-02-23-nextjs-code-review-design.md +156 -0
  13. package/docs/plans/2026-02-23-nextjs-code-review-impl.md +1254 -0
  14. package/docs/plans/2026-02-23-nextjs-standards-design.md +149 -0
  15. package/docs/plans/2026-02-23-nextjs-standards-impl.md +1846 -0
  16. package/framework/agents/README.md +14 -14
  17. package/framework/agents/architecture/standards-architect.md +159 -159
  18. package/framework/agents/frontend/nextjs-expert.md +87 -127
  19. package/framework/agents/infrastructure/azure-architect.md +147 -147
  20. package/framework/agents/infrastructure/infra-architect.md +45 -0
  21. package/framework/agents.json +1145 -278
  22. package/framework/rules/frontend-standards.md +0 -3
  23. package/framework/rules/nextjs-standards.md +17 -0
  24. package/framework/skills/level-0-meta/code-review-nextjs/SKILL.md +147 -0
  25. package/framework/skills/level-0-meta/code-review-nextjs/references/review-example-nextjs.md +254 -0
  26. package/framework/skills/level-0-meta/tool-usage-guide/SKILL.md +3 -3
  27. package/framework/skills/level-1-workflows/phase-design/SKILL.md +45 -9
  28. package/framework/skills/level-1-workflows/phase-tasks/SKILL.md +38 -0
  29. package/framework/standards/STANDARDS.json +121 -0
  30. package/framework/standards/architecture/ddd/bounded-contexts.md +105 -0
  31. package/framework/standards/architecture/ddd/complexity-levels.md +108 -0
  32. package/framework/standards/architecture/ddd/ubiquitous-language.md +58 -0
  33. package/framework/standards/frontend/nextjs/app-router.md +123 -0
  34. package/framework/standards/frontend/nextjs/components.md +132 -0
  35. package/framework/standards/frontend/nextjs/data-fetching.md +126 -0
  36. package/framework/standards/frontend/nextjs/forms.md +128 -0
  37. package/framework/standards/frontend/nextjs/naming-conventions.md +67 -0
  38. package/framework/standards/frontend/nextjs/project-structure.md +102 -0
  39. package/framework/standards/frontend/nextjs/state-management.md +72 -0
  40. package/framework/standards/frontend/nextjs/testing.md +111 -0
  41. package/framework/templates/REGISTRY.json +538 -142
  42. package/framework/templates/code/dotnet/contracts/contracts-level1.cs +69 -0
  43. package/framework/templates/code/dotnet/contracts/contracts-level2.cs +86 -0
  44. package/framework/templates/code/dotnet/contracts/contracts-level3.cs +41 -0
  45. package/framework/templates/docs/spec.md +49 -0
  46. package/framework/templates/frontend/nextjs/Dockerfile.nextjs.hbs +43 -0
  47. package/framework/templates/frontend/nextjs/client-component.tsx.hbs +26 -0
  48. package/framework/templates/frontend/nextjs/env.mjs.hbs +32 -0
  49. package/framework/templates/frontend/nextjs/feature-form.tsx.hbs +56 -0
  50. package/framework/templates/frontend/nextjs/page.tsx.hbs +22 -0
  51. package/framework/templates/frontend/nextjs/tsconfig.json.hbs +26 -0
  52. package/framework/templates/frontend/nextjs/use-feature.ts.hbs +54 -0
  53. package/framework/templates/project-structure/dotnet-ddd.md +70 -0
  54. package/framework/workflows/docs/enforcement-pipeline.md +2 -1
  55. package/package.json +1 -1
  56. package/scripts/scan-nextjs.mjs +169 -0
  57. package/src/commands/project/doctor.js +52 -1
  58. package/src/commands/project/init.js +15 -1
  59. package/src/commands/project/update.js +6 -1
  60. package/src/lib/standards/standards-context-injector.js +5 -0
  61. package/src/lib/validators/nextjs/index.js +6 -0
  62. package/src/lib/validators/nextjs/next-component-validator.js +181 -0
  63. package/src/lib/validators/validation-runner.js +5 -0
  64. package/src/utils/agents-installer.js +14 -2
  65. package/.morph/.morphversion +0 -5
  66. package/.morph/analytics/threads-log.jsonl +0 -6
  67. package/.morph/config/config.json +0 -8
  68. package/.morph/framework/agents.json +0 -948
  69. package/.morph/framework/standards/STANDARDS.json +0 -812
  70. package/.morph/framework/standards/ai-agents/blazor-ui.md +0 -364
  71. package/.morph/framework/standards/ai-agents/production.md +0 -415
  72. package/.morph/framework/standards/ai-agents/setup.md +0 -418
  73. package/.morph/framework/standards/ai-agents/team-orchestration.md +0 -479
  74. package/.morph/framework/standards/ai-agents/workflows.md +0 -354
  75. package/.morph/framework/standards/architecture/ddd/aggregates.md +0 -120
  76. package/.morph/framework/standards/architecture/ddd/entities.md +0 -99
  77. package/.morph/framework/standards/architecture/ddd/value-objects.md +0 -124
  78. package/.morph/framework/standards/backend/api/minimal-api.md +0 -494
  79. package/.morph/framework/standards/backend/api/rest.md +0 -492
  80. package/.morph/framework/standards/backend/api/validation.md +0 -88
  81. package/.morph/framework/standards/backend/authentication/passkeys.md +0 -428
  82. package/.morph/framework/standards/backend/database/ef-core.md +0 -199
  83. package/.morph/framework/standards/backend/database/migrations.md +0 -393
  84. package/.morph/framework/standards/backend/database/postgresql/database.md +0 -352
  85. package/.morph/framework/standards/backend/database/repository-patterns.md +0 -528
  86. package/.morph/framework/standards/backend/database/vector-search-rag.md +0 -541
  87. package/.morph/framework/standards/backend/dotnet/async.md +0 -366
  88. package/.morph/framework/standards/backend/dotnet/core.md +0 -117
  89. package/.morph/framework/standards/backend/dotnet/di.md +0 -439
  90. package/.morph/framework/standards/backend/dotnet/program-cs-checklist.md +0 -92
  91. package/.morph/framework/standards/backend/integrations/asaas/asaas-api.md +0 -216
  92. package/.morph/framework/standards/backend/integrations/clerk/clerk-auth.md +0 -290
  93. package/.morph/framework/standards/backend/integrations/hangfire/hangfire-jobs.md +0 -350
  94. package/.morph/framework/standards/backend/integrations/resend/resend-email.md +0 -385
  95. package/.morph/framework/standards/context/analytics.md +0 -96
  96. package/.morph/framework/standards/context/bundles.md +0 -110
  97. package/.morph/framework/standards/context/priming.md +0 -78
  98. package/.morph/framework/standards/core/architecture.md +0 -185
  99. package/.morph/framework/standards/core/coding.md +0 -214
  100. package/.morph/framework/standards/core/git-branching-strategy.md +0 -403
  101. package/.morph/framework/standards/core/git.md +0 -185
  102. package/.morph/framework/standards/core/testing.md +0 -295
  103. package/.morph/framework/standards/data/nosql/blob-storage.md +0 -102
  104. package/.morph/framework/standards/data/nosql/cache/redis.md +0 -97
  105. package/.morph/framework/standards/data/nosql/cosmos-db.md +0 -118
  106. package/.morph/framework/standards/data/vector-search/azure-ai-search.md +0 -121
  107. package/.morph/framework/standards/data/vector-search/rag-chunking.md +0 -104
  108. package/.morph/framework/standards/frontend/blazor/design-checklist.md +0 -222
  109. package/.morph/framework/standards/frontend/blazor/fluent-ui-setup.md +0 -595
  110. package/.morph/framework/standards/frontend/blazor/fluent-ui.md +0 -137
  111. package/.morph/framework/standards/frontend/blazor/html-conversion.md +0 -184
  112. package/.morph/framework/standards/frontend/blazor/lifecycle.md +0 -195
  113. package/.morph/framework/standards/frontend/blazor/pitfalls.md +0 -198
  114. package/.morph/framework/standards/frontend/blazor/state.md +0 -191
  115. package/.morph/framework/standards/frontend/design-system/animations.md +0 -151
  116. package/.morph/framework/standards/frontend/design-system/naming.md +0 -64
  117. package/.morph/framework/standards/frontend/nextjs/nextjs-patterns.md +0 -215
  118. package/.morph/framework/standards/infrastructure/azure/azure.md +0 -624
  119. package/.morph/framework/standards/infrastructure/azure/bicep/bicep-patterns.md +0 -422
  120. package/.morph/framework/standards/infrastructure/azure/devops/azure-devops-setup.md +0 -516
  121. package/.morph/framework/standards/infrastructure/azure/devops/local-development.md +0 -520
  122. package/.morph/framework/standards/infrastructure/azure/services/functions.md +0 -486
  123. package/.morph/framework/standards/infrastructure/azure/services/service-bus.md +0 -459
  124. package/.morph/framework/standards/infrastructure/azure/services/storage.md +0 -407
  125. package/.morph/framework/standards/infrastructure/docker/easypanel-deploy.md +0 -196
  126. package/.morph/framework/standards/infrastructure/supabase/mcp-setup.md +0 -252
  127. package/.morph/framework/standards/infrastructure/supabase/supabase-auth.md +0 -176
  128. package/.morph/framework/standards/infrastructure/supabase/supabase-pgvector.md +0 -169
  129. package/.morph/framework/standards/infrastructure/supabase/supabase-rls.md +0 -184
  130. package/.morph/framework/standards/infrastructure/supabase/supabase-storage.md +0 -153
  131. package/.morph/framework/standards/integration/api/graphql.md +0 -91
  132. package/.morph/framework/standards/integration/api/grpc.md +0 -114
  133. package/.morph/framework/standards/integration/api/rest-design.md +0 -95
  134. package/.morph/framework/standards/integration/event-driven/cqrs.md +0 -101
  135. package/.morph/framework/standards/integration/event-driven/event-sourcing.md +0 -124
  136. package/.morph/framework/standards/integration/event-driven/service-bus.md +0 -95
  137. package/.morph/framework/standards/integration/mcp/mcp-tools.md +0 -384
  138. package/.morph/framework/standards/observability/logging.md +0 -131
  139. package/.morph/framework/standards/observability/metrics.md +0 -121
  140. package/.morph/framework/standards/observability/monitoring.md +0 -114
  141. package/.morph/framework/standards/observability/tracing.md +0 -132
  142. package/.morph/framework/standards/workflows/parallel-execution.md +0 -112
  143. package/.morph/framework/standards/workflows/thread-management.md +0 -113
  144. package/.morph/framework/templates/.idea/morph-templates.xml +0 -92
  145. package/.morph/framework/templates/.vscode/morph-templates.code-snippets +0 -186
  146. package/.morph/framework/templates/IDE-SNIPPETS.md +0 -266
  147. package/.morph/framework/templates/README.md +0 -814
  148. package/.morph/framework/templates/REGISTRY.json +0 -1492
  149. package/.morph/framework/templates/code/dotnet/backend/repository.cs +0 -141
  150. package/.morph/framework/templates/code/dotnet/backend/service.cs +0 -139
  151. package/.morph/framework/templates/code/dotnet/contracts/Commands.cs +0 -74
  152. package/.morph/framework/templates/code/dotnet/contracts/Entities.cs +0 -25
  153. package/.morph/framework/templates/code/dotnet/contracts/Queries.cs +0 -74
  154. package/.morph/framework/templates/code/dotnet/contracts/README.md +0 -74
  155. package/.morph/framework/templates/code/dotnet/contracts/api-contracts.cs +0 -173
  156. package/.morph/framework/templates/code/dotnet/contracts/contracts.cs +0 -217
  157. package/.morph/framework/templates/code/dotnet/contracts/contracts.cs.hbs +0 -172
  158. package/.morph/framework/templates/code/dotnet/database/migration.cs +0 -83
  159. package/.morph/framework/templates/code/dotnet/frontend/component.razor +0 -239
  160. package/.morph/framework/templates/code/dotnet/jobs/agent.cs +0 -163
  161. package/.morph/framework/templates/code/dotnet/jobs/job.cs +0 -171
  162. package/.morph/framework/templates/code/dotnet/test.cs +0 -239
  163. package/.morph/framework/templates/code/sql/rls-policy.sql +0 -57
  164. package/.morph/framework/templates/code/sql/supabase-migration.sql +0 -100
  165. package/.morph/framework/templates/code/sql/supabase-migration.template.sql +0 -113
  166. package/.morph/framework/templates/code/typescript/contracts.ts +0 -168
  167. package/.morph/framework/templates/context/CONTEXT-FEATURE.md +0 -276
  168. package/.morph/framework/templates/context/CONTEXT.md +0 -181
  169. package/.morph/framework/templates/docs/clarifications.md +0 -253
  170. package/.morph/framework/templates/docs/onboarding.md +0 -123
  171. package/.morph/framework/templates/docs/proposal.md +0 -182
  172. package/.morph/framework/templates/docs/schema-analysis.md +0 -119
  173. package/.morph/framework/templates/docs/spec.md +0 -149
  174. package/.morph/framework/templates/docs/ui-components.md +0 -124
  175. package/.morph/framework/templates/docs/ui-design-system.md +0 -76
  176. package/.morph/framework/templates/docs/ui-flows.md +0 -167
  177. package/.morph/framework/templates/docs/ui-mockups.md +0 -98
  178. package/.morph/framework/templates/docs/user-stories.md +0 -34
  179. package/.morph/framework/templates/examples/design-system-examples.md +0 -357
  180. package/.morph/framework/templates/examples/spec-examples.md +0 -90
  181. package/.morph/framework/templates/feature/decisions.md +0 -187
  182. package/.morph/framework/templates/feature/recap.md +0 -146
  183. package/.morph/framework/templates/feature/tasks.md +0 -199
  184. package/.morph/framework/templates/infrastructure/azure/Dockerfile.example +0 -82
  185. package/.morph/framework/templates/infrastructure/azure/README.md +0 -286
  186. package/.morph/framework/templates/infrastructure/azure/app-insights.bicep +0 -63
  187. package/.morph/framework/templates/infrastructure/azure/app-service.bicep +0 -164
  188. package/.morph/framework/templates/infrastructure/azure/container-app-env.bicep +0 -49
  189. package/.morph/framework/templates/infrastructure/azure/container-app.bicep +0 -156
  190. package/.morph/framework/templates/infrastructure/azure/deploy-checklist.md +0 -426
  191. package/.morph/framework/templates/infrastructure/azure/deploy.ps1 +0 -229
  192. package/.morph/framework/templates/infrastructure/azure/deploy.sh +0 -208
  193. package/.morph/framework/templates/infrastructure/azure/key-vault.bicep +0 -91
  194. package/.morph/framework/templates/infrastructure/azure/main.bicep +0 -189
  195. package/.morph/framework/templates/infrastructure/azure/parameters.dev.json +0 -29
  196. package/.morph/framework/templates/infrastructure/azure/parameters.prod.json +0 -29
  197. package/.morph/framework/templates/infrastructure/azure/parameters.staging.json +0 -29
  198. package/.morph/framework/templates/infrastructure/azure/sql-database.bicep +0 -103
  199. package/.morph/framework/templates/infrastructure/azure/storage.bicep +0 -106
  200. package/.morph/framework/templates/infrastructure/docker/Dockerfile.template +0 -58
  201. package/.morph/framework/templates/infrastructure/docker/docker-compose.template.yml +0 -67
  202. package/.morph/framework/templates/infrastructure/docker/dockerfile-api.dockerfile +0 -38
  203. package/.morph/framework/templates/infrastructure/docker/dockerfile-web.dockerfile +0 -48
  204. package/.morph/framework/templates/infrastructure/docker/easypanel.template.json +0 -54
  205. package/.morph/framework/templates/infrastructure/github/README.md +0 -593
  206. package/.morph/framework/templates/infrastructure/github/actions/azure-auth/action.yml.hbs +0 -22
  207. package/.morph/framework/templates/infrastructure/github/actions/docker-build-push/action.yml.hbs +0 -45
  208. package/.morph/framework/templates/infrastructure/github/actions/health-check/action.yml.hbs +0 -27
  209. package/.morph/framework/templates/infrastructure/github/workflows/deploy-azure-app-service.yml.hbs +0 -61
  210. package/.morph/framework/templates/infrastructure/github/workflows/deploy-easypanel.yml.hbs +0 -31
  211. package/.morph/framework/templates/infrastructure/github/workflows/docker-build-push.yml.hbs +0 -59
  212. package/.morph/framework/templates/infrastructure/github/workflows/dotnet-build.yml.hbs +0 -39
  213. package/.morph/framework/templates/integrations/asaas-client.cs +0 -387
  214. package/.morph/framework/templates/integrations/asaas-webhook.cs +0 -351
  215. package/.morph/framework/templates/integrations/azure-identity-config.cs +0 -288
  216. package/.morph/framework/templates/integrations/clerk-config.cs +0 -258
  217. package/.morph/framework/templates/meta-prompts/fusion/fusion-agent.md +0 -76
  218. package/.morph/framework/templates/meta-prompts/fusion/fusion-aggregator.md +0 -100
  219. package/.morph/framework/templates/meta-prompts/hops/hop-retry.md +0 -78
  220. package/.morph/framework/templates/meta-prompts/hops/hop-validation.md +0 -97
  221. package/.morph/framework/templates/meta-prompts/hops/hop-wrapper.md +0 -36
  222. package/.morph/framework/templates/meta-prompts/parallel-workers/parallel-coordinator.md +0 -113
  223. package/.morph/framework/templates/meta-prompts/parallel-workers/parallel-worker.md +0 -80
  224. package/.morph/framework/templates/meta-prompts/squad-leaders/backend-squad.md +0 -90
  225. package/.morph/framework/templates/meta-prompts/squad-leaders/frontend-squad.md +0 -126
  226. package/.morph/framework/templates/meta-prompts/squad-leaders/squad-leader.md +0 -43
  227. package/.morph/framework/templates/meta-prompts/validators/checkpoint-validator.md +0 -107
  228. package/.morph/framework/templates/meta-prompts/validators/pre-commit-validator.md +0 -95
  229. package/.morph/framework/templates/saas/subscription.cs +0 -347
  230. package/.morph/framework/templates/saas/tenant.cs +0 -338
  231. package/.morph/framework/templates/state.template.json +0 -17
  232. package/.morph/framework/templates/ui/FluentDesignTheme.cs +0 -149
  233. package/.morph/framework/templates/ui/MudTheme.cs +0 -281
  234. package/.morph/framework/templates/ui/design-system.css +0 -226
  235. package/.morph/logs/tool-failures.log +0 -7
  236. package/.morph/memory/pre-compact-2026-02-23T15-43-03-521Z.json +0 -16
  237. package/.morph/state.json +0 -48
  238. package/framework/templates/code/dotnet/contracts/contracts.cs +0 -217
  239. package/framework/templates/code/dotnet/contracts/contracts.cs.hbs +0 -172
@@ -1,516 +0,0 @@
1
- # Azure DevOps Setup - Workload Identity Federation
2
-
3
- > **Scope:** blazor-azure
4
- > **Layer:** 2
5
- > **Keywords:** azure devops, workload identity, ci/cd, pipelines, service connection, federated credential
6
- > **Load When:** CI/CD setup, Azure DevOps integration, pipeline configuration
7
-
8
- > **MORPH-SPEC Framework**
9
- > Configuração de CI/CD com autenticação moderna (sem secrets)
10
-
11
- ---
12
-
13
- ## 🚀 Quick Start
14
-
15
- ### 1. Configurar Workload Identity (10 min)
16
-
17
- ```bash
18
- # Ver guia completo abaixo em "Configurar Workload Identity Federation"
19
-
20
- # Criar App Registrations
21
- az ad app create --display-name "myapp-staging-pipeline"
22
- az ad app create --display-name "myapp-prod-pipeline"
23
-
24
- # Configurar federated credentials
25
- # (Ver guia detalhado)
26
- ```
27
-
28
- ### 2. Importar Pipelines no Azure DevOps
29
-
30
- 1. **Pipelines** → **New pipeline**
31
- 2. **Azure Repos Git** → Selecione repo
32
- 3. **Existing Azure Pipelines YAML file**
33
- 4. Selecione:
34
- - `.azure/pipelines/staging-pipeline.yml`
35
- - `.azure/pipelines/prod-pipeline.yml`
36
-
37
- ### 3. Configurar Variáveis
38
-
39
- Para cada pipeline, adicione:
40
- ```
41
- ACR_NAME: <seu-acr-name>
42
- APP_NAME: <seu-app-name>
43
- SUBSCRIPTION_ID: <subscription-id>
44
- ```
45
-
46
- ### 4. Criar Environments
47
-
48
- 1. **Pipelines** → **Environments** → **New environment**
49
- 2. Criar:
50
- - `staging` (sem aprovação - deploy rápido)
51
- - `production` (aprovação obrigatória)
52
-
53
- ### 5. Testar!
54
-
55
- ```bash
56
- # Trigger staging pipeline
57
- git checkout staging
58
- git commit -m "test" --allow-empty
59
- git push origin staging
60
-
61
- # Trigger prod pipeline
62
- git checkout main
63
- git commit -m "test" --allow-empty
64
- git push origin main
65
- # ⏸️ Aprovar manualmente no Azure DevOps
66
- ```
67
-
68
- ---
69
-
70
- ## 📋 Índice
71
-
72
- 1. [Pré-requisitos](#pré-requisitos)
73
- 2. [Configurar Workload Identity Federation](#configurar-workload-identity-federation)
74
- 3. [Criar Service Connections](#criar-service-connections)
75
- 4. [Configurar Pipelines](#configurar-pipelines)
76
- 5. [Configurar Environments e Aprovações](#configurar-environments-e-aprovações)
77
- 6. [Troubleshooting](#troubleshooting)
78
-
79
- ---
80
-
81
- ## 🔑 Pré-requisitos
82
-
83
- ### Azure
84
- - ✅ Subscription Azure ativa
85
- - ✅ Permissões de Owner ou User Access Administrator na subscription
86
- - ✅ Azure CLI instalado: https://aka.ms/azure-cli
87
-
88
- ### Azure DevOps
89
- - ✅ Organização Azure DevOps criada
90
- - ✅ Projeto criado
91
- - ✅ Permissões de administrador do projeto
92
-
93
- ### Informações Necessárias
94
- ```bash
95
- # Azure
96
- SUBSCRIPTION_ID="<sua-subscription-id>"
97
- TENANT_ID="<seu-tenant-id>"
98
-
99
- # Azure DevOps
100
- ADO_ORG="<sua-org>" # Ex: polymorphismtech
101
- ADO_PROJECT="<seu-projeto>" # Ex: morph-app
102
-
103
- # Application
104
- APP_NAME="<nome-da-app>" # Ex: myapp
105
- ```
106
-
107
- ---
108
-
109
- ## 🌐 Configurar Workload Identity Federation
110
-
111
- ### Passo 1: Criar App Registration
112
-
113
- ```bash
114
- # Login no Azure
115
- az login
116
- az account set --subscription $SUBSCRIPTION_ID
117
-
118
- # Criar App Registration para Dev
119
- APP_DEV_NAME="${APP_NAME}-dev-pipeline"
120
- APP_DEV_ID=$(az ad app create \
121
- --display-name "$APP_DEV_NAME" \
122
- --query appId -o tsv)
123
-
124
- echo "Dev App ID: $APP_DEV_ID"
125
-
126
- # Criar Service Principal
127
- SP_DEV_ID=$(az ad sp create \
128
- --id $APP_DEV_ID \
129
- --query id -o tsv)
130
-
131
- echo "Dev Service Principal ID: $SP_DEV_ID"
132
-
133
- # Repetir para Staging e Prod
134
- APP_STAGING_NAME="${APP_NAME}-staging-pipeline"
135
- APP_STAGING_ID=$(az ad app create --display-name "$APP_STAGING_NAME" --query appId -o tsv)
136
- SP_STAGING_ID=$(az ad sp create --id $APP_STAGING_ID --query id -o tsv)
137
-
138
- APP_PROD_NAME="${APP_NAME}-prod-pipeline"
139
- APP_PROD_ID=$(az ad app create --display-name "$APP_PROD_NAME" --query appId -o tsv)
140
- SP_PROD_ID=$(az ad sp create --id $APP_PROD_ID --query id -o tsv)
141
- ```
142
-
143
- ### Passo 2: Configurar Federated Credentials
144
-
145
- ```bash
146
- # DEV Environment
147
- cat <<EOF > federated-credential-dev.json
148
- {
149
- "name": "dev-pipeline-federated",
150
- "issuer": "https://vstoken.dev.azure.com/<ADO_ORG_ID>",
151
- "subject": "sc://$ADO_ORG/$ADO_PROJECT/Azure-Dev-Connection",
152
- "description": "Federated credential for dev pipeline",
153
- "audiences": [
154
- "api://AzureADTokenExchange"
155
- ]
156
- }
157
- EOF
158
-
159
- az ad app federated-credential create \
160
- --id $APP_DEV_ID \
161
- --parameters federated-credential-dev.json
162
-
163
- # STAGING Environment
164
- cat <<EOF > federated-credential-staging.json
165
- {
166
- "name": "staging-pipeline-federated",
167
- "issuer": "https://vstoken.dev.azure.com/<ADO_ORG_ID>",
168
- "subject": "sc://$ADO_ORG/$ADO_PROJECT/Azure-Staging-Connection",
169
- "description": "Federated credential for staging pipeline",
170
- "audiences": [
171
- "api://AzureADTokenExchange"
172
- ]
173
- }
174
- EOF
175
-
176
- az ad app federated-credential create \
177
- --id $APP_STAGING_ID \
178
- --parameters federated-credential-staging.json
179
-
180
- # PROD Environment
181
- cat <<EOF > federated-credential-prod.json
182
- {
183
- "name": "prod-pipeline-federated",
184
- "issuer": "https://vstoken.dev.azure.com/<ADO_ORG_ID>",
185
- "subject": "sc://$ADO_ORG/$ADO_PROJECT/Azure-Prod-Connection",
186
- "description": "Federated credential for prod pipeline",
187
- "audiences": [
188
- "api://AzureADTokenExchange"
189
- ]
190
- }
191
- EOF
192
-
193
- az ad app federated-credential create \
194
- --id $APP_PROD_ID \
195
- --parameters federated-credential-prod.json
196
- ```
197
-
198
- **📌 Como obter ADO_ORG_ID:**
199
- ```bash
200
- # Via Azure DevOps UI
201
- # Vá em: Organization Settings → Overview → Organization ID
202
- # Ou via API:
203
- curl -u ":${AZURE_DEVOPS_PAT}" \
204
- "https://dev.azure.com/${ADO_ORG}/_apis/connectionData"
205
- ```
206
-
207
- ### Passo 3: Atribuir Permissões Azure
208
-
209
- ```bash
210
- # DEV - Contributor na resource group
211
- RG_DEV="rg-${APP_NAME}-dev"
212
- az role assignment create \
213
- --assignee $SP_DEV_ID \
214
- --role Contributor \
215
- --scope "/subscriptions/$SUBSCRIPTION_ID/resourceGroups/$RG_DEV"
216
-
217
- # STAGING - Contributor na resource group
218
- RG_STAGING="rg-${APP_NAME}-staging"
219
- az role assignment create \
220
- --assignee $SP_STAGING_ID \
221
- --role Contributor \
222
- --scope "/subscriptions/$SUBSCRIPTION_ID/resourceGroups/$RG_STAGING"
223
-
224
- # PROD - Contributor na resource group
225
- RG_PROD="rg-${APP_NAME}-prod"
226
- az role assignment create \
227
- --assignee $SP_PROD_ID \
228
- --role Contributor \
229
- --scope "/subscriptions/$SUBSCRIPTION_ID/resourceGroups/$RG_PROD"
230
-
231
- # ACR - AcrPush para todos
232
- ACR_ID="/subscriptions/$SUBSCRIPTION_ID/resourceGroups/<rg-acr>/providers/Microsoft.ContainerRegistry/registries/<acr-name>"
233
-
234
- az role assignment create --assignee $SP_DEV_ID --role AcrPush --scope $ACR_ID
235
- az role assignment create --assignee $SP_STAGING_ID --role AcrPush --scope $ACR_ID
236
- az role assignment create --assignee $SP_PROD_ID --role AcrPush --scope $ACR_ID
237
- ```
238
-
239
- ---
240
-
241
- ## 🔗 Criar Service Connections
242
-
243
- ### Via Azure DevOps UI
244
-
245
- #### 1. Service Connection para Azure (Dev)
246
-
247
- 1. Vá em: **Project Settings** → **Service connections** → **New service connection**
248
- 2. Selecione: **Azure Resource Manager**
249
- 3. Authentication method: **Workload Identity federation (automatic)**
250
- 4. Scope level: **Subscription**
251
- 5. Preencha:
252
- - **Subscription ID**: `<sua-subscription-id>`
253
- - **Service connection name**: `Azure-Dev-Connection`
254
- - **Service Principal ID**: `$APP_DEV_ID` (do Passo 1)
255
- 6. Marque: **Grant access permission to all pipelines** (ou configure por pipeline)
256
- 7. Click: **Save**
257
-
258
- #### 2. Repetir para Staging e Prod
259
-
260
- - **Staging**: Nome `Azure-Staging-Connection`, usar `$APP_STAGING_ID`
261
- - **Prod**: Nome `Azure-Prod-Connection`, usar `$APP_PROD_ID`
262
-
263
- #### 3. Service Connection para ACR
264
-
265
- 1. **New service connection** → **Docker Registry**
266
- 2. Registry type: **Azure Container Registry**
267
- 3. Authentication type: **Workload Identity federation**
268
- 4. Preencha:
269
- - **Azure subscription**: Selecione a subscription
270
- - **Azure container registry**: Selecione seu ACR
271
- - **Service connection name**: `ACR-Connection`
272
- 5. **Save**
273
-
274
- ### Via Azure CLI (Alternativa)
275
-
276
- ```bash
277
- # Requer Azure DevOps extension
278
- az extension add --name azure-devops
279
-
280
- # Login
281
- az devops configure --defaults organization=https://dev.azure.com/$ADO_ORG project=$ADO_PROJECT
282
-
283
- # Criar service connection (exemplo simplificado)
284
- # Nota: Workload Identity via CLI é complexo, recomenda-se usar UI
285
- ```
286
-
287
- ---
288
-
289
- ## ⚙️ Configurar Pipelines
290
-
291
- ### Passo 1: Importar Pipelines
292
-
293
- 1. Vá em: **Pipelines** → **New pipeline**
294
- 2. Selecione: **Azure Repos Git** (ou seu SCM)
295
- 3. Selecione seu repositório
296
- 4. **Existing Azure Pipelines YAML file**
297
- 5. Path: `.azure/pipelines/dev-pipeline.yml`
298
- 6. **Continue** → **Save** (não run ainda)
299
-
300
- Repetir para:
301
- - `.azure/pipelines/staging-pipeline.yml`
302
- - `.azure/pipelines/prod-pipeline.yml`
303
-
304
- ### Passo 2: Configurar Variáveis
305
-
306
- #### Variáveis no Pipeline Level
307
-
308
- Para cada pipeline, adicione as variáveis:
309
-
310
- **Dev Pipeline** → **Edit** → **Variables**:
311
- ```
312
- ACR_NAME: <seu-acr-name>
313
- APP_NAME: <seu-app-name>
314
- SUBSCRIPTION_ID: <subscription-id>
315
- ```
316
-
317
- **Staging Pipeline** - mesmas variáveis
318
-
319
- **Prod Pipeline** - mesmas variáveis
320
-
321
- #### Variáveis no Group Level (Opcional)
322
-
323
- 1. **Pipelines** → **Library** → **+ Variable group**
324
- 2. Nome: `morph-common-vars`
325
- 3. Adicionar:
326
- ```
327
- ACR_NAME: <seu-acr>
328
- APP_NAME: <seu-app>
329
- SUBSCRIPTION_ID: <subscription-id>
330
- ```
331
- 4. Linkar aos pipelines:
332
- ```yaml
333
- variables:
334
- - group: morph-common-vars
335
- - template: pipeline-variables.yml
336
- ```
337
-
338
- ---
339
-
340
- ## 🛡️ Configurar Environments e Aprovações
341
-
342
- ### Passo 1: Criar Environments
343
-
344
- 1. **Pipelines** → **Environments** → **New environment**
345
- 2. Criar 3 environments:
346
-
347
- **Dev Environment:**
348
- - Name: `dev`
349
- - Resource: None
350
- - Approvals: **Nenhuma** (deploy automático)
351
-
352
- **Staging Environment:**
353
- - Name: `staging`
354
- - Resource: None
355
- - Approvals: **Opcional** (recomendado nenhuma para deploy rápido)
356
- - Se desejar: Add approver selecione você mesmo
357
- - Timeout: 24 hours
358
-
359
- **Production Environment:**
360
- - Name: `production`
361
- - Resource: None
362
- - Approvals: **OBRIGATÓRIO**
363
- - Add approvers: Selecione você mesmo
364
- - Timeout: 48 hours
365
- - **Checks**: Adicionar "Invoke REST API" para verificações adicionais (opcional)
366
-
367
- ### Passo 2: Configurar Branch Policies (Opcional)
368
-
369
- Para `main` branch:
370
-
371
- 1. **Repos** → **Branches** → `main` → **Branch policies**
372
- 2. Habilitar:
373
- - **Require a minimum number of reviewers**: 0 (self-review via approval gate)
374
- - **Check for linked work items**: Recommended
375
- - **Build validation**: Link prod pipeline
376
-
377
- ---
378
-
379
- ## 🧪 Testar Configuração
380
-
381
- ### Teste 1: Dev Pipeline
382
-
383
- ```bash
384
- # Criar branch develop
385
- git checkout -b develop
386
- git push origin develop
387
-
388
- # Fazer um commit qualquer
389
- echo "test" > test.txt
390
- git add test.txt
391
- git commit -m "test: trigger dev pipeline"
392
- git push origin develop
393
- ```
394
-
395
- **Verificar:**
396
- - Pipeline triggou automaticamente
397
- - Build passou
398
- - Deploy para App Service Free foi bem-sucedido
399
- - Health check passou
400
-
401
- ### Teste 2: Staging Pipeline
402
-
403
- ```bash
404
- # Merge develop em main
405
- git checkout main
406
- git merge develop
407
- git push origin main
408
- ```
409
-
410
- **Verificar:**
411
- - Staging pipeline triggou
412
- - Container foi buildado e pushed para ACR
413
- - Deploy para Container Apps funcionou
414
- - Integration tests passaram
415
-
416
- ### Teste 3: Prod Pipeline (Manual)
417
-
418
- 1. **Pipelines** → **prod-pipeline** → **Run pipeline**
419
- 2. Verificar aprovação manual aparece
420
- 3. Aprovar deploy
421
- 4. Verificar deployment bem-sucedido
422
-
423
- ---
424
-
425
- ## 🆘 Troubleshooting
426
-
427
- ### Erro: "Failed to get federated token"
428
-
429
- **Causa:** Subject no federated credential não match com service connection.
430
-
431
- **Solução:**
432
- ```bash
433
- # Verificar subject correto
434
- # Deve ser: sc://<ORG>/<PROJECT>/<SERVICE_CONNECTION_NAME>
435
-
436
- # Recriar federated credential com subject correto
437
- az ad app federated-credential delete \
438
- --id $APP_ID \
439
- --federated-credential-id <credential-id>
440
-
441
- # Criar novamente com subject correto
442
- az ad app federated-credential create \
443
- --id $APP_ID \
444
- --parameters federated-credential.json
445
- ```
446
-
447
- ### Erro: "Insufficient permissions"
448
-
449
- **Causa:** Service Principal não tem permissões na subscription/resource group.
450
-
451
- **Solução:**
452
- ```bash
453
- # Verificar role assignments
454
- az role assignment list \
455
- --assignee $SP_ID \
456
- --output table
457
-
458
- # Adicionar Contributor se necessário
459
- az role assignment create \
460
- --assignee $SP_ID \
461
- --role Contributor \
462
- --scope "/subscriptions/$SUBSCRIPTION_ID/resourceGroups/$RG_NAME"
463
- ```
464
-
465
- ### Erro: "Container registry not found"
466
-
467
- **Causa:** Service Principal não tem permissão no ACR.
468
-
469
- **Solução:**
470
- ```bash
471
- # Adicionar AcrPush role
472
- az role assignment create \
473
- --assignee $SP_ID \
474
- --role AcrPush \
475
- --scope $ACR_ID
476
- ```
477
-
478
- ### Erro: "Pipeline not authorized to access service connection"
479
-
480
- **Causa:** Pipeline não foi autorizado a usar a service connection.
481
-
482
- **Solução:**
483
- 1. **Project Settings** → **Service connections**
484
- 2. Click na service connection
485
- 3. **Security** → Adicionar pipeline específico ou marcar "Grant access to all pipelines"
486
-
487
- ---
488
-
489
- ## 📚 Referências
490
-
491
- - [Workload Identity Federation](https://learn.microsoft.com/azure/devops/pipelines/library/connect-to-azure)
492
- - [Azure Pipelines YAML Schema](https://learn.microsoft.com/azure/devops/pipelines/yaml-schema)
493
- - [Environments](https://learn.microsoft.com/azure/devops/pipelines/process/environments)
494
- - [Service Connections](https://learn.microsoft.com/azure/devops/pipelines/library/service-endpoints)
495
-
496
- ---
497
-
498
- ## ✅ Checklist Final
499
-
500
- Antes de ir para produção:
501
-
502
- - [ ] Workload Identity configurada para dev/staging/prod
503
- - [ ] Service connections criadas e testadas
504
- - [ ] Variáveis configuradas (ACR_NAME, APP_NAME, SUBSCRIPTION_ID)
505
- - [ ] Environments criados (dev, staging, production)
506
- - [ ] Aprovações configuradas (production requer aprovação manual)
507
- - [ ] Dev pipeline testado com sucesso
508
- - [ ] Staging pipeline testado com sucesso
509
- - [ ] Prod pipeline testado com aprovação
510
- - [ ] Health checks funcionando
511
- - [ ] Monitoring configurado (Application Insights)
512
- - [ ] Rollback plan documentado
513
-
514
- ---
515
-
516
- *MORPH-SPEC by Polymorphism Tech*