mirror of
https://github.com/microsoft/agent-framework.git
synced 2026-06-16 21:04:09 +08:00
c341ee7ed2
* Python: DevUI - Internal Refactor, Conversations API support, and performance improvements Comprehensive refactor of DevUI package including samples relocation, frontend reorganization, OpenAI Conversations API support, and critical performance and code quality improvements. Key Changes: Architecture & Organization - Moved DevUI samples to python/samples/getting_started/devui/ - Consolidated with other framework samples for better discoverability - Added .env.example files and comprehensive README - Restructured frontend components into feature-based folders (agent, workflow, gallery, layout) - Created new OpenAI-compliant message renderers (devui should render oai responses types primarily) New Features - Added _conversations.py (467 lines) - Full conversation storage abstraction, replaces the /threads endpoint to better match oai conversations api - Implements OpenAI Conversations API for thread management, Supports in-memory and extensible storage backends API Simplification - Use 'model' field as entity_id (agent/workflow name) instead of extra_body - Use standard OpenAI 'conversation' field for conversation context. Performance & Quality Improvements - Improved context management in MessageMapper with bounded memory (~500KB max) - Implemented hybrid LRU + cleanup approach to prevent unbounded memory growth - General QOL improvement - Eliminated ~150 lines of dead/duplicate code, Consolidated helper functions into _utils.py, Extracted magic numbers to module-level constants, Optimized conversation item lookups with index-based approach Testing - Added test_conversations.py (13 tests) - Added test_performance_fixes.py (9 tests) - Updated existing tests for code consolidation - 53 tests passing Impact: 76 files changed: +4,106 insertions, -2,373 deletions All linting and formatting checks passing. No breaking changes - backward compatible. Migration: Samples moved to python/samples/getting_started/devui/ * readme lint fixes * initial support for function approval and minor ui fixes
80 lines
2.6 KiB
Python
80 lines
2.6 KiB
Python
# Copyright (c) Microsoft. All rights reserved.
|
|
"""Foundry-based weather agent for Agent Framework Debug UI.
|
|
|
|
This agent uses Azure AI Foundry with Azure CLI authentication.
|
|
Make sure to run 'az login' before starting devui.
|
|
"""
|
|
|
|
import os
|
|
from typing import Annotated
|
|
|
|
from agent_framework import ChatAgent
|
|
from agent_framework.azure import AzureAIAgentClient
|
|
from azure.identity.aio import AzureCliCredential
|
|
from pydantic import Field
|
|
|
|
|
|
def get_weather(
|
|
location: Annotated[str, Field(description="The location to get the weather for.")],
|
|
) -> str:
|
|
"""Get the weather for a given location."""
|
|
conditions = ["sunny", "cloudy", "rainy", "stormy"]
|
|
temperature = 22
|
|
return f"The weather in {location} is {conditions[0]} with a high of {temperature}°C."
|
|
|
|
|
|
def get_forecast(
|
|
location: Annotated[str, Field(description="The location to get the forecast for.")],
|
|
days: Annotated[int, Field(description="Number of days for forecast")] = 3,
|
|
) -> str:
|
|
"""Get weather forecast for multiple days."""
|
|
conditions = ["sunny", "cloudy", "rainy", "stormy"]
|
|
forecast: list[str] = []
|
|
|
|
for day in range(1, days + 1):
|
|
condition = conditions[day % len(conditions)]
|
|
temp = 18 + day
|
|
forecast.append(f"Day {day}: {condition}, {temp}°C")
|
|
|
|
return f"Weather forecast for {location}:\n" + "\n".join(forecast)
|
|
|
|
|
|
# Agent instance following Agent Framework conventions
|
|
agent = ChatAgent(
|
|
name="FoundryWeatherAgent",
|
|
chat_client=AzureAIAgentClient(
|
|
project_endpoint=os.environ.get("AZURE_AI_PROJECT_ENDPOINT"),
|
|
model_deployment_name=os.environ.get("FOUNDRY_MODEL_DEPLOYMENT_NAME"),
|
|
async_credential=AzureCliCredential(),
|
|
),
|
|
instructions="""
|
|
You are a weather assistant using Azure AI Foundry models. You can provide
|
|
current weather information and forecasts for any location. Always be helpful
|
|
and provide detailed weather information when asked.
|
|
""",
|
|
tools=[get_weather, get_forecast],
|
|
)
|
|
|
|
|
|
def main():
|
|
"""Launch the Foundry weather agent in DevUI."""
|
|
import logging
|
|
|
|
from agent_framework.devui import serve
|
|
|
|
# Setup logging
|
|
logging.basicConfig(level=logging.INFO, format="%(message)s")
|
|
logger = logging.getLogger(__name__)
|
|
|
|
logger.info("Starting Foundry Weather Agent")
|
|
logger.info("Available at: http://localhost:8090")
|
|
logger.info("Entity ID: agent_FoundryWeatherAgent")
|
|
logger.info("Note: Make sure 'az login' has been run for authentication")
|
|
|
|
# Launch server with the agent
|
|
serve(entities=[agent], port=8090, auto_open=True)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
main()
|