Files
agent-framework/dotnet/samples/GettingStarted/Agents
Ren Finlayson 539852f81c
Some checks are pending
CodeQL / Analyze (csharp) (push) Waiting to run
CodeQL / Analyze (python) (push) Waiting to run
dotnet-build-and-test / paths-filter (push) Waiting to run
dotnet-build-and-test / dotnet-build-and-test (Debug, windows-latest, net9.0) (push) Blocked by required conditions
dotnet-build-and-test / dotnet-build-and-test (Release, integration, true, ubuntu-latest, net10.0) (push) Blocked by required conditions
dotnet-build-and-test / dotnet-build-and-test (Release, integration, true, windows-latest, net472) (push) Blocked by required conditions
dotnet-build-and-test / dotnet-build-and-test (Release, ubuntu-latest, net8.0) (push) Blocked by required conditions
dotnet-build-and-test / dotnet-build-and-test-check (push) Blocked by required conditions
test
2026-01-24 03:05:12 +11:00
..
2026-01-24 03:05:12 +11:00
2026-01-24 03:05:12 +11:00
2026-01-24 03:05:12 +11:00
2026-01-24 03:05:12 +11:00
2026-01-24 03:05:12 +11:00
2026-01-24 03:05:12 +11:00
2026-01-24 03:05:12 +11:00
2026-01-24 03:05:12 +11:00
2026-01-24 03:05:12 +11:00
2026-01-24 03:05:12 +11:00
2026-01-24 03:05:12 +11:00
2026-01-24 03:05:12 +11:00
2026-01-24 03:05:12 +11:00
2026-01-24 03:05:12 +11:00
2026-01-24 03:05:12 +11:00
2026-01-24 03:05:12 +11:00
2026-01-24 03:05:12 +11:00
2026-01-24 03:05:12 +11:00
2026-01-24 03:05:12 +11:00

Getting started with agents

The getting started with agents samples demonstrate the fundamental concepts and functionalities of single agents and can be used with any agent type.

While the functionality can be used with any agent type, these samples use Azure OpenAI as the AI provider and use ChatCompletion as the type of service.

For other samples that demonstrate how to create and configure each type of agent that come with the agent framework, see the How to create an agent for each provider samples.

Getting started with agents prerequisites

Before you begin, ensure you have the following prerequisites:

  • .NET 10 SDK or later
  • Azure OpenAI service endpoint and deployment configured
  • Azure CLI installed and authenticated (for Azure credential authentication)
  • User has the Cognitive Services OpenAI Contributor role for the Azure OpenAI resource.

Note: These samples use Azure OpenAI models. For more information, see how to deploy Azure OpenAI models with Azure AI Foundry.

Note: These samples use Azure CLI credentials for authentication. Make sure you're logged in with az login and have access to the Azure OpenAI resource and have the Cognitive Services OpenAI Contributor role. For more information, see the Azure CLI documentation.

Samples

Sample Description
Running a simple agent This sample demonstrates how to create and run a basic agent with instructions
Multi-turn conversation with a simple agent This sample demonstrates how to implement a multi-turn conversation with a simple agent
Using function tools with a simple agent This sample demonstrates how to use function tools with a simple agent
Using OpenAPI function tools with a simple agent This sample demonstrates how to create function tools from an OpenAPI spec and use them with a simple agent (note that this sample is in the Semantic Kernel repository)
Using function tools with approvals This sample demonstrates how to use function tools where approvals require human in the loop approvals before execution
Structured output with a simple agent This sample demonstrates how to use structured output with a simple agent
Persisted conversations with a simple agent This sample demonstrates how to persist conversations and reload them later. This is useful for cases where an agent is hosted in a stateless service
3rd party thread storage with a simple agent This sample demonstrates how to store conversation history in a 3rd party storage solution
Observability with a simple agent This sample demonstrates how to add telemetry to a simple agent
Dependency injection with a simple agent This sample demonstrates how to add and resolve an agent with a dependency injection container
Exposing a simple agent as MCP tool This sample demonstrates how to expose an agent as an MCP tool
Using images with a simple agent This sample demonstrates how to use image multi-modality with an AI agent
Exposing a simple agent as a function tool This sample demonstrates how to expose an agent as a function tool
Background responses with tools and persistence This sample demonstrates advanced background response scenarios including function calling during background operations and state persistence
Using middleware with an agent This sample demonstrates how to use middleware with an agent
Using plugins with an agent This sample demonstrates how to use plugins with an agent
Reducing chat history size This sample demonstrates how to reduce the chat history to constrain its size, where chat history is maintained locally
Background responses This sample demonstrates how to use background responses for long-running operations with polling and resumption support
Deep research with an agent This sample demonstrates how to use the Deep Research Tool to perform comprehensive research on complex topics
Declarative agent This sample demonstrates how to declaratively define an agent.
Providing additional AI Context to an agent using multiple AIContextProviders This sample demonstrates how to inject additional AI context into a ChatClientAgent using multiple custom AIContextProvider components that are attached to the agent.

Running the samples from the console

To run the samples, navigate to the desired sample directory, e.g.

cd Agents_Step01_Running

Set the following environment variables:

$env:AZURE_OPENAI_ENDPOINT="https://your-resource.openai.azure.com/" # Replace with your Azure OpenAI resource endpoint
$env:AZURE_OPENAI_DEPLOYMENT_NAME="gpt-4o-mini"  # Optional, defaults to gpt-4o-mini

If the variables are not set, you will be prompted for the values when running the samples.

Execute the following command to build the sample:

dotnet build

Execute the following command to run the sample:

dotnet run --no-build

Or just build and run in one step:

dotnet run

Running the samples from Visual Studio

Open the solution in Visual Studio and set the desired sample project as the startup project. Then, run the project using the built-in debugger or by pressing F5.

You will be prompted for any required environment variables if they are not already set.