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                
#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                

Universal.OpenAI.Client

Breaking Changes

  1. Message types are now more specific: SystemMessage, UserMessage, AssistantMessage, ToolMessage, FunctionMessage (deprecated), and UnknownMessage.
  2. The Models class now includes Gpt4, Gpt4Turbo, and potentially other new models.
  3. ResponseFormat can now be set to JsonObject or a custom schema using FromJsonSchema.
  4. Tool usage has been introduced, replacing the older function calling mechanism.
  5. The Content property of messages can now be either a string or IEnumerable<ContentBlock>.
  6. Embeddings, image generation have been marked as obsoleted. They will be refactored at a later point.
  7. 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 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.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
3.0.0 85 9/30/2024
2.4.0 116 9/4/2024
2.3.0 154 7/2/2024
2.2.0 258 8/3/2023
2.1.1 330 3/27/2023
2.1.0 258 3/6/2023
2.0.0 249 3/1/2023
1.0.0 339 12/7/2022

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.