mirror of
https://github.com/microsoft/agent-framework.git
synced 2026-06-16 21:04:09 +08:00
7dee184ae4
* Organize the .Net samples * Organize the .Net samples * Merge latest from main * Update sample to also include function calling telemetry (#577) * Move package installation instructions to user-guide (#572) * Move package installation instructions to user-guide * Update user-documentation-dotnet/getting-started/README.md Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update docs/docs-templates/getting-started/README.md Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * .NET: Add SK-AF Migration Samples for Responses API. (#575) * Responses wip * Adding OpenAI Responses Migration samples * Address all samples and code for Azure and OpenAI Responses Migration code * Update dotnet/samples/SemanticKernelMigration/OpenAIResponses/Step02_ReasoningModel/Program.cs Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Organize the .Net samples * Organize the .Net samples * Merge latest from main * Use Agent rather than AIAgent * Rename agents getting started samples * Use singular Agent --------- Co-authored-by: Roger Barreto <19890735+rogerbarreto@users.noreply.github.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
69 lines
3.3 KiB
C#
69 lines
3.3 KiB
C#
// Copyright (c) Microsoft. All rights reserved.
|
|
|
|
// This sample demonstrates how to use a ChatClientAgent with function tools that require a human in the loop for approvals.
|
|
// It shows both non-streaming and streaming agent interactions using menu-related tools.
|
|
// If the agent is hosted in a service, with a remote user, combine this sample with the Persisted Conversations sample to persist the chat history
|
|
// while the agent is waiting for user input.
|
|
|
|
using System;
|
|
using System.ComponentModel;
|
|
using System.Linq;
|
|
using Azure.AI.OpenAI;
|
|
using Azure.Identity;
|
|
using Microsoft.Extensions.AI;
|
|
using Microsoft.Extensions.AI.Agents;
|
|
using OpenAI;
|
|
|
|
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";
|
|
|
|
// Create a sample function tool that the agent can use.
|
|
[Description("Get the weather for a given location.")]
|
|
static string GetWeather([Description("The location to get the weather for.")] string location)
|
|
=> $"The weather in {location} is cloudy with a high of 15°C.";
|
|
|
|
// Create the chat client and agent.
|
|
// Note that we are wrapping the function tool with ApprovalRequiredAIFunction to require user approval before invoking it.
|
|
AIAgent agent = new AzureOpenAIClient(
|
|
new Uri(endpoint),
|
|
new AzureCliCredential())
|
|
.GetChatClient(deploymentName)
|
|
.CreateAIAgent(instructions: "You are a helpful assistant", tools: [new ApprovalRequiredAIFunction(AIFunctionFactory.Create(GetWeather))]);
|
|
|
|
// Call the agent and check if there are any user input requests to handle.
|
|
AgentThread thread = agent.GetNewThread();
|
|
var response = await agent.RunAsync("What is the weather like in Amsterdam?", thread);
|
|
var userInputRequests = response.UserInputRequests.ToList();
|
|
|
|
// For streaming use:
|
|
// var updates = await agent.RunStreamingAsync("What is the weather like in Amsterdam?", thread).ToListAsync();
|
|
// userInputRequests = updates.SelectMany(x => x.UserInputRequests).ToList();
|
|
|
|
while (userInputRequests.Count > 0)
|
|
{
|
|
// Ask the user to approve each function call request.
|
|
// For simplicity, we are assuming here that only function approval requests are being made.
|
|
var userInputResponses = userInputRequests
|
|
.OfType<FunctionApprovalRequestContent>()
|
|
.Select(functionApprovalRequest =>
|
|
{
|
|
Console.WriteLine($"The agent would like to invoke the following function, please reply Y to approve: Name {functionApprovalRequest.FunctionCall.Name}");
|
|
return new ChatMessage(ChatRole.User, [functionApprovalRequest.CreateResponse(Console.ReadLine()?.Equals("Y", StringComparison.OrdinalIgnoreCase) ?? false)]);
|
|
})
|
|
.ToList();
|
|
|
|
// Pass the user input responses back to the agent for further processing.
|
|
response = await agent.RunAsync(userInputResponses, thread);
|
|
|
|
userInputRequests = response.UserInputRequests.ToList();
|
|
|
|
// For streaming use:
|
|
// updates = await agent.RunStreamingAsync(userInputResponses, thread).ToListAsync();
|
|
// userInputRequests = updates.SelectMany(x => x.UserInputRequests).ToList();
|
|
}
|
|
|
|
Console.WriteLine($"\nAgent: {response}");
|
|
|
|
// For streaming use:
|
|
// Console.WriteLine($"\nAgent: {updates.ToAgentRunResponse()}");
|