mirror of
https://github.com/microsoft/agent-framework.git
synced 2026-06-16 21:04:09 +08:00
b0613a8ceb
* Bump Azure.AI.Projects to 2.0.0 GA - Update Azure.AI.Projects from 2.0.0-beta.2 to 2.0.0 in CPM - Update Azure.Identity from 1.19.0 to 1.20.0 (transitive dep) - Update System.ClientModel from 1.9.0 to 1.10.0 (transitive dep) - Rename types per Azure.AI.Projects.Agents 2.0.0 breaking changes: - AgentVersion -> ProjectsAgentVersion - AgentRecord -> ProjectsAgentRecord - AgentDefinition -> ProjectsAgentDefinition - AgentVersionCreationOptions -> ProjectsAgentVersionCreationOptions - PromptAgentDefinition -> DeclarativeAgentDefinition - AgentTool -> ProjectsAgentTool - AgentsClient -> AgentAdministrationClient - .Agents property -> .AgentAdministrationClient - Add using Azure.AI.Projects.Memory namespace (types moved) - Update AGENTS.md with BOM and output capture conventions * Address PR review feedback - Rename AIProjectClient parameter to aiProjectClient in AsChatClientAgent overloads - Fix XML doc: ProjectsAgentTool namespace from Azure.AI.Projects.OpenAI to Azure.AI.Projects.Agents - Rename test method to reflect DeclarativeAgentDefinition terminology
89 lines
3.6 KiB
C#
89 lines
3.6 KiB
C#
// Copyright (c) Microsoft. All rights reserved.
|
|
|
|
using Azure.AI.Projects;
|
|
using Azure.AI.Projects.Agents;
|
|
using Azure.Identity;
|
|
using Microsoft.Extensions.AI;
|
|
using Microsoft.Extensions.Configuration;
|
|
using OpenAI.Responses;
|
|
using Shared.Foundry;
|
|
using Shared.Workflows;
|
|
|
|
namespace Demo.Workflows.Declarative.InvokeFunctionTool;
|
|
|
|
/// <summary>
|
|
/// Demonstrate a workflow that uses InvokeFunctionTool to call functions directly
|
|
/// from the workflow without going through an AI agent first.
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// The InvokeFunctionTool action allows workflows to invoke function tools directly,
|
|
/// enabling pre-fetching of data or executing operations before calling an AI agent.
|
|
/// See the README.md file in the parent folder (../README.md) for detailed
|
|
/// information about the configuration required to run this sample.
|
|
/// </remarks>
|
|
internal sealed class Program
|
|
{
|
|
public static async Task Main(string[] args)
|
|
{
|
|
// Initialize configuration
|
|
IConfiguration configuration = Application.InitializeConfig();
|
|
Uri foundryEndpoint = new(configuration.GetValue(Application.Settings.FoundryEndpoint));
|
|
|
|
// Create the menu plugin with functions that can be invoked directly by the workflow
|
|
MenuPlugin menuPlugin = new();
|
|
AIFunction[] functions =
|
|
[
|
|
AIFunctionFactory.Create(menuPlugin.GetMenu),
|
|
AIFunctionFactory.Create(menuPlugin.GetSpecials),
|
|
AIFunctionFactory.Create(menuPlugin.GetItemPrice),
|
|
];
|
|
|
|
// Ensure sample agent exists in Foundry
|
|
await CreateAgentAsync(foundryEndpoint, configuration);
|
|
|
|
// Get input from command line or console
|
|
string workflowInput = Application.GetInput(args);
|
|
|
|
// Create the workflow factory.
|
|
WorkflowFactory workflowFactory = new("InvokeFunctionTool.yaml", foundryEndpoint);
|
|
|
|
// Execute the workflow
|
|
WorkflowRunner runner = new(functions) { UseJsonCheckpoints = true };
|
|
await runner.ExecuteAsync(workflowFactory.CreateWorkflow, workflowInput);
|
|
}
|
|
|
|
private static async Task CreateAgentAsync(Uri foundryEndpoint, IConfiguration configuration)
|
|
{
|
|
// WARNING: DefaultAzureCredential is convenient for development but requires careful consideration in production.
|
|
AIProjectClient aiProjectClient = new(foundryEndpoint, new DefaultAzureCredential());
|
|
|
|
await aiProjectClient.CreateAgentAsync(
|
|
agentName: "FunctionMenuAgent",
|
|
agentDefinition: DefineMenuAgent(configuration, []), // Create Agent with no function tool in the definition.
|
|
agentDescription: "Provides information about the restaurant menu");
|
|
}
|
|
|
|
private static DeclarativeAgentDefinition DefineMenuAgent(IConfiguration configuration, AIFunction[] functions)
|
|
{
|
|
DeclarativeAgentDefinition agentDefinition =
|
|
new(configuration.GetValue(Application.Settings.FoundryModel))
|
|
{
|
|
Instructions =
|
|
"""
|
|
Answer the users questions about the menu.
|
|
Use the information provided in the conversation history to answer questions.
|
|
If the information is already available in the conversation, use it directly.
|
|
For questions or input that do not require searching the documentation, inform the
|
|
user that you can only answer questions about what's on the menu.
|
|
"""
|
|
};
|
|
|
|
foreach (AIFunction function in functions)
|
|
{
|
|
agentDefinition.Tools.Add(function.AsOpenAIResponseTool());
|
|
}
|
|
|
|
return agentDefinition;
|
|
}
|
|
}
|