Universal.OpenAI.Client
3.0.0
dotnet add package Universal.OpenAI.Client --version 3.0.0
NuGet\Install-Package Universal.OpenAI.Client -Version 3.0.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="Universal.OpenAI.Client" Version="3.0.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Universal.OpenAI.Client --version 3.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Universal.OpenAI.Client, 3.0.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.
// Install Universal.OpenAI.Client as a Cake Addin #addin nuget:?package=Universal.OpenAI.Client&version=3.0.0 // Install Universal.OpenAI.Client as a Cake Tool #tool nuget:?package=Universal.OpenAI.Client&version=3.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
Universal.OpenAI.Client
Breaking Changes
- Message types are now more specific:
SystemMessage
,UserMessage
,AssistantMessage
,ToolMessage
,FunctionMessage
(deprecated), andUnknownMessage
. - The
Models
class now includesGpt4
,Gpt4Turbo
, and potentially other new models. ResponseFormat
can now be set toJsonObject
or a custom schema usingFromJsonSchema
.- Tool usage has been introduced, replacing the older function calling mechanism.
- The
Content
property of messages can now be either a string orIEnumerable<ContentBlock>
. - Embeddings, image generation have been marked as obsoleted. They will be refactored at a later point.
- Text completion support has been removed.
Usage
Chat Completion
using Universal.OpenAI.Client;
using Universal.OpenAI.Client.Chat;
using (OpenAIClient openAIClient = new OpenAIClient(ApiKey))
{
ChatCompletion response = await openAIClient.CreateChatCompletionAsync(new CreateChatCompletionRequest()
{
Model = Models.Gpt4,
Messages = new Message[]
{
new SystemMessage("You are a chatbot for a company named Red Marble AI. Be as helpful as you can without being too terse or verbose.")
}
});
foreach (var choice in response.Choices)
{
Console.WriteLine(choice.Message.Content);
}
}
JSON Output Enforcement
You can enforce JSON output from the model:
ChatCompletion response = await openAIClient.CreateChatCompletionAsync(new CreateChatCompletionRequest()
{
Model = Models.Gpt4Turbo,
Messages = [
new SystemMessage("Your system message here"),
new UserMessage("Your user message here")
],
ResponseFormat = ResponseFormat.JsonObject
});
Structured JSON Output
You can specify a schema for structured JSON output:
ChatCompletion response = await openAIClient.CreateChatCompletionAsync(new CreateChatCompletionRequest()
{
Model = "gpt-4o-2024-08-06",
Messages = [
new UserMessage("Your message here")
],
ResponseFormat = ResponseFormat.FromJsonSchema("schema_name", new JsonSchema()
{
Type = "object",
Properties = new Dictionary<string, JsonSchema>()
{
["propertyName"] = new JsonSchema()
{
Type = "boolean",
Description = "Property description"
}
},
AdditionalProperties = false,
Required = ["propertyName"]
})
});
Using Tools
You can use tools (like functions) in your chat completions:
ChatCompletion firstTurn = await openAIClient.CreateChatCompletionAsync(new CreateChatCompletionRequest()
{
Model = "gpt-4o-2024-08-06",
Messages = [
new SystemMessage("System message"),
new UserMessage("User message")
],
Tools = [
new Tool() {
Type = ToolTypes.Function,
Function = new Function()
{
Name = "function_name",
Description = "Function description",
Parameters = new JsonSchema
{
// Define your function parameters here
}
}
}
]
});
// Process the tool call and get the tool response
ChatCompletion secondTurn = await openAIClient.CreateChatCompletionAsync(new CreateChatCompletionRequest()
{
Model = "gpt-4o-2024-08-06",
Messages = [
// Previous messages
new ToolMessage(toolResponse, toolCallId)
]
});
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
.NETStandard 2.0
- Newtonsoft.Json (>= 13.0.3)
- Universal.Common.Json (>= 1.0.2)
- Universal.Common.Net.Http (>= 5.0.0)
- Universal.Common.Serialization (>= 2.4.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Moved individual operations and models to dedicated namespaces.
Implemented support for tool calling.
Implemented strongly-typed models with support for latest schema changes from OpenAI.