Files
agent-framework/dotnet/samples/AGENTS.md
Chris 904a5b843e Python / .NET Samples - Restructure and Improve Samples (Feature Branc… (#4092)
* Python: .NET Samples - Restructure and Improve Samples (Feature Branch) (#4091)

* Moved by agent (#4094)

* Fix readme links

* .NET Samples - Create `04-hosting` learning path step (#4098)

* Agent move

* Agent reorderd

* Remove A2A section from README 

Removed A2A section from the Getting Started README.

* Agent fixed links

* Fix broken sample links in durable-agents README (#4101)

* Initial plan

* Fix broken internal links in documentation

Co-authored-by: crickman <66376200+crickman@users.noreply.github.com>

* Revert template link changes; keep only durable-agents README fix

Co-authored-by: crickman <66376200+crickman@users.noreply.github.com>

---------

Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com>
Co-authored-by: crickman <66376200+crickman@users.noreply.github.com>

* .NET Samples - Create `03-workflows` learning path step (#4102)

* Fix solution project path

* Python: Fix broken markdown links to repo resources (outside /docs) (#4105)

* Initial plan

* Fix broken markdown links to repo resources

Co-authored-by: crickman <66376200+crickman@users.noreply.github.com>

* Update README to rename .NET Workflows Samples section

---------

Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com>
Co-authored-by: crickman <66376200+crickman@users.noreply.github.com>

* .NET Samples - Create `02-agents` learning path step (#4107)

* .NET: Fix broken relative link in GroupChatToolApproval README (#4108)

* Initial plan

* Fix broken link in GroupChatToolApproval README

Co-authored-by: crickman <66376200+crickman@users.noreply.github.com>

---------

Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com>
Co-authored-by: crickman <66376200+crickman@users.noreply.github.com>

* Update labeler configuration for workflow samples

* .NET - Reorder Agents samples to start from Step01 instead of Step04 (#4110)

* Fix solution

* Resolve new sample paths

* Move new AgentSkills and AgentWithMemory_Step04 samples

* Fix link

* Fix readme path

* fix: update stale dotnet/samples/Durable path reference in AGENTS.md

Co-authored-by: crickman <66376200+crickman@users.noreply.github.com>

* Moved new sample

* Update solution

* Resolve merge (new sample)

* Sync to new sample - FoundryAgents_Step21_BingCustomSearch

* Updated README

* .NET Samples - Configuration Naming Update (#4149)

* .NET: Restore AzureFunctions index parity with ConsoleApps under DurableAgents samples (#4221)

* Clean-up `05_host_your_agent`

* Config setting consistency

* Refine samples

* AGENTS.md

* Move new samples

* Re-order samples

* Move new project and fixup solution

* Fixup model config

* Fix up new UT project

---------

Co-authored-by: Copilot <198982749+Copilot@users.noreply.github.com>
2026-02-26 00:56:10 +00:00

131 lines
6.4 KiB
Markdown
Raw Permalink Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
# Samples Structure & Design Choices — .NET
> This file documents the structure and conventions of the .NET samples so that
> agents (AI or human) can maintain them without rediscovering decisions.
## Directory layout
```
dotnet/samples/
├── 01-get-started/ # Progressive tutorial (steps 0106)
│ ├── 01_hello_agent/ # Create and run your first agent
│ ├── 02_add_tools/ # Add function tools
│ ├── 03_multi_turn/ # Multi-turn conversations with AgentSession
│ ├── 04_memory/ # Agent memory with AIContextProvider
│ ├── 05_first_workflow/ # Build a workflow with executors and edges
│ └── 06_host_your_agent/ # Host your agent via Azure Functions
├── 02-agents/ # Deep-dive concept samples
│ ├── Agents/ # Core agent patterns (tools, structured output,
│ │ # conversations, middleware, plugins, MCP, etc.)
│ ├── AgentProviders/ # One project per provider (Azure OpenAI, OpenAI,
│ │ # Anthropic, Gemini, Ollama, ONNX, Foundry, etc.)
│ ├── AgentOpenTelemetry/ # OpenTelemetry integration
│ ├── AgentSkills/ # Agent skills patterns
│ ├── AgentWithAnthropic/ # Anthropic-specific samples
│ ├── AgentWithMemory/ # Memory providers (chat history, Mem0, Foundry)
│ ├── AgentWithOpenAI/ # OpenAI-specific samples
│ ├── AgentWithRAG/ # RAG patterns (text, vector store, Foundry)
│ ├── AGUI/ # AG-UI protocol samples
│ ├── DeclarativeAgents/ # Declarative agent definitions
│ ├── DevUI/ # DevUI samples
│ ├── FoundryAgents/ # Azure AI Foundry agent samples
│ └── ModelContextProtocol/ # MCP server/client patterns
├── 03-workflows/ # Workflow patterns
│ ├── _StartHere/ # Introductory workflow samples
│ ├── Agents/ # Agents in workflows
│ ├── Checkpoint/ # Checkpointing & resume
│ ├── Concurrent/ # Concurrent execution
│ ├── ConditionalEdges/ # Conditional routing
│ ├── Declarative/ # YAML-based workflows
│ ├── HumanInTheLoop/ # HITL patterns
│ ├── Loop/ # Loop patterns
│ ├── Observability/ # Workflow telemetry
│ ├── SharedStates/ # State isolation
│ └── Visualization/ # Workflow visualization
├── 04-hosting/ # Deployment & hosting
│ ├── A2A/ # Agent-to-Agent protocol
│ └── DurableAgents/ # Durable task framework
│ ├── AzureFunctions/ # Azure Functions hosting
│ └── ConsoleApps/ # Console app hosting
├── 05-end-to-end/ # Complete applications
│ ├── A2AClientServer/ # A2A client/server demo
│ ├── AgentWebChat/ # Aspire-based web chat
│ ├── AgentWithPurview/ # Purview integration
│ ├── AGUIClientServer/ # AG-UI client/server demo
│ ├── AGUIWebChat/ # AG-UI web chat
│ ├── HostedAgents/ # Hosted agent scenarios
│ └── M365Agent/ # Microsoft 365 agent
```
## Design principles
1. **Progressive complexity**: Sections 01→05 build from "hello world" to
production. Within 01-get-started, projects are numbered 0106 and each step
adds exactly one concept.
2. **One concept per project** in 01-get-started. Each step is a standalone
C# project with a single `Program.cs` file.
3. **Workflows preserved**: 03-workflows/ keeps the upstream folder names
intact. Do not rename or restructure workflow samples.
4. **Per-project structure**: Each sample is a separate .csproj. Shared build
configuration is inherited from `Directory.Build.props`.
## Default provider
All canonical samples (01-get-started) use **Azure OpenAI** via `AzureOpenAIClient`
with `DefaultAzureCredential`:
```csharp
using Azure.AI.OpenAI;
using Azure.Identity;
using Microsoft.Agents.AI;
using OpenAI.Chat;
var endpoint = Environment.GetEnvironmentVariable("AZURE_OPENAI_ENDPOINT")
?? throw new InvalidOperationException("AZURE_OPENAI_ENDPOINT is not set.");
var deploymentName = Environment.GetEnvironmentVariable("AZURE_OPENAI_DEPLOYMENT_NAME") ?? "gpt-4o-mini";
// WARNING: DefaultAzureCredential is convenient for development but requires careful consideration in production.
// In production, consider using a specific credential (e.g., ManagedIdentityCredential) to avoid
// latency issues, unintended credential probing, and potential security risks from fallback mechanisms.
AIAgent agent = new AzureOpenAIClient(new Uri(endpoint), new DefaultAzureCredential())
.GetChatClient(deploymentName)
.AsAIAgent(instructions: "...", name: "...");
```
Environment variables:
- `AZURE_OPENAI_ENDPOINT` — Your Azure OpenAI endpoint
- `AZURE_OPENAI_DEPLOYMENT_NAME` — Model deployment name (defaults to `gpt-4o-mini`)
For authentication, run `az login` before running samples.
## Snippet tags for docs integration
Samples embed named snippet regions for future `:::code` integration:
```csharp
// <snippet_name>
code here
// </snippet_name>
```
## Building and running
All samples use project references to the framework source. To build and run:
```bash
cd dotnet/samples/01-get-started/01_hello_agent
dotnet run
```
## Current API notes
- `AIAgent` is the primary agent abstraction (created via `ChatClient.AsAIAgent(...)`)
- `AgentSession` manages multi-turn conversation state
- `AIContextProvider` injects memory and context
- Prefer `client.GetChatClient(deployment).AsAIAgent(...)` extension method pattern
- Azure Functions hosting uses `ConfigureDurableAgents(options => options.AddAIAgent(agent))`
- Workflows use `WorkflowBuilder` with `Executor<TIn, TOut>` and edge connections