Files
Eduard van Valkenburg 6acab3d1d6 Python: [BREAKING] Standardize model selection on model (#4999)
* Refactor Anthropic model option and provider clients

Rename the Anthropic client model option from model_id to model, add provider-specific Anthropic wrappers for Foundry, Bedrock, and Vertex, and expose them through the Anthropic, Foundry, Amazon, and Google namespaces. Update core option handling, docs, samples, and tests accordingly.

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>

* Fix Anthropic skills sample typing

Cast the Anthropic beta client to Any in the skills sample so the pre-commit sample pyright check no longer fails on beta skills and files endpoints that are not exposed by the current SDK stubs.

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>

* undo sample mypy

* Retry CI after transient external failures

Retrigger PR validation after an unrelated Copilot review workflow SAML failure and a transient external tau2 git fetch failure in the Windows Python test setup.

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>

* Address review feedback on model option merging

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>

* Address Anthropic compatibility review feedback

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>

* moved all to `model`

* fixes for azure ai search

* Python: standardize remaining sample env var names

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>

* Python: fix foundry-local pyright compatibility

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>

* updated env vars in cicd

---------

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
6acab3d1d6 ยท 2026-04-01 19:00:18 +00:00
History
..

Hosted Agent Samples

These samples demonstrate how to build and host AI agents in Python using the Azure AI AgentServer SDK together with Microsoft Agent Framework. Each sample runs locally as a hosted agent and includes Dockerfile and agent.yaml assets for deployment to Microsoft Foundry.

Samples

Sample Description
agent_with_hosted_mcp Hosted MCP tool that connects to Microsoft Learn via https://learn.microsoft.com/api/mcp
agent_with_text_search_rag Retrieval-augmented generation using a custom ContextProvider with Contoso Outdoors sample data
agents_in_workflow Concurrent workflow that combines researcher, marketer, and legal specialist agents
agent_with_local_tools Local Python tool execution for Seattle hotel search
writer_reviewer_agents_in_workflow Writer/Reviewer workflow using FoundryChatClient

Common Prerequisites

Before running any sample, ensure you have:

  1. Python 3.10 or later
  2. Azure CLI installed
  3. An Azure OpenAI resource or a Microsoft Foundry project with a chat model deployment

Authenticate with Azure CLI

All samples rely on Azure credentials. For local development, the simplest approach is Azure CLI authentication:

az login
az account show

Running a Sample

Each sample folder contains its own requirements.txt. Run commands from the specific sample directory you want to try.

The sample dependencies include preview packages, so allow prerelease installs:

cd <sample-directory>
uv venv .venv
uv pip install --prerelease=allow -r requirements.txt
uv run main.py

Alternative: venv

Windows PowerShell:

cd <sample-directory>
python -m venv .venv
.\.venv\Scripts\Activate.ps1
pip install -r requirements.txt
python main.py

macOS/Linux:

cd <sample-directory>
python -m venv .venv
source .venv/bin/activate
pip install -r requirements.txt
python main.py

Each sample starts a hosted agent locally on http://localhost:8088/.

Environment Variable Setup

You can either export variables in your shell or create a local .env file in the sample directory.

Example .env for Azure OpenAI samples:

AZURE_OPENAI_ENDPOINT=https://<your-openai-resource>.openai.azure.com/
AZURE_OPENAI_MODEL=gpt-4.1

Example .env for Foundry project samples:

FOUNDRY_PROJECT_ENDPOINT=https://<your-resource>.services.ai.azure.com/api/projects/<your-project>
FOUNDRY_MODEL=gpt-4.1

Interacting with the Agent

After starting a sample, send requests to the Responses endpoint.

PowerShell:

$body = @{
		input = "Your question here"
		stream = $false
} | ConvertTo-Json

Invoke-RestMethod -Uri "http://localhost:8088/responses" -Method Post -Body $body -ContentType "application/json"

curl:

curl -sS -H "Content-Type: application/json" -X POST http://localhost:8088/responses \
	-d '{"input":"Your question here","stream":false}'

Example prompts by sample:

Sample Example input
agent_with_hosted_mcp What does Microsoft Learn say about managed identities in Azure?
agent_with_text_search_rag What is Contoso Outdoors' return policy for refunds?
agents_in_workflow Create a launch strategy for a budget-friendly electric SUV.
agent_with_local_tools Find me Seattle hotels from 2025-03-15 to 2025-03-18 under $200 per night.
writer_reviewer_agents_in_workflow Write a slogan for a new affordable electric SUV.

Deploying to Microsoft Foundry

Each sample includes a Dockerfile and agent.yaml for deployment. For deployment steps, follow the hosted agents guidance in Microsoft Foundry:

Troubleshooting

Missing Azure credentials

If startup fails with authentication errors, run az login and verify the selected subscription with az account show.

Preview package install issues

These samples depend on preview packages such as azure-ai-agentserver-agentframework. Use uv pip install --prerelease=allow -r requirements.txt or pip install -r requirements.txt.

ARM64 container images fail after deployment

If you build images locally on ARM64 hardware such as Apple Silicon, build for linux/amd64:

docker build --platform=linux/amd64 -t image .