@polymorphism-tech/morph-spec 2.3.0 → 3.0.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 (166) hide show
  1. package/CLAUDE.md +446 -1730
  2. package/README.md +515 -516
  3. package/bin/morph-spec.js +366 -294
  4. package/bin/task-manager.js +429 -368
  5. package/bin/validate.js +369 -268
  6. package/content/.claude/commands/morph-apply.md +221 -158
  7. package/content/.claude/commands/morph-deploy.md +529 -0
  8. package/content/.claude/commands/morph-preflight.md +227 -0
  9. package/content/.claude/commands/morph-proposal.md +122 -101
  10. package/content/.claude/commands/morph-status.md +86 -86
  11. package/content/.claude/commands/morph-troubleshoot.md +122 -0
  12. package/content/.claude/skills/infra/azure-deploy-specialist.md +699 -0
  13. package/content/.claude/skills/level-0-meta/README.md +7 -0
  14. package/content/.claude/skills/level-0-meta/code-review.md +226 -0
  15. package/content/.claude/skills/level-0-meta/morph-checklist.md +117 -0
  16. package/content/.claude/skills/level-0-meta/simulation-checklist.md +77 -0
  17. package/content/.claude/skills/level-1-workflows/README.md +7 -0
  18. package/content/.claude/skills/level-1-workflows/morph-replicate.md +213 -0
  19. package/content/.claude/{commands/morph-clarify.md → skills/level-1-workflows/phase-clarify.md} +131 -184
  20. package/content/.claude/{commands/morph-design.md → skills/level-1-workflows/phase-design.md} +213 -275
  21. package/content/.claude/skills/level-1-workflows/phase-setup.md +106 -0
  22. package/content/.claude/skills/level-1-workflows/phase-tasks.md +164 -0
  23. package/content/.claude/{commands/morph-uiux.md → skills/level-1-workflows/phase-uiux.md} +169 -211
  24. package/content/.claude/skills/level-2-domains/README.md +14 -0
  25. package/content/.claude/skills/level-2-domains/ai-agents/ai-system-architect.md +192 -0
  26. package/content/.claude/skills/{specialists → level-2-domains/architecture}/po-pm-advisor.md +197 -197
  27. package/content/.claude/skills/level-2-domains/architecture/standards-architect.md +156 -0
  28. package/content/.claude/skills/level-2-domains/backend/dotnet-senior.md +287 -0
  29. package/content/.claude/skills/level-2-domains/backend/ef-modeler.md +113 -0
  30. package/content/.claude/skills/level-2-domains/backend/hangfire-orchestrator.md +126 -0
  31. package/content/.claude/skills/level-2-domains/backend/ms-agent-expert.md +109 -0
  32. package/content/.claude/skills/level-2-domains/frontend/blazor-builder.md +210 -0
  33. package/content/.claude/skills/level-2-domains/frontend/nextjs-expert.md +154 -0
  34. package/content/.claude/skills/level-2-domains/frontend/ui-ux-designer.md +191 -0
  35. package/content/.claude/skills/{specialists → level-2-domains/infrastructure}/azure-architect.md +142 -142
  36. package/content/.claude/skills/level-2-domains/infrastructure/bicep-architect.md +126 -0
  37. package/content/.claude/skills/level-2-domains/infrastructure/container-specialist.md +131 -0
  38. package/content/.claude/skills/level-2-domains/infrastructure/devops-engineer.md +119 -0
  39. package/content/.claude/skills/level-2-domains/integrations/asaas-financial.md +130 -0
  40. package/content/.claude/skills/level-2-domains/integrations/azure-identity.md +142 -0
  41. package/content/.claude/skills/level-2-domains/integrations/clerk-auth.md +108 -0
  42. package/content/.claude/skills/level-2-domains/integrations/resend-email.md +119 -0
  43. package/content/.claude/skills/level-2-domains/quality/code-analyzer.md +235 -0
  44. package/content/.claude/skills/level-2-domains/quality/testing-specialist.md +126 -0
  45. package/content/.claude/skills/level-3-technologies/README.md +7 -0
  46. package/content/.claude/skills/level-4-patterns/README.md +7 -0
  47. package/content/.claude/skills/specialists/prompt-engineer.md +189 -0
  48. package/content/.claude/skills/specialists/seo-growth-hacker.md +320 -0
  49. package/content/.morph/config/agents.json +762 -242
  50. package/content/.morph/config/config.template.json +122 -108
  51. package/content/.morph/docs/workflows/design-impl.md +37 -0
  52. package/content/.morph/docs/workflows/enforcement-pipeline.md +668 -0
  53. package/content/.morph/docs/workflows/fast-track.md +29 -0
  54. package/content/.morph/docs/workflows/full-morph.md +76 -0
  55. package/content/.morph/docs/workflows/standard.md +44 -0
  56. package/content/.morph/docs/workflows/ui-refresh.md +39 -0
  57. package/content/.morph/examples/scheduled-reports/decisions.md +158 -0
  58. package/content/.morph/examples/scheduled-reports/proposal.md +95 -0
  59. package/content/.morph/examples/scheduled-reports/spec.md +267 -0
  60. package/content/.morph/hooks/README.md +348 -239
  61. package/content/.morph/hooks/pre-commit-agents.sh +24 -24
  62. package/content/.morph/hooks/task-completed.js +73 -0
  63. package/content/.morph/hooks/teammate-idle.js +68 -0
  64. package/content/.morph/schemas/tasks.schema.json +220 -0
  65. package/content/.morph/standards/agent-framework-blazor-ui.md +359 -0
  66. package/content/.morph/standards/agent-framework-production.md +410 -0
  67. package/content/.morph/standards/agent-framework-setup.md +413 -453
  68. package/content/.morph/standards/agent-framework-workflows.md +349 -0
  69. package/content/.morph/standards/agent-teams-workflow.md +474 -0
  70. package/content/.morph/standards/architecture.md +325 -325
  71. package/content/.morph/standards/azure.md +605 -379
  72. package/content/.morph/standards/dotnet10-migration.md +520 -494
  73. package/content/.morph/templates/CONTEXT-FEATURE.md +276 -0
  74. package/content/.morph/templates/CONTEXT.md +170 -0
  75. package/content/.morph/templates/agent.cs +163 -172
  76. package/content/.morph/templates/clarify-questions.md +159 -0
  77. package/content/.morph/templates/contracts/Commands.cs +74 -0
  78. package/content/.morph/templates/contracts/Entities.cs +25 -0
  79. package/content/.morph/templates/contracts/Queries.cs +74 -0
  80. package/content/.morph/templates/contracts/README.md +74 -0
  81. package/content/.morph/templates/decisions.md +123 -106
  82. package/content/.morph/templates/infra/azure-pipelines-deploy.yml +480 -0
  83. package/content/.morph/templates/infra/deploy-checklist.md +426 -0
  84. package/content/.morph/templates/proposal.md +141 -155
  85. package/content/.morph/templates/recap.md +94 -105
  86. package/content/.morph/templates/simulation.md +353 -0
  87. package/content/.morph/templates/spec.md +149 -148
  88. package/content/.morph/templates/state.template.json +222 -222
  89. package/content/.morph/templates/tasks.md +257 -235
  90. package/content/.morph/templates/ui-components.md +362 -276
  91. package/content/CLAUDE.md +150 -442
  92. package/detectors/structure-detector.js +245 -250
  93. package/docs/README.md +144 -149
  94. package/docs/getting-started.md +301 -302
  95. package/docs/installation.md +361 -361
  96. package/docs/validation-checklist.md +265 -266
  97. package/package.json +80 -80
  98. package/src/commands/advance-phase.js +266 -0
  99. package/src/commands/analyze-blazor-concurrency.js +193 -0
  100. package/src/commands/deploy.js +780 -0
  101. package/src/commands/detect-agents.js +167 -0
  102. package/src/commands/doctor.js +356 -280
  103. package/src/commands/generate-context.js +40 -0
  104. package/src/commands/init.js +258 -245
  105. package/src/commands/lint-fluent.js +352 -0
  106. package/src/commands/rollback-phase.js +185 -0
  107. package/src/commands/session-summary.js +291 -0
  108. package/src/commands/task.js +78 -75
  109. package/src/commands/troubleshoot.js +222 -0
  110. package/src/commands/update.js +192 -159
  111. package/src/commands/validate-blazor-state.js +210 -0
  112. package/src/commands/validate-blazor.js +156 -0
  113. package/src/commands/validate-css.js +84 -0
  114. package/src/commands/validate-phase.js +221 -0
  115. package/src/lib/blazor-concurrency-analyzer.js +288 -0
  116. package/src/lib/blazor-state-validator.js +291 -0
  117. package/src/lib/blazor-validator.js +374 -0
  118. package/src/lib/complexity-analyzer.js +441 -292
  119. package/src/lib/context-generator.js +513 -0
  120. package/src/lib/continuous-validator.js +421 -440
  121. package/src/lib/css-validator.js +352 -0
  122. package/src/lib/decision-constraint-loader.js +109 -0
  123. package/src/lib/design-system-detector.js +187 -0
  124. package/src/lib/design-system-scaffolder.js +299 -0
  125. package/src/lib/hook-executor.js +256 -0
  126. package/src/lib/recap-generator.js +205 -0
  127. package/src/lib/spec-validator.js +258 -0
  128. package/src/lib/standards-context-injector.js +287 -0
  129. package/src/lib/state-manager.js +397 -340
  130. package/src/lib/team-orchestrator.js +322 -0
  131. package/src/lib/troubleshoot-grep.js +194 -0
  132. package/src/lib/troubleshoot-index.js +144 -0
  133. package/src/lib/validation-runner.js +283 -0
  134. package/src/lib/validators/contract-compliance-validator.js +273 -0
  135. package/src/lib/validators/design-system-validator.js +231 -0
  136. package/src/utils/file-copier.js +187 -139
  137. package/content/.claude/commands/morph-costs.md +0 -206
  138. package/content/.claude/commands/morph-setup.md +0 -100
  139. package/content/.claude/commands/morph-tasks.md +0 -319
  140. package/content/.claude/skills/infra/bicep-architect.md +0 -419
  141. package/content/.claude/skills/infra/container-specialist.md +0 -437
  142. package/content/.claude/skills/infra/devops-engineer.md +0 -405
  143. package/content/.claude/skills/integrations/asaas-financial.md +0 -333
  144. package/content/.claude/skills/integrations/azure-identity.md +0 -309
  145. package/content/.claude/skills/integrations/clerk-auth.md +0 -290
  146. package/content/.claude/skills/specialists/ai-system-architect.md +0 -604
  147. package/content/.claude/skills/specialists/cost-guardian.md +0 -110
  148. package/content/.claude/skills/specialists/ef-modeler.md +0 -211
  149. package/content/.claude/skills/specialists/hangfire-orchestrator.md +0 -255
  150. package/content/.claude/skills/specialists/ms-agent-expert.md +0 -263
  151. package/content/.claude/skills/specialists/standards-architect.md +0 -78
  152. package/content/.claude/skills/specialists/ui-ux-designer.md +0 -1100
  153. package/content/.claude/skills/stacks/dotnet-blazor.md +0 -606
  154. package/content/.claude/skills/stacks/dotnet-nextjs.md +0 -402
  155. package/content/.claude/skills/stacks/shopify.md +0 -445
  156. package/content/.morph/config/azure-pricing.json +0 -70
  157. package/content/.morph/config/azure-pricing.schema.json +0 -50
  158. package/content/.morph/hooks/pre-commit-costs.sh +0 -91
  159. package/docs/api/cost-calculator.js.html +0 -513
  160. package/docs/api/design-system-generator.js.html +0 -382
  161. package/docs/api/global.html +0 -5263
  162. package/docs/api/index.html +0 -96
  163. package/docs/api/state-manager.js.html +0 -423
  164. package/src/commands/cost.js +0 -181
  165. package/src/commands/update-pricing.js +0 -206
  166. 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*