mirror of
https://github.com/microsoft/agent-framework.git
synced 2026-06-16 21:04:09 +08:00
aab621f5eb
* Fix tool normalization and provider samples - restore callable/single-tool normalization paths and unset tool-choice behavior\n- consolidate and expand chat/provider samples (OpenAI/Azure/Anthropic/Ollama/Bedrock)\n- migrate Bedrock lazy import surface to agent_framework.amazon and move provider samples Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com> * small fix in sample * Finalize provider, samples, and core cleanup Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com> * Fix CopilotTool passthrough in agent Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com> * fix link --------- Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
62 lines
1.9 KiB
Python
62 lines
1.9 KiB
Python
# Copyright (c) Microsoft. All rights reserved.
|
|
|
|
import asyncio
|
|
from typing import Annotated
|
|
|
|
from agent_framework import Agent, tool
|
|
from agent_framework.amazon import BedrockChatClient
|
|
from pydantic import Field
|
|
|
|
"""
|
|
Bedrock Chat Client Example
|
|
|
|
This sample demonstrates using `BedrockChatClient` with an agent and a simple tool.
|
|
|
|
Environment variables used:
|
|
- `BEDROCK_CHAT_MODEL_ID`
|
|
- `BEDROCK_REGION` (defaults to `us-east-1` if unset)
|
|
- AWS credentials via standard variables (`AWS_ACCESS_KEY_ID`, `AWS_SECRET_ACCESS_KEY`,
|
|
optional `AWS_SESSION_TOKEN`)
|
|
"""
|
|
|
|
|
|
# NOTE: approval_mode="never_require" is for sample brevity.
|
|
# Use "always_require" in production; see samples/02-agents/tools/function_tool_with_approval.py
|
|
# and samples/02-agents/tools/function_tool_with_approval_and_sessions.py.
|
|
@tool(approval_mode="never_require")
|
|
def get_weather(
|
|
city: Annotated[str, Field(description="The city to get the weather for.")],
|
|
) -> dict[str, str]:
|
|
"""Return a mock forecast for the requested city."""
|
|
normalized_city = city.strip() or "New York"
|
|
return {"city": normalized_city, "forecast": "72F and sunny"}
|
|
|
|
|
|
async def main() -> None:
|
|
"""Run a Bedrock-backed agent with one tool call."""
|
|
# 1. Create an agent with Bedrock chat client and one tool.
|
|
agent = Agent(
|
|
client=BedrockChatClient(),
|
|
instructions="You are a concise travel assistant.",
|
|
name="BedrockWeatherAgent",
|
|
tool_choice="auto",
|
|
tools=[get_weather],
|
|
)
|
|
|
|
# 2. Run a query that uses the weather tool.
|
|
query = "Use the weather tool to check the forecast for New York."
|
|
print(f"User: {query}")
|
|
response = await agent.run(query)
|
|
print(f"Assistant: {response.text}")
|
|
|
|
|
|
if __name__ == "__main__":
|
|
asyncio.run(main())
|
|
|
|
|
|
"""
|
|
Sample output:
|
|
User: Use the weather tool to check the forecast for New York.
|
|
Assistant: The forecast for New York is 72F and sunny.
|
|
"""
|