Share via


AIAgent Class

Definition

Provides the base abstraction for all AI agents, defining the core interface for agent interactions and conversation management.

public abstract class AIAgent
type AIAgent = class
Public MustInherit Class AIAgent
Inheritance
AIAgent
Derived

Remarks

AIAgent serves as the foundational class for implementing AI agents that can participate in conversations and process user requests. An agent instance may participate in multiple concurrent conversations, and each conversation may involve multiple agents working together.

Constructors

Name Description
AIAgent()

Properties

Name Description
CurrentRunContext

Gets or sets the AgentRunContext for the current agent run.

Description

Gets a description of the agent's purpose, capabilities, or behavior.

Id

Gets the unique identifier for this agent instance.

IdCore

Gets a custom identifier for the agent, which can be overridden by derived classes.

Name

Gets the human-readable name of the agent.

Methods

Name Description
CreateSessionAsync(CancellationToken)

Creates a new conversation session that is compatible with this agent.

CreateSessionCoreAsync(CancellationToken)

Core implementation of session creation logic.

DeserializeSessionAsync(JsonElement, JsonSerializerOptions, CancellationToken)

Deserializes an agent session from its JSON serialized representation.

DeserializeSessionCoreAsync(JsonElement, JsonSerializerOptions, CancellationToken)

Core implementation of session deserialization logic.

GetService(Type, Object)

Asks the AIAgent for an object of the specified type serviceType.

GetService<TService>(Object)

Asks the AIAgent for an object of type TService.

RunAsync(AgentSession, AgentRunOptions, CancellationToken)

Run the agent with no message assuming that all required instructions are already provided to the agent or on the session.

RunAsync(ChatMessage, AgentSession, AgentRunOptions, CancellationToken)

Runs the agent with a single chat message.

RunAsync(IEnumerable<ChatMessage>, AgentSession, AgentRunOptions, CancellationToken)

Runs the agent with a collection of chat messages, providing the core invocation logic that all other overloads delegate to.

RunAsync(String, AgentSession, AgentRunOptions, CancellationToken)

Runs the agent with a text message from the user.

RunAsync<T>(AgentSession, JsonSerializerOptions, AgentRunOptions, CancellationToken)

Run the agent with no message assuming that all required instructions are already provided to the agent or on the session, and requesting a response of the specified type T.

RunAsync<T>(ChatMessage, AgentSession, JsonSerializerOptions, AgentRunOptions, CancellationToken)

Runs the agent with a single chat message, requesting a response of the specified type T.

RunAsync<T>(IEnumerable<ChatMessage>, AgentSession, JsonSerializerOptions, AgentRunOptions, CancellationToken)

Runs the agent with a collection of chat messages, requesting a response of the specified type T.

RunAsync<T>(String, AgentSession, JsonSerializerOptions, AgentRunOptions, CancellationToken)

Runs the agent with a text message from the user, requesting a response of the specified type T.

RunCoreAsync(IEnumerable<ChatMessage>, AgentSession, AgentRunOptions, CancellationToken)

Core implementation of the agent invocation logic with a collection of chat messages.

RunCoreStreamingAsync(IEnumerable<ChatMessage>, AgentSession, AgentRunOptions, CancellationToken)

Core implementation of the agent streaming invocation logic with a collection of chat messages.

RunStreamingAsync(AgentSession, AgentRunOptions, CancellationToken)

Runs the agent in streaming mode without providing new input messages, relying on existing context and instructions.

RunStreamingAsync(ChatMessage, AgentSession, AgentRunOptions, CancellationToken)

Runs the agent in streaming mode with a single chat message.

RunStreamingAsync(IEnumerable<ChatMessage>, AgentSession, AgentRunOptions, CancellationToken)

Runs the agent in streaming mode with a collection of chat messages, providing the core streaming invocation logic.

RunStreamingAsync(String, AgentSession, AgentRunOptions, CancellationToken)

Runs the agent in streaming mode with a text message from the user.

SerializeSessionAsync(AgentSession, JsonSerializerOptions, CancellationToken)

Serializes an agent session to its JSON representation.

SerializeSessionCoreAsync(AgentSession, JsonSerializerOptions, CancellationToken)

Core implementation of session serialization logic.

Extension Methods

Name Description
AsAIFunction(AIAgent, AIFunctionFactoryOptions, AgentSession)

Creates an AIFunction that runs the provided AIAgent.

AsBuilder(AIAgent)

Creates a new AIAgentBuilder using the specified agent as the foundation for the builder pipeline.

AsDurableAgentProxy(AIAgent, IServiceProvider)

Converts an AIAgent to a durable agent proxy.

BindAsExecutor(AIAgent, AIAgentHostOptions)

Configure an AIAgent as an executor for use in a workflow.

BindAsExecutor(AIAgent, Boolean)

Configure an AIAgent as an executor for use in a workflow.

MapA2A(AIAgent, AgentCard, ITaskManager, ILoggerFactory, AgentSessionStore, AgentRunMode, JsonSerializerOptions)

Attaches A2A (Agent2Agent) messaging capabilities via Message processing to the specified AIAgent.

MapA2A(AIAgent, ITaskManager, ILoggerFactory, AgentSessionStore, AgentRunMode, JsonSerializerOptions)

Attaches A2A (Agent2Agent) messaging capabilities via Message processing to the specified AIAgent.

RunAsync(AIAgent, IEnumerable<ChatMessage>, AgentSession, AgentRunOptions, CancellationToken)

Runs the AI agent with a collection of OpenAI chat messages and returns the response as a native OpenAI OpenAI.Chat.ChatCompletion.

RunAsync(AIAgent, IEnumerable<ResponseItem>, AgentSession, AgentRunOptions, CancellationToken)

Runs the AI agent with a collection of OpenAI response items and returns the response as a native OpenAI OpenAI.Responses.ResponseResult.

RunStreamingAsync(AIAgent, IEnumerable<ChatMessage>, AgentSession, AgentRunOptions, CancellationToken)

Runs the AI agent with a single OpenAI chat message and returns the response as collection of native OpenAI OpenAI.Chat.StreamingChatCompletionUpdate.

RunStreamingAsync(AIAgent, IEnumerable<ResponseItem>, AgentSession, AgentRunOptions, CancellationToken)

Runs the AI agent in streaming mode with a collection of OpenAI response items and returns the response as a collection of native OpenAI OpenAI.Responses.StreamingResponseUpdate.

Applies to