@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,453 +1,413 @@
1
- # Microsoft Agent Framework - Setup Obrigatório (.NET 10)
2
-
3
- > **IMPORTANTE:** O MORPH-SPEC usa **exclusivamente** o Microsoft Agent Framework.
4
- > Semantic Kernel foi descontinuado. Não use mais.
5
-
6
- ---
7
-
8
- ## 📦 Packages Necessários
9
-
10
- ```xml
11
- <!-- .csproj -->
12
- <PackageReference Include="Microsoft.Agents.AI" Version="1.0.0" />
13
- ```
14
-
15
- **Nota:** O package `Microsoft.Agents.AI` já traz as dependências:
16
- - `Microsoft.Extensions.AI`
17
- - `OpenAI` (cliente)
18
- - Suporte a múltiplos providers (Azure OpenAI, GitHub Models, Ollama)
19
-
20
- ---
21
-
22
- ## ⚙️ Configuração no Program.cs
23
-
24
- ### 1. Registrar ChatClient (Azure OpenAI)
25
-
26
- ```csharp
27
- using Microsoft.Extensions.AI;
28
-
29
- var builder = WebApplication.CreateBuilder(args);
30
-
31
- // Registrar ChatClient como singleton
32
- builder.Services.AddSingleton<IChatClient>(sp =>
33
- {
34
- var config = sp.GetRequiredService<IConfiguration>();
35
-
36
- return new ChatClient(
37
- model: "gpt-4o-mini", // Modelo padrão para tasks simples
38
- credential: new ApiKeyCredential(config["AzureOpenAI:ApiKey"]!),
39
- endpoint: new Uri(config["AzureOpenAI:Endpoint"]!)
40
- );
41
- });
42
- ```
43
-
44
- ### 2. Registrar ChatClient (GitHub Models - Desenvolvimento)
45
-
46
- ```csharp
47
- builder.Services.AddSingleton<IChatClient>(sp =>
48
- {
49
- var config = sp.GetRequiredService<IConfiguration>();
50
-
51
- return new ChatClient(
52
- model: "gpt-4.1-mini",
53
- credential: new ApiKeyCredential(config["GitHub:Token"]!),
54
- endpoint: new Uri("https://models.github.com")
55
- );
56
- });
57
- ```
58
-
59
- ### 3. Registrar ChatClient (Ollama - Local)
60
-
61
- ```csharp
62
- builder.Services.AddSingleton<IChatClient>(sp =>
63
- {
64
- return new ChatClient(
65
- model: "llama3.2:3b",
66
- endpoint: new Uri("http://localhost:11434")
67
- );
68
- });
69
- ```
70
-
71
- **Escolha o provider adequado ao ambiente.**
72
-
73
- ---
74
-
75
- ## 🤖 Pattern de Agent (Obrigatório)
76
-
77
- ### Interface do Agent
78
-
79
- ```csharp
80
- public interface IOrderAnalysisAgent
81
- {
82
- Task<string> AnalyzeAsync(Order order, CancellationToken ct = default);
83
- }
84
- ```
85
-
86
- ### Implementação do Agent
87
-
88
- ```csharp
89
- using Microsoft.Agents.AI;
90
-
91
- public class OrderAnalysisAgent : IOrderAnalysisAgent
92
- {
93
- private readonly IChatClient _chatClient;
94
- private readonly ILogger<OrderAnalysisAgent> _logger;
95
-
96
- public OrderAnalysisAgent(
97
- IChatClient chatClient,
98
- ILogger<OrderAnalysisAgent> logger)
99
- {
100
- _chatClient = chatClient;
101
- _logger = logger;
102
- }
103
-
104
- public async Task<string> AnalyzeAsync(Order order, CancellationToken ct = default)
105
- {
106
- // Criar agente com instruções específicas
107
- var agent = _chatClient.CreateAgent(
108
- instructions: """
109
- Você é um especialista em análise de pedidos de e-commerce.
110
-
111
- Analise o pedido fornecido e retorne:
112
- 1. Resumo do pedido
113
- 2. Sugestões de upsell baseadas nos itens
114
- 3. Risco de cancelamento (baixo/médio/alto) com justificativa
115
-
116
- Seja conciso e objetivo.
117
- """,
118
- name: "OrderAnalyzer"
119
- );
120
-
121
- // Criar prompt com dados do pedido
122
- var prompt = $"""
123
- Pedido: {order.OrderNumber}
124
- Total: {order.Total:C}
125
- Itens: {order.Items.Count}
126
- Cliente: {order.Customer.Name}
127
- Histórico: {order.Customer.TotalOrders} pedidos anteriores
128
-
129
- Analise este pedido.
130
- """;
131
-
132
- _logger.LogInformation("Analisando pedido {OrderNumber}", order.OrderNumber);
133
-
134
- // Executar agente
135
- var response = await agent.RunAsync(prompt, cancellationToken: ct);
136
-
137
- return response.Content;
138
- }
139
- }
140
- ```
141
-
142
- ### Registrar Agent como Service
143
-
144
- ```csharp
145
- // Program.cs
146
- builder.Services.AddScoped<IOrderAnalysisAgent, OrderAnalysisAgent>();
147
- ```
148
-
149
- ---
150
-
151
- ## 🔧 Agents com Tools (Function Calling)
152
-
153
- ### Definir Tools
154
-
155
- ```csharp
156
- public class WeatherAgent
157
- {
158
- private readonly IChatClient _chatClient;
159
- private readonly IWeatherService _weatherService;
160
-
161
- public WeatherAgent(IChatClient chatClient, IWeatherService weatherService)
162
- {
163
- _chatClient = chatClient;
164
- _weatherService = weatherService;
165
- }
166
-
167
- // Tool 1: Buscar clima
168
- [AgentTool("get_weather")]
169
- [Description("Busca o clima atual de uma cidade")]
170
- public async Task<string> GetWeatherAsync(
171
- [Description("Nome da cidade")] string city,
172
- CancellationToken ct = default)
173
- {
174
- var weather = await _weatherService.GetCurrentWeatherAsync(city, ct);
175
- return $"Temp: {weather.Temperature}°C, Condição: {weather.Condition}";
176
- }
177
-
178
- // Tool 2: Previsão
179
- [AgentTool("get_forecast")]
180
- [Description("Busca a previsão para os próximos dias")]
181
- public async Task<string> GetForecastAsync(
182
- [Description("Nome da cidade")] string city,
183
- [Description("Número de dias")] int days = 3,
184
- CancellationToken ct = default)
185
- {
186
- var forecast = await _weatherService.GetForecastAsync(city, days, ct);
187
- return string.Join("\n", forecast.Select(f => $"{f.Date:dd/MM}: {f.Temperature}°C"));
188
- }
189
-
190
- public async Task<string> ChatAsync(string userMessage, CancellationToken ct = default)
191
- {
192
- // Criar agente com tools
193
- var agent = _chatClient.CreateAgent(
194
- instructions: """
195
- Você é um assistente de clima.
196
- Use as tools disponíveis para responder perguntas sobre o tempo.
197
- Seja amigável e informativo.
198
- """,
199
- name: "WeatherAssistant",
200
- tools: new[]
201
- {
202
- AgentTool.FromMethod(nameof(GetWeatherAsync), this),
203
- AgentTool.FromMethod(nameof(GetForecastAsync), this)
204
- }
205
- );
206
-
207
- var response = await agent.RunAsync(userMessage, cancellationToken: ct);
208
- return response.Content;
209
- }
210
- }
211
- ```
212
-
213
- **Nota:** Cada método com `[AgentTool]` vira uma tool que o agente pode chamar automaticamente.
214
-
215
- ---
216
-
217
- ## 💬 Threads (Persistência de Conversação)
218
-
219
- ### Criar e Usar Thread
220
-
221
- ```csharp
222
- public class ChatService
223
- {
224
- private readonly IChatClient _chatClient;
225
- private readonly Dictionary<string, AgentThread> _threads = new();
226
-
227
- public async Task<string> StartConversationAsync(string userId)
228
- {
229
- var agent = _chatClient.CreateAgent(
230
- instructions: "Você é um assistente útil e amigável.",
231
- name: "ChatAssistant"
232
- );
233
-
234
- // Criar thread
235
- var thread = await agent.CreateThreadAsync();
236
-
237
- // Armazenar thread ID para o usuário
238
- _threads[userId] = thread;
239
-
240
- return thread.Id;
241
- }
242
-
243
- public async Task<string> SendMessageAsync(
244
- string userId,
245
- string message,
246
- CancellationToken ct = default)
247
- {
248
- if (!_threads.TryGetValue(userId, out var thread))
249
- throw new InvalidOperationException("Thread não encontrada");
250
-
251
- var agent = _chatClient.CreateAgent(
252
- instructions: "Você é um assistente útil e amigável.",
253
- name: "ChatAssistant"
254
- );
255
-
256
- // Adicionar mensagem do usuário
257
- await thread.AddMessageAsync(message, ct);
258
-
259
- // Executar agente no contexto do thread
260
- var response = await agent.RunAsync(thread, cancellationToken: ct);
261
-
262
- // Histórico é mantido automaticamente
263
- return response.Content;
264
- }
265
- }
266
- ```
267
-
268
- **Vantagem:** Threads mantêm todo o histórico da conversa automaticamente.
269
-
270
- ---
271
-
272
- ## 🔄 Multi-Agent Communication (A2A)
273
-
274
- ### Agent-to-Agent Pattern
275
-
276
- ```csharp
277
- public class ResearchAgent
278
- {
279
- private readonly IChatClient _chatClient;
280
-
281
- public async Task<string> ResearchTopicAsync(string topic)
282
- {
283
- // Agent 1: Researcher
284
- var researcher = _chatClient.CreateAgent(
285
- instructions: "Você pesquisa tópicos e fornece informações detalhadas.",
286
- name: "Researcher"
287
- );
288
-
289
- // Agent 2: Summarizer
290
- var summarizer = _chatClient.CreateAgent(
291
- instructions: "Você resume textos longos de forma concisa.",
292
- name: "Summarizer"
293
- );
294
-
295
- // Passo 1: Pesquisar
296
- var research = await researcher.RunAsync($"Pesquise sobre: {topic}");
297
-
298
- // Passo 2: Resumir resultado da pesquisa
299
- var summary = await summarizer.RunAsync(
300
- $"Resuma o seguinte texto:\n\n{research.Content}"
301
- );
302
-
303
- return summary.Content;
304
- }
305
- }
306
- ```
307
-
308
- ---
309
-
310
- ## 📊 Modelos Recomendados
311
-
312
- | Uso | Modelo | Provider | Custo |
313
- |-----|--------|----------|-------|
314
- | Tarefas simples | gpt-4o-mini | Azure OpenAI | $0.15/1M input |
315
- | Análise complexa | gpt-4o | Azure OpenAI | $2.50/1M input |
316
- | Desenvolvimento local | llama3.2:3b | Ollama | Grátis |
317
- | Desenvolvimento cloud | gpt-4.1-mini | GitHub Models | Grátis (beta) |
318
-
319
- **Padrão MORPH-SPEC:** `gpt-4o-mini` para produção.
320
-
321
- ---
322
-
323
- ## 🔐 Segurança
324
-
325
- ### API Keys no Azure Key Vault
326
-
327
- ```csharp
328
- // Program.cs
329
- if (builder.Environment.IsProduction())
330
- {
331
- var keyVaultUri = new Uri(builder.Configuration["KeyVault:Uri"]!);
332
- builder.Configuration.AddAzureKeyVault(keyVaultUri, new DefaultAzureCredential());
333
- }
334
-
335
- builder.Services.AddSingleton<IChatClient>(sp =>
336
- {
337
- var config = sp.GetRequiredService<IConfiguration>();
338
-
339
- // API Key vem do Key Vault em produção
340
- var apiKey = config["AzureOpenAI:ApiKey"]!;
341
- var endpoint = config["AzureOpenAI:Endpoint"]!;
342
-
343
- return new ChatClient(
344
- model: "gpt-4o-mini",
345
- credential: new ApiKeyCredential(apiKey),
346
- endpoint: new Uri(endpoint)
347
- );
348
- });
349
- ```
350
-
351
- ### Managed Identity (Recomendado)
352
-
353
- ```csharp
354
- builder.Services.AddSingleton<IChatClient>(sp =>
355
- {
356
- var config = sp.GetRequiredService<IConfiguration>();
357
- var endpoint = config["AzureOpenAI:Endpoint"]!;
358
-
359
- return new ChatClient(
360
- model: "gpt-4o-mini",
361
- credential: new DefaultAzureCredential(), // Managed Identity
362
- endpoint: new Uri(endpoint)
363
- );
364
- });
365
- ```
366
-
367
- ---
368
-
369
- ## 📈 Observabilidade com .NET Aspire
370
-
371
- ### Integrar com Aspire Dashboard
372
-
373
- ```csharp
374
- // Program.cs
375
- builder.Services.AddOpenTelemetry()
376
- .WithTracing(tracing =>
377
- {
378
- tracing.AddSource("Microsoft.Agents.AI");
379
- tracing.AddAspireTracing();
380
- })
381
- .WithMetrics(metrics =>
382
- {
383
- metrics.AddMeter("Microsoft.Agents.AI");
384
- metrics.AddAspireMetrics();
385
- });
386
- ```
387
-
388
- **Resultado:** Visualize chamadas a agentes e tools no Aspire Dashboard.
389
-
390
- ---
391
-
392
- ## ⚠️ Limitações e Troubleshooting
393
-
394
- ### Tool Calling com Modelos Pequenos
395
-
396
- **Problema:** Modelos abaixo de 3B parâmetros não fazem tool calling bem.
397
-
398
- **Solução:** Use `gpt-4o-mini` (mínimo) para agents com tools.
399
-
400
- ### Rate Limits
401
-
402
- ```csharp
403
- public async Task<string> AnalyzeWithRetryAsync(Order order, CancellationToken ct = default)
404
- {
405
- var retryPolicy = Policy
406
- .Handle<RateLimitException>()
407
- .WaitAndRetryAsync(3, attempt => TimeSpan.FromSeconds(Math.Pow(2, attempt)));
408
-
409
- return await retryPolicy.ExecuteAsync(async () =>
410
- {
411
- var agent = _chatClient.CreateAgent(...);
412
- var response = await agent.RunAsync(..., cancellationToken: ct);
413
- return response.Content;
414
- });
415
- }
416
- ```
417
-
418
- ---
419
-
420
- ## ✅ Checklist de Implementação
421
-
422
- - [ ] Package `Microsoft.Agents.AI` instalado
423
- - [ ] `IChatClient` registrado como singleton
424
- - [ ] Agents criados com `client.CreateAgent()`
425
- - [ ] Agents registrados como services (scoped/transient)
426
- - [ ] API keys no Key Vault (produção)
427
- - [ ] Logging configurado para agents
428
- - [ ] Observabilidade com Aspire (opcional)
429
- - [ ] Error handling para rate limits
430
- - [ ] Testes de integração para agents
431
-
432
- ---
433
-
434
- ## 🚫 O Que NÃO Fazer
435
-
436
- ❌ Usar Semantic Kernel
437
- ❌ Usar `Kernel.CreateFunctionFromPrompt()`
438
- ❌ Usar `ChatHistory` (use Threads)
439
- ❌ Hardcoded API keys
440
- ❌ Modelos pequenos (<3B) para tool calling
441
-
442
- ---
443
-
444
- ## 📚 Referências
445
-
446
- - [Microsoft Agent Framework Documentation](https://learn.microsoft.com/agent-framework/)
447
- - [Agent Framework GitHub](https://github.com/microsoft/agent-framework)
448
- - [Microsoft.Extensions.AI](https://learn.microsoft.com/dotnet/ai/ai-extensions)
449
- - [Azure OpenAI Service](https://learn.microsoft.com/azure/ai-services/openai/)
450
-
451
- ---
452
-
453
- *MORPH-SPEC by Polymorphism Tech*
1
+ # Microsoft Agent Framework - Setup Guide (.NET 10)
2
+
3
+ > **IMPORTANT:** MORPH-SPEC uses **exclusively** Microsoft Agent Framework.
4
+ > Semantic Kernel is superseded. Do NOT use `Kernel`, `KernelFunction`, or `InvokePromptAsync`.
5
+
6
+ ---
7
+
8
+ ## Packages
9
+
10
+ ```xml
11
+ <!-- .csproj -->
12
+ <PackageReference Include="Microsoft.Agents.AI" Version="1.0.0-preview.*" />
13
+ <PackageReference Include="Microsoft.Agents.AI.Abstractions" Version="1.0.0-preview.*" />
14
+ <PackageReference Include="Microsoft.Agents.AI.OpenAI" Version="1.0.0-preview.*" />
15
+
16
+ <!-- For Web API hosting + A2A -->
17
+ <PackageReference Include="Microsoft.Agents.AI.Hosting" Version="1.0.0-preview.*" />
18
+
19
+ <!-- For Azure OpenAI -->
20
+ <PackageReference Include="Azure.AI.OpenAI" Version="2.*" />
21
+ <PackageReference Include="Azure.Identity" Version="1.*" />
22
+
23
+ <!-- For Microsoft.Extensions.AI abstractions -->
24
+ <PackageReference Include="Microsoft.Extensions.AI" Version="10.2.0" />
25
+ <PackageReference Include="Microsoft.Extensions.AI.OpenAI" Version="9.3.0-preview.*" />
26
+ ```
27
+
28
+ ---
29
+
30
+ ## Quick Start (Minimal Agent)
31
+
32
+ ```csharp
33
+ using Azure.AI.OpenAI;
34
+ using Azure.Identity;
35
+ using Microsoft.Agents.AI;
36
+
37
+ AIAgent agent = new AzureOpenAIClient(
38
+ new Uri("https://your-resource.openai.azure.com/"),
39
+ new AzureCliCredential())
40
+ .GetChatClient("gpt-4o-mini")
41
+ .AsAIAgent(instructions: "You are a helpful assistant.");
42
+
43
+ Console.WriteLine(await agent.RunAsync("Analyze this order."));
44
+ ```
45
+
46
+ ---
47
+
48
+ ## Setup by Provider
49
+
50
+ ### Azure OpenAI (Production)
51
+
52
+ ```csharp
53
+ using Azure.AI.OpenAI;
54
+ using Azure.Identity;
55
+ using Microsoft.Extensions.AI;
56
+
57
+ builder.Services.AddSingleton<IChatClient>(sp =>
58
+ {
59
+ var cfg = sp.GetRequiredService<IConfiguration>();
60
+ return new AzureOpenAIClient(
61
+ new Uri(cfg["AzureOpenAI:Endpoint"]!),
62
+ new DefaultAzureCredential()) // Managed Identity
63
+ .GetChatClient(cfg["AzureOpenAI:DeploymentName"] ?? "gpt-4o-mini")
64
+ .AsIChatClient();
65
+ });
66
+ ```
67
+
68
+ ### GitHub Models (Development)
69
+
70
+ ```csharp
71
+ using OpenAI;
72
+ using Microsoft.Extensions.AI;
73
+
74
+ builder.Services.AddSingleton<IChatClient>(sp =>
75
+ {
76
+ var cfg = sp.GetRequiredService<IConfiguration>();
77
+ return new ChatClient(
78
+ "gpt-4o-mini",
79
+ new ApiKeyCredential(cfg["GitHub:Token"]!),
80
+ new OpenAIClientOptions { Endpoint = new Uri("https://models.github.ai/inference") })
81
+ .AsIChatClient();
82
+ });
83
+ ```
84
+
85
+ ### Ollama (Local)
86
+
87
+ ```csharp
88
+ builder.Services.AddSingleton<IChatClient>(sp =>
89
+ new ChatClient("llama3.2:3b",
90
+ endpoint: new Uri("http://localhost:11434"))
91
+ .AsIChatClient());
92
+ ```
93
+
94
+ ---
95
+
96
+ ## Agent Pattern (Required)
97
+
98
+ ### Using ChatClientAgent
99
+
100
+ ```csharp
101
+ using Microsoft.Agents.AI;
102
+ using Microsoft.Extensions.AI;
103
+
104
+ public class OrderAnalysisAgent
105
+ {
106
+ private readonly IChatClient _chatClient;
107
+ private readonly ILogger<OrderAnalysisAgent> _logger;
108
+
109
+ public OrderAnalysisAgent(IChatClient chatClient, ILogger<OrderAnalysisAgent> logger)
110
+ {
111
+ _chatClient = chatClient;
112
+ _logger = logger;
113
+ }
114
+
115
+ public async Task<string> AnalyzeAsync(Order order, CancellationToken ct = default)
116
+ {
117
+ var agent = new ChatClientAgent(
118
+ _chatClient,
119
+ new ChatClientAgentOptions
120
+ {
121
+ Name = "OrderAnalyzer",
122
+ Instructions = """
123
+ You are an e-commerce order analyst.
124
+ Analyze the order and return:
125
+ 1. Summary
126
+ 2. Upsell suggestions
127
+ 3. Cancellation risk (low/medium/high)
128
+ Be concise.
129
+ """
130
+ });
131
+
132
+ _logger.LogInformation("Analyzing order {OrderNumber}", order.OrderNumber);
133
+
134
+ var response = await agent.RunAsync(
135
+ $"Order: {order.OrderNumber}, Total: {order.Total:C}, Items: {order.Items.Count}",
136
+ cancellationToken: ct);
137
+
138
+ return response.Text;
139
+ }
140
+ }
141
+ ```
142
+
143
+ ### Using AsAIAgent (Shorthand)
144
+
145
+ ```csharp
146
+ AIAgent agent = chatClient.AsAIAgent(
147
+ instructions: "You are a helpful assistant.",
148
+ name: "MyAgent");
149
+
150
+ var response = await agent.RunAsync("Hello!", cancellationToken: ct);
151
+ Console.WriteLine(response.Text);
152
+ ```
153
+
154
+ ---
155
+
156
+ ## Tools (Function Calling)
157
+
158
+ ### Define Tools with AIFunctionFactory
159
+
160
+ ```csharp
161
+ using Microsoft.Extensions.AI;
162
+
163
+ public class WeatherFunctions
164
+ {
165
+ private readonly IWeatherService _weatherService;
166
+
167
+ public WeatherFunctions(IWeatherService weatherService) => _weatherService = weatherService;
168
+
169
+ [Description("Gets current weather for a city")]
170
+ public async Task<string> GetWeatherAsync(
171
+ [Description("City name")] string city,
172
+ CancellationToken ct = default)
173
+ {
174
+ var weather = await _weatherService.GetCurrentAsync(city, ct);
175
+ return $"Temp: {weather.Temperature}°C, Condition: {weather.Condition}";
176
+ }
177
+
178
+ [Description("Gets weather forecast for upcoming days")]
179
+ public async Task<string> GetForecastAsync(
180
+ [Description("City name")] string city,
181
+ [Description("Number of days")] int days = 3,
182
+ CancellationToken ct = default)
183
+ {
184
+ var forecast = await _weatherService.GetForecastAsync(city, days, ct);
185
+ return string.Join("\n", forecast.Select(f => $"{f.Date:dd/MM}: {f.Temperature}°C"));
186
+ }
187
+ }
188
+ ```
189
+
190
+ ### Register Agent with Tools
191
+
192
+ ```csharp
193
+ var weatherFunctions = new WeatherFunctions(weatherService);
194
+
195
+ var agent = new ChatClientAgent(
196
+ chatClient,
197
+ new ChatClientAgentOptions
198
+ {
199
+ Name = "WeatherAssistant",
200
+ Instructions = "You help with weather questions. Use available tools.",
201
+ ChatOptions = new ChatOptions
202
+ {
203
+ Tools =
204
+ [
205
+ AIFunctionFactory.Create(weatherFunctions.GetWeatherAsync),
206
+ AIFunctionFactory.Create(weatherFunctions.GetForecastAsync)
207
+ ]
208
+ }
209
+ });
210
+ ```
211
+
212
+ ### Static Function Tools
213
+
214
+ ```csharp
215
+ [Description("Gets the current date and time")]
216
+ static string GetCurrentDateTime() => DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
217
+
218
+ var agent = chatClient.AsAIAgent(
219
+ instructions: "You are a helpful assistant.",
220
+ tools: [AIFunctionFactory.Create(GetCurrentDateTime)]);
221
+ ```
222
+
223
+ ---
224
+
225
+ ## Dependency Injection (Web API / Blazor)
226
+
227
+ ### Register Agents with Keyed Services
228
+
229
+ ```csharp
230
+ // Program.cs
231
+ builder.AddAIAgent("OrderAnalyzer", (sp, key) =>
232
+ {
233
+ var chatClient = sp.GetRequiredService<IChatClient>();
234
+ var orderFunctions = sp.GetRequiredService<OrderFunctions>();
235
+
236
+ return new ChatClientAgent(
237
+ chatClient,
238
+ name: key,
239
+ instructions: "You are an order analysis expert.",
240
+ tools:
241
+ [
242
+ AIFunctionFactory.Create(orderFunctions.GetOrderAsync),
243
+ AIFunctionFactory.Create(orderFunctions.CalculateDiscountAsync)
244
+ ]);
245
+ });
246
+
247
+ // Simple agent (no tools)
248
+ builder.AddAIAgent(
249
+ name: "Editor",
250
+ instructions: "You are an editor who improves text quality.");
251
+ ```
252
+
253
+ ### Inject in Controllers / Blazor Components
254
+
255
+ ```csharp
256
+ // Controller
257
+ public class AgentController(
258
+ [FromKeyedServices("OrderAnalyzer")] AIAgent orderAgent) : ControllerBase
259
+ {
260
+ [HttpPost("analyze")]
261
+ public async Task<IActionResult> Analyze(OrderRequest request)
262
+ {
263
+ var response = await orderAgent.RunAsync(request.Prompt);
264
+ return Ok(response.Text);
265
+ }
266
+ }
267
+
268
+ // Blazor component
269
+ @inject IServiceProvider ServiceProvider
270
+ @code {
271
+ private AIAgent _agent = default!;
272
+
273
+ protected override void OnInitialized()
274
+ {
275
+ _agent = ServiceProvider.GetRequiredKeyedService<AIAgent>("OrderAnalyzer");
276
+ }
277
+ }
278
+ ```
279
+
280
+ ---
281
+
282
+ ## Streaming
283
+
284
+ ```csharp
285
+ await foreach (var update in agent.RunStreamingAsync(
286
+ "Write a detailed analysis.",
287
+ cancellationToken: ct))
288
+ {
289
+ if (update is AgentResponseUpdateEvent e)
290
+ {
291
+ Console.Write(e.Data);
292
+ }
293
+ }
294
+ ```
295
+
296
+ ---
297
+
298
+ ## Recommended Models
299
+
300
+ | Use Case | Model | Provider | Cost (per 1M input tokens) |
301
+ |----------|-------|----------|---------------------------|
302
+ | Simple tasks (default) | gpt-4o-mini | Azure OpenAI | $0.15 |
303
+ | Complex analysis | gpt-4o | Azure OpenAI | $2.50 |
304
+ | Embeddings | text-embedding-3-small | Azure OpenAI | $0.02 |
305
+ | Local development | llama3.2:3b | Ollama | Free |
306
+ | Cloud development | gpt-4o-mini | GitHub Models | Free (preview) |
307
+
308
+ **MORPH-SPEC default:** `gpt-4o-mini` for production.
309
+
310
+ ---
311
+
312
+ ## Security
313
+
314
+ ### API Keys in Azure Key Vault
315
+
316
+ ```csharp
317
+ if (builder.Environment.IsProduction())
318
+ {
319
+ var keyVaultUri = new Uri(builder.Configuration["KeyVault:Uri"]!);
320
+ builder.Configuration.AddAzureKeyVault(keyVaultUri, new DefaultAzureCredential());
321
+ }
322
+ ```
323
+
324
+ ### Managed Identity (Recommended)
325
+
326
+ ```csharp
327
+ // Use DefaultAzureCredential — works with Managed Identity in production,
328
+ // AzureCliCredential in development
329
+ var client = new AzureOpenAIClient(
330
+ new Uri(config["AzureOpenAI:Endpoint"]!),
331
+ new DefaultAzureCredential());
332
+ ```
333
+
334
+ ---
335
+
336
+ ## Observability
337
+
338
+ ```csharp
339
+ // Enable OpenTelemetry on agents
340
+ agent.WithOpenTelemetry();
341
+
342
+ // Program.cs — Aspire Dashboard integration
343
+ builder.Services.AddOpenTelemetry()
344
+ .WithTracing(tracing =>
345
+ {
346
+ tracing.AddSource("Experimental.Microsoft.Extensions.AI.*");
347
+ tracing.AddAspNetCoreInstrumentation();
348
+ })
349
+ .WithMetrics(metrics =>
350
+ {
351
+ metrics.AddMeter("Experimental.Microsoft.Extensions.AI.*");
352
+ metrics.AddAspNetCoreInstrumentation();
353
+ });
354
+ ```
355
+
356
+ ---
357
+
358
+ ## Limitations & Troubleshooting
359
+
360
+ | Problem | Cause | Solution |
361
+ |---------|-------|----------|
362
+ | Tool calling fails | Model < 3B params | Use gpt-4o-mini minimum |
363
+ | Rate limit errors | Too many requests | Add retry middleware (see production.md) |
364
+ | Tools not invoked | Missing `[Description]` | Add `[Description]` to method AND parameters |
365
+ | Agent returns empty | No instructions | Always set `Instructions` in agent options |
366
+
367
+ ---
368
+
369
+ ## Checklist
370
+
371
+ - [ ] `Microsoft.Agents.AI` + `Microsoft.Agents.AI.OpenAI` installed
372
+ - [ ] `IChatClient` registered as singleton via DI
373
+ - [ ] Agents created with `ChatClientAgent` or `AsAIAgent()`
374
+ - [ ] Agents registered with `builder.AddAIAgent()` (keyed services)
375
+ - [ ] Tools use `AIFunctionFactory.Create()` + `[Description]`
376
+ - [ ] API keys in Key Vault (production)
377
+ - [ ] Managed Identity configured
378
+ - [ ] gpt-4o-mini as default model
379
+ - [ ] OpenTelemetry enabled on agents
380
+ - [ ] Error handling via middleware (see `agent-framework-production.md`)
381
+
382
+ ---
383
+
384
+ ## What NOT To Do
385
+
386
+ | Wrong | Correct |
387
+ |-------|---------|
388
+ | `using Microsoft.SemanticKernel` | `using Microsoft.Agents.AI` |
389
+ | `Kernel.InvokePromptAsync()` | `agent.RunAsync()` |
390
+ | `[KernelFunction]` | `AIFunctionFactory.Create()` |
391
+ | `[AgentTool]` attribute | `[Description]` + `AIFunctionFactory` |
392
+ | `AgentTool.FromMethod()` | `AIFunctionFactory.Create(method)` |
393
+ | `_chatClient.CreateAgent()` | `new ChatClientAgent()` or `.AsAIAgent()` |
394
+ | `agent.CreateThreadAsync()` | Use session/conversation management |
395
+ | `ChatHistory` | `IEnumerable<ChatMessage>` |
396
+ | Hardcoded API keys | Key Vault / Managed Identity |
397
+ | Models < 3B for tools | gpt-4o-mini minimum |
398
+
399
+ ---
400
+
401
+ ## References
402
+
403
+ - [Agent Framework Quick Start](https://learn.microsoft.com/agent-framework/tutorials/quick-start)
404
+ - [Agent Tools](https://learn.microsoft.com/agent-framework/user-guide/agents/agent-tools)
405
+ - [Microsoft.Extensions.AI](https://learn.microsoft.com/dotnet/ai/ai-extensions)
406
+ - [GitHub: microsoft/agent-framework](https://github.com/microsoft/agent-framework)
407
+ - `agent-framework-workflows.md` Orchestration patterns
408
+ - `agent-framework-production.md` — Middleware, A2A, MCP, caching
409
+ - `agent-framework-blazor-ui.md` Natural Language First UI patterns
410
+
411
+ ---
412
+
413
+ *MORPH-SPEC by Polymorphism Tech*