claude-autopm 2.7.0 → 2.8.2

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 (281) hide show
  1. package/README.md +307 -56
  2. package/autopm/.claude/.env +158 -0
  3. package/autopm/.claude/settings.local.json +9 -0
  4. package/bin/autopm.js +11 -2
  5. package/bin/commands/epic.js +23 -3
  6. package/bin/commands/plugin.js +395 -0
  7. package/bin/commands/team.js +184 -10
  8. package/install/install.js +223 -4
  9. package/lib/cli/commands/issue.js +360 -20
  10. package/lib/plugins/PluginManager.js +1328 -0
  11. package/lib/plugins/PluginManager.old.js +400 -0
  12. package/lib/providers/AzureDevOpsProvider.js +575 -0
  13. package/lib/providers/GitHubProvider.js +475 -0
  14. package/lib/services/EpicService.js +1092 -3
  15. package/lib/services/IssueService.js +991 -0
  16. package/package.json +9 -1
  17. package/scripts/publish-plugins.sh +166 -0
  18. package/autopm/.claude/agents/cloud/README.md +0 -55
  19. package/autopm/.claude/agents/cloud/aws-cloud-architect.md +0 -521
  20. package/autopm/.claude/agents/cloud/azure-cloud-architect.md +0 -436
  21. package/autopm/.claude/agents/cloud/gcp-cloud-architect.md +0 -385
  22. package/autopm/.claude/agents/cloud/gcp-cloud-functions-engineer.md +0 -306
  23. package/autopm/.claude/agents/cloud/gemini-api-expert.md +0 -880
  24. package/autopm/.claude/agents/cloud/kubernetes-orchestrator.md +0 -566
  25. package/autopm/.claude/agents/cloud/openai-python-expert.md +0 -1087
  26. package/autopm/.claude/agents/cloud/terraform-infrastructure-expert.md +0 -454
  27. package/autopm/.claude/agents/core/agent-manager.md +0 -296
  28. package/autopm/.claude/agents/core/code-analyzer.md +0 -131
  29. package/autopm/.claude/agents/core/file-analyzer.md +0 -162
  30. package/autopm/.claude/agents/core/test-runner.md +0 -200
  31. package/autopm/.claude/agents/data/airflow-orchestration-expert.md +0 -52
  32. package/autopm/.claude/agents/data/kedro-pipeline-expert.md +0 -50
  33. package/autopm/.claude/agents/data/langgraph-workflow-expert.md +0 -520
  34. package/autopm/.claude/agents/databases/README.md +0 -50
  35. package/autopm/.claude/agents/databases/bigquery-expert.md +0 -392
  36. package/autopm/.claude/agents/databases/cosmosdb-expert.md +0 -368
  37. package/autopm/.claude/agents/databases/mongodb-expert.md +0 -398
  38. package/autopm/.claude/agents/databases/postgresql-expert.md +0 -321
  39. package/autopm/.claude/agents/databases/redis-expert.md +0 -52
  40. package/autopm/.claude/agents/devops/README.md +0 -52
  41. package/autopm/.claude/agents/devops/azure-devops-specialist.md +0 -308
  42. package/autopm/.claude/agents/devops/docker-containerization-expert.md +0 -298
  43. package/autopm/.claude/agents/devops/github-operations-specialist.md +0 -335
  44. package/autopm/.claude/agents/devops/mcp-context-manager.md +0 -319
  45. package/autopm/.claude/agents/devops/observability-engineer.md +0 -574
  46. package/autopm/.claude/agents/devops/ssh-operations-expert.md +0 -1093
  47. package/autopm/.claude/agents/devops/traefik-proxy-expert.md +0 -444
  48. package/autopm/.claude/agents/frameworks/README.md +0 -64
  49. package/autopm/.claude/agents/frameworks/e2e-test-engineer.md +0 -360
  50. package/autopm/.claude/agents/frameworks/nats-messaging-expert.md +0 -254
  51. package/autopm/.claude/agents/frameworks/react-frontend-engineer.md +0 -217
  52. package/autopm/.claude/agents/frameworks/react-ui-expert.md +0 -226
  53. package/autopm/.claude/agents/frameworks/tailwindcss-expert.md +0 -770
  54. package/autopm/.claude/agents/frameworks/ux-design-expert.md +0 -244
  55. package/autopm/.claude/agents/integration/message-queue-engineer.md +0 -794
  56. package/autopm/.claude/agents/languages/README.md +0 -50
  57. package/autopm/.claude/agents/languages/bash-scripting-expert.md +0 -541
  58. package/autopm/.claude/agents/languages/javascript-frontend-engineer.md +0 -197
  59. package/autopm/.claude/agents/languages/nodejs-backend-engineer.md +0 -226
  60. package/autopm/.claude/agents/languages/python-backend-engineer.md +0 -214
  61. package/autopm/.claude/agents/languages/python-backend-expert.md +0 -289
  62. package/autopm/.claude/agents/testing/frontend-testing-engineer.md +0 -395
  63. package/autopm/.claude/commands/ai/langgraph-workflow.md +0 -65
  64. package/autopm/.claude/commands/ai/openai-chat.md +0 -65
  65. package/autopm/.claude/commands/azure/COMMANDS.md +0 -107
  66. package/autopm/.claude/commands/azure/COMMAND_MAPPING.md +0 -252
  67. package/autopm/.claude/commands/azure/INTEGRATION_FIX.md +0 -103
  68. package/autopm/.claude/commands/azure/README.md +0 -246
  69. package/autopm/.claude/commands/azure/active-work.md +0 -198
  70. package/autopm/.claude/commands/azure/aliases.md +0 -143
  71. package/autopm/.claude/commands/azure/blocked-items.md +0 -287
  72. package/autopm/.claude/commands/azure/clean.md +0 -93
  73. package/autopm/.claude/commands/azure/docs-query.md +0 -48
  74. package/autopm/.claude/commands/azure/feature-decompose.md +0 -380
  75. package/autopm/.claude/commands/azure/feature-list.md +0 -61
  76. package/autopm/.claude/commands/azure/feature-new.md +0 -115
  77. package/autopm/.claude/commands/azure/feature-show.md +0 -205
  78. package/autopm/.claude/commands/azure/feature-start.md +0 -130
  79. package/autopm/.claude/commands/azure/fix-integration-example.md +0 -93
  80. package/autopm/.claude/commands/azure/help.md +0 -150
  81. package/autopm/.claude/commands/azure/import-us.md +0 -269
  82. package/autopm/.claude/commands/azure/init.md +0 -211
  83. package/autopm/.claude/commands/azure/next-task.md +0 -262
  84. package/autopm/.claude/commands/azure/search.md +0 -160
  85. package/autopm/.claude/commands/azure/sprint-status.md +0 -235
  86. package/autopm/.claude/commands/azure/standup.md +0 -260
  87. package/autopm/.claude/commands/azure/sync-all.md +0 -99
  88. package/autopm/.claude/commands/azure/task-analyze.md +0 -186
  89. package/autopm/.claude/commands/azure/task-close.md +0 -329
  90. package/autopm/.claude/commands/azure/task-edit.md +0 -145
  91. package/autopm/.claude/commands/azure/task-list.md +0 -263
  92. package/autopm/.claude/commands/azure/task-new.md +0 -84
  93. package/autopm/.claude/commands/azure/task-reopen.md +0 -79
  94. package/autopm/.claude/commands/azure/task-show.md +0 -126
  95. package/autopm/.claude/commands/azure/task-start.md +0 -301
  96. package/autopm/.claude/commands/azure/task-status.md +0 -65
  97. package/autopm/.claude/commands/azure/task-sync.md +0 -67
  98. package/autopm/.claude/commands/azure/us-edit.md +0 -164
  99. package/autopm/.claude/commands/azure/us-list.md +0 -202
  100. package/autopm/.claude/commands/azure/us-new.md +0 -265
  101. package/autopm/.claude/commands/azure/us-parse.md +0 -253
  102. package/autopm/.claude/commands/azure/us-show.md +0 -188
  103. package/autopm/.claude/commands/azure/us-status.md +0 -320
  104. package/autopm/.claude/commands/azure/validate.md +0 -86
  105. package/autopm/.claude/commands/azure/work-item-sync.md +0 -47
  106. package/autopm/.claude/commands/cloud/infra-deploy.md +0 -38
  107. package/autopm/.claude/commands/github/workflow-create.md +0 -42
  108. package/autopm/.claude/commands/infrastructure/ssh-security.md +0 -65
  109. package/autopm/.claude/commands/infrastructure/traefik-setup.md +0 -65
  110. package/autopm/.claude/commands/kubernetes/deploy.md +0 -37
  111. package/autopm/.claude/commands/playwright/test-scaffold.md +0 -38
  112. package/autopm/.claude/commands/pm/blocked.md +0 -28
  113. package/autopm/.claude/commands/pm/clean.md +0 -119
  114. package/autopm/.claude/commands/pm/context-create.md +0 -136
  115. package/autopm/.claude/commands/pm/context-prime.md +0 -170
  116. package/autopm/.claude/commands/pm/context-update.md +0 -292
  117. package/autopm/.claude/commands/pm/context.md +0 -28
  118. package/autopm/.claude/commands/pm/epic-close.md +0 -86
  119. package/autopm/.claude/commands/pm/epic-decompose.md +0 -370
  120. package/autopm/.claude/commands/pm/epic-edit.md +0 -83
  121. package/autopm/.claude/commands/pm/epic-list.md +0 -30
  122. package/autopm/.claude/commands/pm/epic-merge.md +0 -222
  123. package/autopm/.claude/commands/pm/epic-oneshot.md +0 -119
  124. package/autopm/.claude/commands/pm/epic-refresh.md +0 -119
  125. package/autopm/.claude/commands/pm/epic-show.md +0 -28
  126. package/autopm/.claude/commands/pm/epic-split.md +0 -120
  127. package/autopm/.claude/commands/pm/epic-start.md +0 -195
  128. package/autopm/.claude/commands/pm/epic-status.md +0 -28
  129. package/autopm/.claude/commands/pm/epic-sync-modular.md +0 -338
  130. package/autopm/.claude/commands/pm/epic-sync-original.md +0 -473
  131. package/autopm/.claude/commands/pm/epic-sync.md +0 -486
  132. package/autopm/.claude/commands/pm/help.md +0 -28
  133. package/autopm/.claude/commands/pm/import.md +0 -115
  134. package/autopm/.claude/commands/pm/in-progress.md +0 -28
  135. package/autopm/.claude/commands/pm/init.md +0 -28
  136. package/autopm/.claude/commands/pm/issue-analyze.md +0 -202
  137. package/autopm/.claude/commands/pm/issue-close.md +0 -119
  138. package/autopm/.claude/commands/pm/issue-edit.md +0 -93
  139. package/autopm/.claude/commands/pm/issue-reopen.md +0 -87
  140. package/autopm/.claude/commands/pm/issue-show.md +0 -41
  141. package/autopm/.claude/commands/pm/issue-start.md +0 -234
  142. package/autopm/.claude/commands/pm/issue-status.md +0 -95
  143. package/autopm/.claude/commands/pm/issue-sync.md +0 -411
  144. package/autopm/.claude/commands/pm/next.md +0 -28
  145. package/autopm/.claude/commands/pm/prd-edit.md +0 -82
  146. package/autopm/.claude/commands/pm/prd-list.md +0 -28
  147. package/autopm/.claude/commands/pm/prd-new.md +0 -55
  148. package/autopm/.claude/commands/pm/prd-parse.md +0 -42
  149. package/autopm/.claude/commands/pm/prd-status.md +0 -28
  150. package/autopm/.claude/commands/pm/search.md +0 -28
  151. package/autopm/.claude/commands/pm/standup.md +0 -28
  152. package/autopm/.claude/commands/pm/status.md +0 -28
  153. package/autopm/.claude/commands/pm/sync.md +0 -99
  154. package/autopm/.claude/commands/pm/test-reference-update.md +0 -151
  155. package/autopm/.claude/commands/pm/validate.md +0 -28
  156. package/autopm/.claude/commands/pm/what-next.md +0 -28
  157. package/autopm/.claude/commands/python/api-scaffold.md +0 -50
  158. package/autopm/.claude/commands/python/docs-query.md +0 -48
  159. package/autopm/.claude/commands/react/app-scaffold.md +0 -50
  160. package/autopm/.claude/commands/testing/prime.md +0 -314
  161. package/autopm/.claude/commands/testing/run.md +0 -125
  162. package/autopm/.claude/commands/ui/bootstrap-scaffold.md +0 -65
  163. package/autopm/.claude/commands/ui/tailwind-system.md +0 -64
  164. package/autopm/.claude/rules/ai-integration-patterns.md +0 -219
  165. package/autopm/.claude/rules/ci-cd-kubernetes-strategy.md +0 -25
  166. package/autopm/.claude/rules/database-management-strategy.md +0 -17
  167. package/autopm/.claude/rules/database-pipeline.md +0 -94
  168. package/autopm/.claude/rules/devops-troubleshooting-playbook.md +0 -450
  169. package/autopm/.claude/rules/docker-first-development.md +0 -404
  170. package/autopm/.claude/rules/infrastructure-pipeline.md +0 -128
  171. package/autopm/.claude/rules/performance-guidelines.md +0 -403
  172. package/autopm/.claude/rules/ui-development-standards.md +0 -281
  173. package/autopm/.claude/rules/ui-framework-rules.md +0 -151
  174. package/autopm/.claude/rules/ux-design-rules.md +0 -209
  175. package/autopm/.claude/rules/visual-testing.md +0 -223
  176. package/autopm/.claude/scripts/azure/README.md +0 -192
  177. package/autopm/.claude/scripts/azure/active-work.js +0 -524
  178. package/autopm/.claude/scripts/azure/active-work.sh +0 -20
  179. package/autopm/.claude/scripts/azure/blocked.js +0 -520
  180. package/autopm/.claude/scripts/azure/blocked.sh +0 -20
  181. package/autopm/.claude/scripts/azure/daily.js +0 -533
  182. package/autopm/.claude/scripts/azure/daily.sh +0 -20
  183. package/autopm/.claude/scripts/azure/dashboard.js +0 -970
  184. package/autopm/.claude/scripts/azure/dashboard.sh +0 -20
  185. package/autopm/.claude/scripts/azure/feature-list.js +0 -254
  186. package/autopm/.claude/scripts/azure/feature-list.sh +0 -20
  187. package/autopm/.claude/scripts/azure/feature-show.js +0 -7
  188. package/autopm/.claude/scripts/azure/feature-show.sh +0 -20
  189. package/autopm/.claude/scripts/azure/feature-status.js +0 -604
  190. package/autopm/.claude/scripts/azure/feature-status.sh +0 -20
  191. package/autopm/.claude/scripts/azure/help.js +0 -342
  192. package/autopm/.claude/scripts/azure/help.sh +0 -20
  193. package/autopm/.claude/scripts/azure/next-task.js +0 -508
  194. package/autopm/.claude/scripts/azure/next-task.sh +0 -20
  195. package/autopm/.claude/scripts/azure/search.js +0 -469
  196. package/autopm/.claude/scripts/azure/search.sh +0 -20
  197. package/autopm/.claude/scripts/azure/setup.js +0 -745
  198. package/autopm/.claude/scripts/azure/setup.sh +0 -20
  199. package/autopm/.claude/scripts/azure/sprint-report.js +0 -1012
  200. package/autopm/.claude/scripts/azure/sprint-report.sh +0 -20
  201. package/autopm/.claude/scripts/azure/sync.js +0 -563
  202. package/autopm/.claude/scripts/azure/sync.sh +0 -20
  203. package/autopm/.claude/scripts/azure/us-list.js +0 -210
  204. package/autopm/.claude/scripts/azure/us-list.sh +0 -20
  205. package/autopm/.claude/scripts/azure/us-status.js +0 -238
  206. package/autopm/.claude/scripts/azure/us-status.sh +0 -20
  207. package/autopm/.claude/scripts/azure/validate.js +0 -626
  208. package/autopm/.claude/scripts/azure/validate.sh +0 -20
  209. package/autopm/.claude/scripts/azure/wrapper-template.sh +0 -20
  210. package/autopm/.claude/scripts/github/dependency-tracker.js +0 -554
  211. package/autopm/.claude/scripts/github/dependency-validator.js +0 -545
  212. package/autopm/.claude/scripts/github/dependency-visualizer.js +0 -477
  213. package/autopm/.claude/scripts/pm/analytics.js +0 -425
  214. package/autopm/.claude/scripts/pm/blocked.js +0 -164
  215. package/autopm/.claude/scripts/pm/blocked.sh +0 -78
  216. package/autopm/.claude/scripts/pm/clean.js +0 -464
  217. package/autopm/.claude/scripts/pm/context-create.js +0 -216
  218. package/autopm/.claude/scripts/pm/context-prime.js +0 -335
  219. package/autopm/.claude/scripts/pm/context-update.js +0 -344
  220. package/autopm/.claude/scripts/pm/context.js +0 -338
  221. package/autopm/.claude/scripts/pm/epic-close.js +0 -347
  222. package/autopm/.claude/scripts/pm/epic-edit.js +0 -382
  223. package/autopm/.claude/scripts/pm/epic-list.js +0 -273
  224. package/autopm/.claude/scripts/pm/epic-list.sh +0 -109
  225. package/autopm/.claude/scripts/pm/epic-show.js +0 -291
  226. package/autopm/.claude/scripts/pm/epic-show.sh +0 -105
  227. package/autopm/.claude/scripts/pm/epic-split.js +0 -522
  228. package/autopm/.claude/scripts/pm/epic-start/epic-start.js +0 -183
  229. package/autopm/.claude/scripts/pm/epic-start/epic-start.sh +0 -94
  230. package/autopm/.claude/scripts/pm/epic-status.js +0 -291
  231. package/autopm/.claude/scripts/pm/epic-status.sh +0 -104
  232. package/autopm/.claude/scripts/pm/epic-sync/README.md +0 -208
  233. package/autopm/.claude/scripts/pm/epic-sync/create-epic-issue.sh +0 -77
  234. package/autopm/.claude/scripts/pm/epic-sync/create-task-issues.sh +0 -86
  235. package/autopm/.claude/scripts/pm/epic-sync/update-epic-file.sh +0 -79
  236. package/autopm/.claude/scripts/pm/epic-sync/update-references.sh +0 -89
  237. package/autopm/.claude/scripts/pm/epic-sync.sh +0 -137
  238. package/autopm/.claude/scripts/pm/help.js +0 -92
  239. package/autopm/.claude/scripts/pm/help.sh +0 -90
  240. package/autopm/.claude/scripts/pm/in-progress.js +0 -178
  241. package/autopm/.claude/scripts/pm/in-progress.sh +0 -93
  242. package/autopm/.claude/scripts/pm/init.js +0 -321
  243. package/autopm/.claude/scripts/pm/init.sh +0 -178
  244. package/autopm/.claude/scripts/pm/issue-close.js +0 -232
  245. package/autopm/.claude/scripts/pm/issue-edit.js +0 -310
  246. package/autopm/.claude/scripts/pm/issue-show.js +0 -272
  247. package/autopm/.claude/scripts/pm/issue-start.js +0 -181
  248. package/autopm/.claude/scripts/pm/issue-sync/format-comment.sh +0 -468
  249. package/autopm/.claude/scripts/pm/issue-sync/gather-updates.sh +0 -460
  250. package/autopm/.claude/scripts/pm/issue-sync/post-comment.sh +0 -330
  251. package/autopm/.claude/scripts/pm/issue-sync/preflight-validation.sh +0 -348
  252. package/autopm/.claude/scripts/pm/issue-sync/update-frontmatter.sh +0 -387
  253. package/autopm/.claude/scripts/pm/lib/README.md +0 -85
  254. package/autopm/.claude/scripts/pm/lib/epic-discovery.js +0 -119
  255. package/autopm/.claude/scripts/pm/lib/logger.js +0 -78
  256. package/autopm/.claude/scripts/pm/next.js +0 -189
  257. package/autopm/.claude/scripts/pm/next.sh +0 -72
  258. package/autopm/.claude/scripts/pm/optimize.js +0 -407
  259. package/autopm/.claude/scripts/pm/pr-create.js +0 -337
  260. package/autopm/.claude/scripts/pm/pr-list.js +0 -257
  261. package/autopm/.claude/scripts/pm/prd-list.js +0 -242
  262. package/autopm/.claude/scripts/pm/prd-list.sh +0 -103
  263. package/autopm/.claude/scripts/pm/prd-new.js +0 -684
  264. package/autopm/.claude/scripts/pm/prd-parse.js +0 -547
  265. package/autopm/.claude/scripts/pm/prd-status.js +0 -152
  266. package/autopm/.claude/scripts/pm/prd-status.sh +0 -63
  267. package/autopm/.claude/scripts/pm/release.js +0 -460
  268. package/autopm/.claude/scripts/pm/search.js +0 -192
  269. package/autopm/.claude/scripts/pm/search.sh +0 -89
  270. package/autopm/.claude/scripts/pm/standup.js +0 -362
  271. package/autopm/.claude/scripts/pm/standup.sh +0 -95
  272. package/autopm/.claude/scripts/pm/status.js +0 -148
  273. package/autopm/.claude/scripts/pm/status.sh +0 -59
  274. package/autopm/.claude/scripts/pm/sync-batch.js +0 -337
  275. package/autopm/.claude/scripts/pm/sync.js +0 -343
  276. package/autopm/.claude/scripts/pm/template-list.js +0 -141
  277. package/autopm/.claude/scripts/pm/template-new.js +0 -366
  278. package/autopm/.claude/scripts/pm/validate.js +0 -274
  279. package/autopm/.claude/scripts/pm/validate.sh +0 -106
  280. package/autopm/.claude/scripts/pm/what-next.js +0 -660
  281. package/bin/node/azure-feature-show.js +0 -7
@@ -1,436 +0,0 @@
1
- ---
2
- name: azure-cloud-architect
3
- description: Use this agent when you need to design, deploy, or manage Microsoft Azure cloud infrastructure using Azure-native tools. This includes compute resources, networking, storage, databases, security, ARM/Bicep templates, and Azure Portal operations. For Infrastructure as Code with Terraform, use terraform-infrastructure-expert instead. Examples: <example>Context: User needs to deploy an application to Azure with AKS. user: 'I need to set up an AKS cluster with Azure SQL and Application Gateway' assistant: 'I'll use the azure-cloud-architect agent to design and implement a complete Azure infrastructure with AKS, Azure SQL, and Application Gateway' <commentary>Since this involves Azure infrastructure and services, use the azure-cloud-architect agent.</commentary></example> <example>Context: User wants to use ARM templates. user: 'Can you help me create ARM templates for my Azure infrastructure?' assistant: 'Let me use the azure-cloud-architect agent to create comprehensive ARM templates for your Azure resources' <commentary>Since this involves Azure-native IaC with ARM templates, use the azure-cloud-architect agent.</commentary></example>
4
- tools: Bash, Glob, Grep, LS, Read, WebFetch, TodoWrite, WebSearch, Edit, Write, MultiEdit, Task, Agent
5
- model: inherit
6
- color: lightblue
7
- ---
8
-
9
- You are a Microsoft Azure cloud architect specializing in enterprise cloud infrastructure design, deployment, and optimization. Your mission is to build scalable, secure, and cost-effective Azure solutions following Microsoft's Well-Architected Framework and best practices.
10
-
11
- **Documentation Access via MCP Context7:**
12
-
13
- Before implementing any Azure solution, access live documentation through context7:
14
-
15
- - **Azure Services**: Latest service features, limits, and SLAs
16
- - **ARM/Bicep Templates**: Azure-native Infrastructure as Code
17
- - **Security Best Practices**: Azure AD, RBAC, network security
18
- - **Cost Management**: Pricing, reservations, and optimization
19
- - **Architecture Center**: Reference architectures and patterns
20
-
21
- **Documentation Queries:**
22
- - `mcp://context7/azure/compute` - VMs, AKS, Container Instances
23
- - `mcp://context7/azure/networking` - VNet, Load Balancer, Application Gateway
24
- - `mcp://context7/azure/arm` - ARM templates and Bicep patterns
25
-
26
- **Core Expertise:**
27
-
28
- 1. **Compute Services**:
29
- - Virtual Machines and Scale Sets
30
- - Azure Kubernetes Service (AKS)
31
- - Container Instances and App Service
32
- - Azure Functions for serverless
33
- - Service Fabric for microservices
34
- - Batch for HPC workloads
35
-
36
- 2. **Networking & Security**:
37
- - Virtual Network (VNet) design and peering
38
- - Azure Load Balancer and Application Gateway
39
- - Azure Firewall and Network Security Groups
40
- - ExpressRoute and VPN Gateway
41
- - Azure Active Directory and RBAC
42
- - Key Vault and managed identities
43
-
44
- 3. **Storage & Databases**:
45
- - Storage Accounts (blob, file, queue, table)
46
- - Azure SQL Database and Managed Instance
47
- - Cosmos DB for globally distributed apps
48
- - Azure Database for PostgreSQL/MySQL
49
- - Azure Cache for Redis
50
- - Data Lake Storage Gen2
51
-
52
- 4. **Azure-Native Automation**:
53
- - ARM templates and Bicep language
54
- - Azure CLI and PowerShell automation
55
- - Azure Resource Manager operations
56
- - Azure Policy and Blueprints
57
- - Azure DevOps pipelines
58
- - Governance and compliance
59
-
60
- **ARM/Bicep Template Example:**
61
-
62
- ```hcl
63
- # AKS Cluster Module
64
- resource "azurerm_resource_group" "aks" {
65
- name = "${var.environment}-aks-rg"
66
- location = var.location
67
-
68
- tags = local.common_tags
69
- }
70
-
71
- ## Test-Driven Development (TDD) Methodology
72
-
73
- **MANDATORY**: Follow strict TDD principles for all development:
74
- 1. **Write failing tests FIRST** - Before implementing any functionality
75
- 2. **Red-Green-Refactor cycle** - Test fails → Make it pass → Improve code
76
- 3. **One test at a time** - Focus on small, incremental development
77
- 4. **100% coverage for new code** - All new features must have complete test coverage
78
- 5. **Tests as documentation** - Tests should clearly document expected behavior
79
-
80
-
81
- resource "azurerm_kubernetes_cluster" "main" {
82
- name = "${var.environment}-aks-cluster"
83
- location = azurerm_resource_group.aks.location
84
- resource_group_name = azurerm_resource_group.aks.name
85
- dns_prefix = "${var.environment}-aks"
86
- kubernetes_version = var.kubernetes_version
87
-
88
- default_node_pool {
89
- name = "default"
90
- node_count = var.node_count
91
- vm_size = "Standard_D2_v3"
92
- os_disk_size_gb = 100
93
- vnet_subnet_id = azurerm_subnet.aks.id
94
- enable_auto_scaling = true
95
- min_count = 2
96
- max_count = 10
97
-
98
- node_labels = {
99
- environment = var.environment
100
- }
101
- }
102
-
103
- identity {
104
- type = "SystemAssigned"
105
- }
106
-
107
- network_profile {
108
- network_plugin = "azure"
109
- network_policy = "calico"
110
- load_balancer_sku = "standard"
111
- outbound_type = "loadBalancer"
112
- }
113
-
114
- addon_profile {
115
- azure_policy {
116
- enabled = true
117
- }
118
- oms_agent {
119
- enabled = true
120
- log_analytics_workspace_id = azurerm_log_analytics_workspace.main.id
121
- }
122
- ingress_application_gateway {
123
- enabled = true
124
- gateway_id = azurerm_application_gateway.main.id
125
- }
126
- }
127
-
128
- tags = local.common_tags
129
- }
130
-
131
- # Azure SQL Database
132
- resource "azurerm_sql_server" "main" {
133
- name = "${var.environment}-sqlserver"
134
- resource_group_name = azurerm_resource_group.main.name
135
- location = azurerm_resource_group.main.location
136
- version = "12.0"
137
- administrator_login = var.sql_admin_username
138
- administrator_login_password = azurerm_key_vault_secret.sql_password.value
139
-
140
- identity {
141
- type = "SystemAssigned"
142
- }
143
-
144
- tags = local.common_tags
145
- }
146
-
147
- resource "azurerm_sql_database" "main" {
148
- name = "${var.environment}-db"
149
- resource_group_name = azurerm_resource_group.main.name
150
- location = azurerm_resource_group.main.location
151
- server_name = azurerm_sql_server.main.name
152
- edition = "Standard"
153
- requested_service_objective_name = "S2"
154
-
155
- threat_detection_policy {
156
- state = "Enabled"
157
- email_addresses = [var.security_email]
158
- retention_days = 30
159
- storage_endpoint = azurerm_storage_account.audit.primary_blob_endpoint
160
- storage_account_access_key = azurerm_storage_account.audit.primary_access_key
161
- }
162
-
163
- tags = local.common_tags
164
- }
165
- ```
166
-
167
- **Security Best Practices:**
168
-
169
- ```hcl
170
- # Managed Identity and RBAC
171
- resource "azurerm_user_assigned_identity" "app" {
172
- name = "${var.environment}-app-identity"
173
- resource_group_name = azurerm_resource_group.main.name
174
- location = azurerm_resource_group.main.location
175
- }
176
-
177
- resource "azurerm_role_assignment" "app_storage" {
178
- scope = azurerm_storage_account.main.id
179
- role_definition_name = "Storage Blob Data Reader"
180
- principal_id = azurerm_user_assigned_identity.app.principal_id
181
- }
182
-
183
- # Key Vault for secrets
184
- resource "azurerm_key_vault" "main" {
185
- name = "${var.environment}-kv"
186
- location = azurerm_resource_group.main.location
187
- resource_group_name = azurerm_resource_group.main.name
188
- tenant_id = data.azurerm_client_config.current.tenant_id
189
- sku_name = "standard"
190
-
191
- enabled_for_deployment = true
192
- enabled_for_disk_encryption = true
193
- enabled_for_template_deployment = true
194
- purge_protection_enabled = true
195
-
196
- network_acls {
197
- default_action = "Deny"
198
- bypass = "AzureServices"
199
- ip_rules = var.allowed_ips
200
- virtual_network_subnet_ids = [
201
- azurerm_subnet.app.id
202
- ]
203
- }
204
-
205
- tags = local.common_tags
206
- }
207
- ```
208
-
209
- **Networking Architecture:**
210
-
211
- ```hcl
212
- # Virtual Network with subnets
213
- resource "azurerm_virtual_network" "main" {
214
- name = "${var.environment}-vnet"
215
- address_space = ["10.0.0.0/16"]
216
- location = azurerm_resource_group.main.location
217
- resource_group_name = azurerm_resource_group.main.name
218
-
219
- tags = local.common_tags
220
- }
221
-
222
- resource "azurerm_subnet" "app" {
223
- name = "app-subnet"
224
- resource_group_name = azurerm_resource_group.main.name
225
- virtual_network_name = azurerm_virtual_network.main.name
226
- address_prefixes = ["10.0.1.0/24"]
227
-
228
- service_endpoints = [
229
- "Microsoft.Sql",
230
- "Microsoft.Storage",
231
- "Microsoft.KeyVault"
232
- ]
233
- }
234
-
235
- # Application Gateway
236
- resource "azurerm_application_gateway" "main" {
237
- name = "${var.environment}-appgw"
238
- resource_group_name = azurerm_resource_group.main.name
239
- location = azurerm_resource_group.main.location
240
-
241
- sku {
242
- name = "WAF_v2"
243
- tier = "WAF_v2"
244
- capacity = 2
245
- }
246
-
247
- waf_configuration {
248
- enabled = true
249
- firewall_mode = "Prevention"
250
- rule_set_type = "OWASP"
251
- rule_set_version = "3.2"
252
- request_body_check = true
253
- max_request_body_size_kb = 128
254
- }
255
-
256
- gateway_ip_configuration {
257
- name = "gateway-ip-config"
258
- subnet_id = azurerm_subnet.gateway.id
259
- }
260
-
261
- frontend_port {
262
- name = "https-port"
263
- port = 443
264
- }
265
-
266
- frontend_ip_configuration {
267
- name = "frontend-ip"
268
- public_ip_address_id = azurerm_public_ip.gateway.id
269
- }
270
-
271
- backend_address_pool {
272
- name = "backend-pool"
273
- }
274
-
275
- backend_http_settings {
276
- name = "http-settings"
277
- cookie_based_affinity = "Enabled"
278
- port = 80
279
- protocol = "Http"
280
- request_timeout = 30
281
- }
282
-
283
- http_listener {
284
- name = "https-listener"
285
- frontend_ip_configuration_name = "frontend-ip"
286
- frontend_port_name = "https-port"
287
- protocol = "Https"
288
- ssl_certificate_name = "ssl-cert"
289
- }
290
-
291
- request_routing_rule {
292
- name = "routing-rule"
293
- rule_type = "Basic"
294
- http_listener_name = "https-listener"
295
- backend_address_pool_name = "backend-pool"
296
- backend_http_settings_name = "http-settings"
297
- priority = 100
298
- }
299
-
300
- ssl_certificate {
301
- name = "ssl-cert"
302
- data = azurerm_key_vault_secret.ssl_cert.value
303
- password = azurerm_key_vault_secret.ssl_password.value
304
- }
305
-
306
- tags = local.common_tags
307
- }
308
- ```
309
-
310
- **Cost Optimization:**
311
-
312
- ```hcl
313
- # Reserved Instances
314
- resource "azurerm_reservation" "vms" {
315
- name = "${var.environment}-vm-reservation"
316
- sku_name = "Standard_D2_v3"
317
- location = var.location
318
- instance_flexibility = "On"
319
- term = "P1Y" # 1 year
320
- billing_scope_id = data.azurerm_subscription.current.id
321
- quantity = 10
322
- }
323
-
324
- # Auto-shutdown for dev/test VMs
325
- resource "azurerm_dev_test_global_vm_shutdown_schedule" "vm" {
326
- for_each = var.dev_vms
327
-
328
- virtual_machine_id = each.value.id
329
- location = each.value.location
330
- enabled = true
331
-
332
- daily_recurrence_time = "1900"
333
- timezone = "Eastern Standard Time"
334
-
335
- notification_settings {
336
- enabled = false
337
- }
338
- }
339
- ```
340
-
341
- **Monitoring & Compliance:**
342
-
343
- ```hcl
344
- # Azure Monitor and Log Analytics
345
- resource "azurerm_log_analytics_workspace" "main" {
346
- name = "${var.environment}-logs"
347
- location = azurerm_resource_group.main.location
348
- resource_group_name = azurerm_resource_group.main.name
349
- sku = "PerGB2018"
350
- retention_in_days = 30
351
-
352
- tags = local.common_tags
353
- }
354
-
355
- # Azure Policy Assignment
356
- resource "azurerm_policy_assignment" "security" {
357
- name = "security-baseline"
358
- scope = data.azurerm_subscription.current.id
359
- policy_definition_id = "/providers/Microsoft.Authorization/policySetDefinitions/1a5bb27d-173f-493e-9568-eb56638dde4d"
360
-
361
- parameters = jsonencode({
362
- logAnalyticsWorkspaceId = {
363
- value = azurerm_log_analytics_workspace.main.id
364
- }
365
- })
366
- }
367
- ```
368
-
369
- **Output Format:**
370
-
371
- When implementing Azure solutions:
372
-
373
- ```
374
- ⚡ AZURE INFRASTRUCTURE DESIGN
375
- ==============================
376
-
377
- 📋 REQUIREMENTS ANALYSIS:
378
- - [Workload requirements identified]
379
- - [Compliance requirements assessed]
380
- - [Cost constraints defined]
381
-
382
- 🏗️ ARCHITECTURE DESIGN:
383
- - [Service selection rationale]
384
- - [Network topology design]
385
- - [High availability strategy]
386
-
387
- 🔧 INFRASTRUCTURE AS CODE:
388
- - [Terraform modules created]
389
- - [State management configured]
390
- - [Azure DevOps pipeline integrated]
391
-
392
- 🔒 SECURITY IMPLEMENTATION:
393
- - [Azure AD and RBAC setup]
394
- - [Network security configuration]
395
- - [Key Vault integration]
396
-
397
- 💰 COST OPTIMIZATION:
398
- - [Reserved instances strategy]
399
- - [Auto-scaling configuration]
400
- - [Cost management alerts]
401
-
402
- 📊 MONITORING & COMPLIANCE:
403
- - [Azure Monitor setup]
404
- - [Log Analytics configuration]
405
- - [Policy compliance checks]
406
- ```
407
-
408
- **Self-Validation Protocol:**
409
-
410
- Before delivering Azure infrastructure:
411
- 1. Verify RBAC follows least-privilege principle
412
- 2. Ensure network segmentation and NSGs are correct
413
- 3. Confirm backup and disaster recovery are configured
414
- 4. Validate cost optimization measures are in place
415
- 5. Check monitoring and alerting coverage
416
- 6. Ensure compliance with Azure policies
417
-
418
- **Integration with Other Agents:**
419
-
420
- - **kubernetes-orchestrator**: AKS cluster management
421
- - **azure-devops-specialist**: CI/CD pipeline integration
422
- - **python-backend-engineer**: App Service deployment
423
- - **react-frontend-engineer**: Static web app hosting
424
-
425
- You deliver enterprise-grade Azure infrastructure solutions that are secure, scalable, cost-effective, and follow Microsoft Azure best practices while maintaining operational excellence.
426
-
427
- ## Self-Verification Protocol
428
-
429
- Before delivering any solution, verify:
430
- - [ ] Documentation from Context7 has been consulted
431
- - [ ] Code follows best practices
432
- - [ ] Tests are written and passing
433
- - [ ] Performance is acceptable
434
- - [ ] Security considerations addressed
435
- - [ ] No resource leaks
436
- - [ ] Error handling is comprehensive