VOOZH about

URL: https://www.nuget.org/packages/AgentFrameworkToolkit.OpenAI/

⇱ NuGet Gallery | AgentFrameworkToolkit.OpenAI 1.10.0




👁 Image
AgentFrameworkToolkit.OpenAI 1.10.0

dotnet add package AgentFrameworkToolkit.OpenAI --version 1.10.0
 
 
NuGet\Install-Package AgentFrameworkToolkit.OpenAI -Version 1.10.0
 
 
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="AgentFrameworkToolkit.OpenAI" Version="1.10.0" />
 
 
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="AgentFrameworkToolkit.OpenAI" Version="1.10.0" />
 
Directory.Packages.props
<PackageReference Include="AgentFrameworkToolkit.OpenAI" />
 
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add AgentFrameworkToolkit.OpenAI --version 1.10.0
 
 
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: AgentFrameworkToolkit.OpenAI, 1.10.0"
 
 
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package AgentFrameworkToolkit.OpenAI@1.10.0
 
 
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=AgentFrameworkToolkit.OpenAI&version=1.10.0
 
Install as a Cake Addin
#tool nuget:?package=AgentFrameworkToolkit.OpenAI&version=1.10.0
 
Install as a Cake Tool
The NuGet Team does not provide support for this client. Please contact its maintainers for support.

Agent Framework Toolkit @ OpenAI

This package is aimed at OpenAI as an LLM Provider. Check out the General README.md for other providers and shared features in Agent Framework Toolkit.

What is Agent Framework Toolkit?

Agent Framework Toolkit is an opinionated C# wrapper on top of the Microsoft Agent Framework that makes various things easier to work with:

FAQ

Q: If I use the Agent Framework Toolkit, does it limit or hinder what I can do with Microsoft Agent Framework?

A: No, everything you can do with Microsoft Agent Framework can still be done with Agent Framework Toolkit. It is just a wrapper that enables options that are hard to use otherwise

Q: What is the release frequency of Agent Framework Toolkit (can I always use the latest Microsoft Agent Framework release)?

A: This NuGet package is released as often (or more) than the Microsoft Agent Framework. At a minimum, it will be bumped to the latest Microsoft Agent Framework Release within a day of official release. It follows the same versioning scheme as AF, so the same or higher version number will always be compatible with the latest release.

Q: Why are the agents not AIAgent / ChatClientAgents? Are they compatible with the rest of the Microsoft Agent Framework?

A: The specialized agents in Agent Framework Toolkit are all 100% compatible with AF as they simply inherit from AIAgent

Getting Started

  1. Install the 'AgentFrameworkToolkit.OpenAI' NuGet Package (dotnet add package AgentFrameworkToolkit.OpenAI)
  2. Get your OpenAI API Key
  3. Create an OpenAIAgentFactory instance (Namespace: AgentFrameworkToolkit.OpenAI)
  4. Use instance to create your OpenAIAgent (which is a regular Microsoft Agent Framework AIAgent behind the scenes)

Minimal Code Example

//Create your AgentFactory
OpenAIAgentFactory agentFactory = new OpenAIAgentFactory("<API Key>");

//Create your Agent
OpenAIAgent agent = agentFactory.CreateAgent("gpt-5");
AgentResponse response = await agent.RunAsync("Hello World");
Console.WriteLine(response);

Normal Code Example

//Create your AgentFactory
OpenAIAgentFactory agentFactory = new OpenAIAgentFactory("<API Key>");

//Create your Agent
OpenAIAgent agent = agentFactory.CreateAgent(new AgentOptions //Use AgentOptions overload to access more options
{
 Model = "gpt-5",
 ReasoningEffort = OpenAIReasoningEffort.Low, //Set reasoning effort
 Instructions = "You are a nice AI", //The System Prompt
 Tools = [], //Add your tools here
});

AgentResponse response = await agent.RunAsync("Hello World");
Console.WriteLine(response);

Full Code example with ALL options

//Create your AgentFactory (using a connection object for more options)
OpenAIAgentFactory agentFactory = new OpenAIAgentFactory(new OpenAIConnection
{
 //Endpoint = "<endpoint>", //Optional: if targeting non-OpenAI provider
 ApiKey = "<apiKey>",
 NetworkTimeout = TimeSpan.FromMinutes(5), //Set call timeout
 DefaultClientType = ClientType.ResponsesApi, //Set default Client Type for each agent (ChatClient or ResponsesAPI)
 AdditionalOpenAIClientOptions = options =>
 {
 //Set additional properties if needed
 }
});

//Create your Agent
OpenAIAgent agent = agentFactory.CreateAgent(new AgentOptions
{
 //Mandatory
 Model = "gpt-5", //Model to use
 
 //Optional (Common)
 ClientType = ClientType.ChatClient, //Choose ClientType (ChatClient or Responses API)
 Name = "MyAgent", //Agent Name
 Temperature = 0, //The Temperature of the LLM Call (1 = Normal; 0 = Less creativity) [ONLY NON-REASONING MODELS]
 ReasoningEffort = OpenAIReasoningEffort.Low, //Set Reasoning Effort [ONLY REASONING MODELS]
 ReasoningSummaryVerbosity = OpenAIReasoningSummaryVerbosity.Detailed, //Only used in Responses API [ONLY REASONING MODELS]
 StoredOutputEnabled = false, //Set OpenAI's "store" setting
 ServiceTier = OpenAIServiceTier.Default, //Set OpenAI service tier
 Instructions = "You are a nice AI", //The System Prompt for the Agent to Follow
 Tools = [], //Add your tools for Tool Calling here
 ToolCallingMiddleware = async (callingAgent, context, next, token) => //Tool Calling Middleware to Inspect, change, and cancel tool-calling
 {
 AIFunctionArguments arguments = context.Arguments; //Details on the tool-call that is about to happen
 return await next(context, token);
 },
 OpenTelemetryMiddleware = new OpenTelemetryMiddleware(source: "MyOpenTelemetrySource", telemetryAgent => telemetryAgent.EnableSensitiveData = true), //Configure OpenTelemetry Middleware

 //Optional (Rarely used)
 MaxOutputTokens = 2000, //Max allow token
 Id = "1234", //Set the ID of Agent (else a random GUID is assigned as ID)
 Description = "My Description", //Description of the Agent (not used by the LLM)
 LoggingMiddleware = new LoggingMiddleware( /* Configure custom logging */),
 Services = null, //Setup Tool Calling Service Injection (See https://youtu.be/EGs-Myf5MB4 for more details)
 LoggerFactory = null, //Setup logger Factory (Alternative to Middleware)
 ChatHistoryProvider = new MyChatMessageStore(), //Set a custom message store
 AIContextProviders = [new MyAIContextProvider()], //Set custom AI context providers
 AdditionalChatClientAgentOptions = options =>
 {
 //Option to set even more options if not covered by AgentFrameworkToolkit
 },
 RawToolCallDetails = Console.WriteLine, //Raw Tool calling Middleware (if you just wish to log what tools are being called. ToolCallingMiddleware is a more advanced version of this)
 RawHttpCallDetails = details => //Intercept the raw HTTP Call to the LLM (great for advanced debugging sessions)
 {
 Console.WriteLine(details.RequestUrl);
 Console.WriteLine(details.RequestData);
 Console.WriteLine(details.ResponseData);
 },
 ClientFactory = client =>
 {
 //Interact with the underlying Client-factory
 return client;
 }
});

AgentResponse response = await agent.RunAsync("Hello World");
Console.WriteLine(response);

Batch Runner

OpenAIBatchRunner batchRunner = new("<apiKey>");

ChatBatchRun run = await batchRunner.RunChatBatchAsync(
 new ChatBatchOptions
 {
 Model = "gpt-5-mini"
 },
 [
 ChatBatchRequest.Create("Summarize this text.")
 ]);

EmbeddingBatchRun embeddingRun = await batchRunner.RunEmbeddingBatchAsync(
 new EmbeddingBatchOptions
 {
 Model = "text-embedding-3-small"
 },
 [
 EmbeddingBatchRequest.Create("Embed this text.")
 ]);

Note: Batch runner APIs are marked experimental with AFT999.

Product Versions Compatible and additional computed target framework versions.
.NET net8.0 net8.0 is compatible.  net8.0-android net8.0-android was computed.  net8.0-browser net8.0-browser was computed.  net8.0-ios net8.0-ios was computed.  net8.0-maccatalyst net8.0-maccatalyst was computed.  net8.0-macos net8.0-macos was computed.  net8.0-tvos net8.0-tvos was computed.  net8.0-windows net8.0-windows was computed.  net9.0 net9.0 was computed.  net9.0-android net9.0-android was computed.  net9.0-browser net9.0-browser was computed.  net9.0-ios net9.0-ios was computed.  net9.0-maccatalyst net9.0-maccatalyst was computed.  net9.0-macos net9.0-macos was computed.  net9.0-tvos net9.0-tvos was computed.  net9.0-windows net9.0-windows was computed.  net10.0 net10.0 was computed.  net10.0-android net10.0-android was computed.  net10.0-browser net10.0-browser was computed.  net10.0-ios net10.0-ios was computed.  net10.0-maccatalyst net10.0-maccatalyst was computed.  net10.0-macos net10.0-macos was computed.  net10.0-tvos net10.0-tvos was computed.  net10.0-windows net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (6)

Showing the top 5 NuGet packages that depend on AgentFrameworkToolkit.OpenAI:

Package Downloads
AgentFrameworkToolkit.AzureOpenAI

An opinionated C# Toolkit targeting Azure OpenAI for Microsoft Agent Framework that makes life eaisier

AgentFrameworkToolkit.XAI

An opinionated C# Toolkit targeting XAI (Grok) for Microsoft Agent Framework that makes life eaisier

AgentFrameworkToolkit.OpenRouter

An opinionated C# Toolkit targeting OpenRouter for Microsoft Agent Framework that makes life eaisier

AgentFrameworkToolkit.Cohere

An opinionated C# Toolkit targeting Cohere for Microsoft Agent Framework that makes life easier

WASU.Plugin.AIAgent

Package Description

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
1.10.0 204 6/10/2026
1.9.0 484 6/4/2026
1.8.0 373 5/28/2026
1.7.0 191 5/27/2026
1.6.2 213 5/20/2026
1.6.1 255 5/14/2026
1.5.0 178 5/14/2026
1.4.0 387 5/5/2026
1.3.0 1,234 4/24/2026
1.2.0 233 4/22/2026
1.1.0 669 4/10/2026
1.0.0 794 4/2/2026
1.0.0-rc5 234 3/31/2026
1.0.0-rc4.2 75 3/31/2026
1.0.0-rc4.1 66 3/31/2026
1.0.0-rc4 1,213 3/12/2026
1.0.0-rc3.1 434 3/8/2026
1.0.0-rc3 205 3/4/2026
1.0.0-rc2 685 2/26/2026
1.0.0-rc1 508 2/21/2026
Loading failed