Mscc.GenerativeAI
                             
                            
                                2.8.16
                            
                        
                    See the version list below for details.
dotnet add package Mscc.GenerativeAI --version 2.8.16
NuGet\Install-Package Mscc.GenerativeAI -Version 2.8.16
<PackageReference Include="Mscc.GenerativeAI" Version="2.8.16" />
<PackageVersion Include="Mscc.GenerativeAI" Version="2.8.16" />
<PackageReference Include="Mscc.GenerativeAI" />
paket add Mscc.GenerativeAI --version 2.8.16
#r "nuget: Mscc.GenerativeAI, 2.8.16"
#:package Mscc.GenerativeAI@2.8.16
#addin nuget:?package=Mscc.GenerativeAI&version=2.8.16
#tool nuget:?package=Mscc.GenerativeAI&version=2.8.16
Gemini API Client for .NET and ASP.NET Core
<picture> <img alt="Gemini SDK for .NET" src="./docs/images/GeminiNET.png" /> </picture>
Access and integrate the Gemini API into your .NET applications. This SDK allows you to connect to the Gemini API through either Google AI Studio or Vertex AI. The SDK is fully compatible with all Gemini API models and features, including recent additions like improved tool usage (code execution, function calling and integrated Google search grounding), and media generation (Imagen).
| Name | Package | Status | 
|---|---|---|
| Client for .NET | Mscc.GenerativeAI | |
| Client for ASP.NET (Core) | Mscc.GenerativeAI.Web | |
| Client for .NET using Google API Client Library | Mscc.GenerativeAI.Google | |
| Client for Microsoft.Extensions.AI and Semantic Kernel | Mscc.GenerativeAI.Microsoft | 
Read more about Mscc.GenerativeAI.Web and how to add it to your ASP.NET (Core) web applications. Read more about Mscc.GenerativeAI.Google. Read more about Mscc.GenerativeAI.Microsoft and how to use it with Semantic Kernel.
Install the package 🖥️
Install the package Mscc.GenerativeAI from NuGet. You can install the package from the command line using either the command line or the NuGet Package Manager Console. Or you add it directly to your .NET project.
Add the package using the dotnet command line tool in your .NET project folder.
> dotnet add package Mscc.GenerativeAI
Working with Visual Studio use the NuGet Package Manager to install the package Mscc.GenerativeAI.
PM> Install-Package Mscc.GenerativeAI
Alternatively, add the following line to your .csproj file.
  <ItemGroup>
    <PackageReference Include="Mscc.GenerativeAI" Version="2.8.16" />
  </ItemGroup>
You can then add this code to your sources whenever you need to access any Gemini API provided by Google. This package works for Google AI (Google AI Studio) and Google Cloud Vertex AI.
Features (as per Gemini analysis) ✦
The provided code defines a C# library for interacting with Google's Generative AI models, specifically the Gemini models. It provides functionalities to:
- List available models: This allows users to see which models are available for use.
- Get information about a specific model: This provides details about a specific model, such as its capabilities and limitations.
- Generate content: This allows users to send prompts to a model and receive generated text in response.
- Generate content stream: This allows users to receive a stream of generated text from a model, which can be useful for real-time applications.
- Generate a grounded answer: This allows users to ask questions and receive answers that are grounded in provided context.
- Generate embeddings: This allows users to convert text into numerical representations that can be used for tasks like similarity search.
- Count tokens: This allows users to estimate the cost of using a model by counting the number of tokens in a prompt or response.
- Start a chat session: This allows users to have a back-and-forth conversation with a model.
- Create tuned models: This allows users to provide samples for tuning an existing model. Currently, only the text-bison-001andgemini-2.0-flash-001models are supported for tuning
- File API: This allows users to upload large files and use them with Gemini 2.0 and later.
The package also defines various helper classes and enums to represent different aspects of the Gemini API, such as model names, request parameters, and response data.
Authentication use cases 👥
The package supports the following use cases to authenticate.
| API | Authentication | Remarks | 
|---|---|---|
| Google AI | Authentication with an API key | |
| Google AI | Authentication with OAuth | required for tuned models | 
| Vertex AI | Authentication with Application Default Credentials (ADC) | |
| Vertex AI | Authentication with Credentials by Metadata Server | requires access to a metadata server | 
| Vertex AI | Authentication with OAuth | using Mscc.GenerativeAI.Google | 
| Vertex AI | Authentication with Service Account | using Mscc.GenerativeAI.Google | 
| Vertex AI | Express Mode with an API key | 
This applies mainly to the instantiation procedure.
Getting Started 🚀
Use of Gemini API in either Google AI or Vertex AI is almost identical. The major difference is the way to instantiate the model handling your prompt.
Using Environment variables
In the cloud most settings are configured via environment variables (EnvVars). The ease of configuration, their widespread support and the simplicity of environment variables makes them a very interesting option.
| Variable Name | Description | 
|---|---|
| GOOGLE_AI_MODEL | The name of the model to use (default is Model.Gemini25Pro) | 
| GOOGLE_API_KEY | The API key generated in Google AI Studio | 
| GEMINI_API_KEY | -"- | 
| GOOGLE_PROJECT_ID | Project ID in Google Cloud to access the APIs | 
| GOOGLE_CLOUD_PROJECT | -"- | 
| GOOGLE_REGION | Region in Google Cloud (default is us-central1) | 
| GOOGLE_CLOUD_LOCATION | -"- | 
| GOOGLE_ACCESS_TOKEN | The access token required to use models running in Vertex AI | 
| GOOGLE_APPLICATION_CREDENTIALS | Path to the application credentials file. | 
| GOOGLE_WEB_CREDENTIALS | Path to a Web credentials file. | 
Using any environment variable provides simplified access to a model.
using Mscc.GenerativeAI;
var model = new GenerativeModel();
Choose an API and authentication mode
Google AI with an API key
using Mscc.GenerativeAI;
// Google AI with an API key
var googleAI = new GoogleAI(apiKey: "your API key");
var model = googleAI.GenerativeModel(model: Model.Gemini25Flash);
Google AI with OAuth. Use gcloud auth application-default print-access-token to get the access token.
using Mscc.GenerativeAI;
// Google AI with OAuth. Use `gcloud auth application-default print-access-token` to get the access token.
var accessToken = "your access token";
var googleAI = new GoogleAI(accessToken: accessToken);
var model = googleAI.GenerativeModel(model: Model.Gemini25Flash);
Vertex AI with OAuth. Use gcloud auth application-default print-access-token to get the access token.
using Mscc.GenerativeAI;
// Vertex AI with OAuth. Use `gcloud auth application-default print-access-token` to get the access token.
var vertex = new VertexAI(projectId: projectId, region: region);
var model = vertex.GenerativeModel(model: Model.Gemini25Flash);
model.AccessToken = accessToken;
Vertex AI in express mode using an API key.
using Mscc.GenerativeAI;
// Vertex AI in express mode with an API key.
var vertex = new VertexAI(apiKey: "your API key");
var model = vertex.GenerativeModel(model: Model.Gemini25Flash);
The ConfigurationFixture type in the test project implements multiple options to retrieve sensitive information, i.e. API key or access token.
Using Google AI Gemini API
Working with Google AI in your application requires an API key. Get an API key from Google AI Studio.
using Mscc.GenerativeAI;
var apiKey = "your_api_key";
var prompt = "Write a story about a magic backpack.";
var googleAI = new GoogleAI(apiKey: apiKey);
var model = googleAI.GenerativeModel(model: Model.Gemini25Flash);
var response = await model.GenerateContent(prompt);
Console.WriteLine(response.Text);
Using Vertex AI Gemini API
Use of Vertex AI requires an account on Google Cloud, a project with billing and Vertex AI API enabled.
using Mscc.GenerativeAI;
var projectId = "your_google_project_id"; // the ID of a project, not its name.
var region = "us-central1";     // see documentation for available regions.
var accessToken = "your_access_token";      // use `gcloud auth application-default print-access-token` to get it.
var prompt = "Write a story about a magic backpack.";
var vertex = new VertexAI(projectId: projectId, region: region);
var model = vertex.GenerativeModel(model: Model.Gemini25Flash);
model.AccessToken = accessToken;
var response = await model.GenerateContent(prompt);
Console.WriteLine(response.Text);
Using Vertex AI in express mode
Vertex AI in express mode is the fastest way to start building generative AI applications on Google Cloud. Signing up in express mode is quick and easy, and it doesn't require entering any billing information. After you sign up, you can access and use Google Cloud APIs in just a few steps.
using Mscc.GenerativeAI;
var prompt = "Explain bubble sort to me.";
var vertex = new VertexAI(apiKey: "your API key");
var model = vertex.GenerativeModel(model: Model.Gemini25Flash);
var response = await model.GenerateContent(prompt);
Console.WriteLine(response.Text);
More examples 🪄
Supported models are accessible via the Model class. Since release 0.9.0 there is support for the previous PaLM 2 models and their functionalities.
Use system instruction
The model can be injected with a system instruction that applies to all further requests. Following is an example how to instruct the model to respond like a pirate.
var apiKey = "your_api_key";
var systemInstruction = new Content("You are a friendly pirate. Speak like one.");
var prompt = "Good morning! How are you?";
IGenerativeAI genAi = new GoogleAI(apiKey);
var model = genAi.GenerativeModel(Model.Gemini25Flash, 
    systemInstruction: systemInstruction);
var request = new GenerateContentRequest(prompt);
var response = await model.GenerateContent(request);
Console.WriteLine(response.Text);
The response might look similar to this:
Ahoy there, matey! I be doin' finer than a freshly swabbed poop deck on this fine mornin', how about yerself?  
Shimmer me timbers, it's good to see a friendly face!  
What brings ye to these here waters?
Generate structured output
Gemini generates unstructured text by default, but some applications require structured text. For these use cases, you can constrain Gemini to respond with JSON, a structured data format suitable for automated processing.
You can control the structure of the JSON response by supplying a schema. There are two ways to supply a schema to the model:
- As text in the prompt
- As a structured schema supplied through model configuration
class Recipe {
    public string RecipeName { get; set; }
    public List<string> Ingredients { get; set; }
}
// generate structure JSON output
var apiKey = "your_api_key";
var prompt = "List a few popular cookie recipes, and include the amounts of ingredients.";
var googleAi = new GoogleAI(apiKey);
var model = googleAi.GenerativeModel(model: Model.Gemini25Flash);
var generationConfig = new GenerationConfig()
{
    ResponseMimeType = "application/json",
    ResponseSchema = Schema.FromType<List<Recipe>>()
};
var response = await model.GenerateContent(prompt, 
    generationConfig: generationConfig);
Console.WriteLine(response?.Text);
The output might look like this:
[{"recipeName": "Chocolate Chip Cookies"}, {"recipeName": "Peanut Butter Cookies"}, {"recipeName": "Snickerdoodles"}, {"recipeName": "Oatmeal Raisin Cookies"}, {"recipeName": "Sugar Cookies"}]
Use Google Search
To activate Google Search as a tool, set the boolean property UseGoogleSearch to true, like the following example.
var apiKey = "your_api_key";
var prompt = "When is the next total solar eclipse in Mauritius?";
var genAi = new GoogleAI(apiKey);
var model = genAi.GenerativeModel(Model.Gemini25Flash);
model.UseGoogleSearch = true;
var response = await model.GenerateContent(prompt);
Console.WriteLine(string.Join(Environment.NewLine,
    response.Candidates![0].Content!.Parts
        .Select(x => x.Text)
        .ToArray()));
More details are described in the API documentation on Search as a tool.
Grounding with Google Search (deprecated)
The simplest version is to toggle the boolean property UseGrounding, like so.
var apiKey = "your_api_key";
var prompt = "What is the current Google stock price?";
var genAi = new GoogleAI(apiKey);
var model = genAi.GenerativeModel(Model.Gemini25Flash);
model.UseGrounding = true;
var response = await model.GenerateContent(prompt);
Console.WriteLine(response.Text);
In case that you would like to have more control over the Google Search retrieval parameters, use the following approach.
var apiKey = "your_api_key";
var prompt = "Who won Wimbledon this year?";
IGenerativeAI genAi = new GoogleAI(apiKey);
var model = genAi.GenerativeModel(Model.Gemini25Flash,
    tools: [new Tool { GoogleSearchRetrieval = 
        new(DynamicRetrievalConfigMode.ModeUnspecified, 0.06f) }]);
var response = await model.GenerateContent(prompt);
Console.WriteLine(response.Text);
In either case, the returned Candidates item type has an additional property GroundingMetadata which provides the details of the Google Search based grounding
Thinking and budget
using Mscc.GenerativeAI;
var apiKey = "your_api_key";
var prompt = "Give me a tutorial to create a landing page";
var googleAI = new GoogleAI(apiKey: apiKey);
var model = googleAI.GenerativeModel(model: Model.Gemini25Flash);
var generationConfig = new GenerationConfig()
{
    ThinkingConfig = new ThinkingConfig()
    {
        IncludeThoughts = true,
        ThinkingBudget = 8192
    }
};
var response = await model.GenerateContent(prompt, 
    generationConfig: generationConfig);
Console.WriteLine(response?.Text);
Text-and-image input
using Mscc.GenerativeAI;
var apiKey = "your_api_key";
var prompt = "Parse the time and city from the airport board shown in this image into a list, in Markdown";
var googleAI = new GoogleAI(apiKey: apiKey);
var model = googleAI.GenerativeModel(model: Model.Gemini25Flash);
var request = new GenerateContentRequest(prompt);
await request.AddMedia("https://raw.githubusercontent.com/mscraftsman/generative-ai/refs/heads/main/tests/Mscc.GenerativeAI/payload/timetable.png");
var response = await model.GenerateContent(request);
Console.WriteLine(response.Text);
The part of InlineData is supported by both Google AI and Vertex AI. Whereas the part FileData is restricted to Vertex AI only.
Chat conversations
Gemini enables you to have freeform conversations across multiple turns. You can interact with Gemini Pro using a single-turn prompt and response or chat with it in a multi-turn, continuous conversation, even for code understanding and generation.
using Mscc.GenerativeAI;
var apiKey = "your_api_key";
var googleAI = new GoogleAI(apiKey);
var model = googleAI.GenerativeModel();    // using default model: gemini-2.5-pro
var chat = model.StartChat();   // optionally pass a previous history in the constructor.
// Instead of discarding you could also use the response and access `response.Text`.
_ = await chat.SendMessage("Hello, fancy brainstorming about IT?");
_ = await chat.SendMessage("In one sentence, explain how a computer works to a young child.");
_ = await chat.SendMessage("Okay, how about a more detailed explanation to a high schooler?");
_ = await chat.SendMessage("Lastly, give a thorough definition for a CS graduate.");
// A chat session keeps every response in its history.
chat.History.ForEach(c => Console.WriteLine($"{c.Role}: {c.Text}"));
// Last request/response pair can be removed from the history.
var latest = chat.Rewind();
Console.WriteLine($"{latest.Sent} - {latest.Received}");
Use Gemini 1.5 with large files
With Gemini 1.5 you can create multimodal prompts supporting large files.
The following example uploads one or more files via File API and the created File URIs are used in the GenerateContent call to generate text.
using Mscc.GenerativeAI;
var apiKey = "your_api_key";
var prompt = "Make a short story from the media resources. The media resources are:";
IGenerativeAI genAi = new GoogleAI(apiKey);
var model = genAi.GenerativeModel(Model.Gemini25Flash);
// Upload your large image(s).
// Instead of discarding you could also use the response and access `response.Text`.
var filePath = Path.Combine(Environment.CurrentDirectory, "verylarge.png");
var displayName = "My very large image";
_ = await model.UploadMedia(filePath, displayName);
// Create the prompt with references to File API resources.
var request = new GenerateContentRequest(prompt);
var files = await model.ListFiles();
foreach (var file in files.Where(x => x.MimeType.StartsWith("image/")))
{
    Console.WriteLine($"File: {file.Name}");
    request.AddMedia(file);
}
var response = await model.GenerateContent(request);
Console.WriteLine(response.Text);
Read more about Gemini 1.5: Our next-generation model, now available for Private Preview in Google AI Studio.
Create a tuned model
The Gemini API lets you tune models on your own data. Since it's your data and your tuned models this needs stricter access controls than API-Keys can provide.
Before you can create a tuned model, you'll need to set up OAuth for your project.
using Mscc.GenerativeAI;
var projectId = "your_google_project_id"; // the ID of a project, not its name.
var accessToken = "your_access_token";      // use `gcloud auth application-default print-access-token` to get it.
var googleAI = new GoogleAI(accessToken: accessToken);
var model = googleAI.GenerativeModel(model: Model.Gemini25Flash);
model.ProjectId = projectId;
var parameters = new HyperParameters() { BatchSize = 2, LearningRate = 0.001f, EpochCount = 3 };
var dataset = new List<TuningExample>
{    
    new() { TextInput = "1", Output = "2" },
    new() { TextInput = "3", Output = "4" },
    new() { TextInput = "-3", Output = "-2" },
    new() { TextInput = "twenty two", Output = "twenty three" },
    new() { TextInput = "two hundred", Output = "two hundred one" },
    new() { TextInput = "ninety nine", Output = "one hundred" },
    new() { TextInput = "8", Output = "9" },
    new() { TextInput = "-98", Output = "-97" },
    new() { TextInput = "1,000", Output = "1,001" },
    new() { TextInput = "thirteen", Output = "fourteen" },
    new() { TextInput = "seven", Output = "eight" },
};
var request = new CreateTunedModelRequest(Model.Gemini25Flash, 
    "Simply autogenerated Test model",
    dataset,
    parameters);
var response = await model.CreateTunedModel(request);
Console.WriteLine($"Name: {response.Name}");
Console.WriteLine($"Model: {response.Metadata.TunedModel} (Steps: {response.Metadata.TotalSteps})");
(This is still work in progress but operational. Future release will provide types to simplify the create request.)
Tuned models appear in your Google AI Studio library.
Read more about Tune Gemini Pro in Google AI Studio or with the Gemini API.
More samples
The folders samples and tests contain more examples.
- Sample console application
- ASP.NET Core Minimal web application
- ASP.NET Core MVP web application (work in progress!)
Troubleshooting ⚡
Sometimes you might have authentication warnings HTTP 403 (Forbidden). Especially while working with OAuth-based authentication. You can fix it by re-authenticating through ADC.
gcloud config set project "$PROJECT_ID"
gcloud auth application-default login
gcloud auth application-default set-quota-project "$PROJECT_ID"
Make sure that the required API have been enabled.
# ENABLE APIs
gcloud services enable aiplatform.googleapis.com
In case of long-running streaming requests it can happen that you get a HttpIOException: The response ended prematurely while waiting for the next frame from the server. (ResponseEnded).
The root cause is the .NET runtime and the solution is to upgrade to the latest version of the .NET runtime.
In case that you cannot upgrade you might disable dynamic window sizing as a workaround:
Either using the environment variable DOTNET_SYSTEM_NET_HTTP_SOCKETSHTTPHANDLER_HTTP2FLOWCONTROL_DISABLEDYNAMICWINDOWSIZING
DOTNET_SYSTEM_NET_HTTP_SOCKETSHTTPHANDLER_HTTP2FLOWCONTROL_DISABLEDYNAMICWINDOWSIZING=true
or setting an AppContext switch:
AppContext.SetSwitch("System.Net.SocketsHttpHandler.Http2FlowControl.DisableDynamicWindowSizing", true);
Several issues regarding this problem have been reported on GitHub:
- https://github.com/dotnet/runtime/pull/97881
- https://github.com/grpc/grpc-dotnet/issues/2361
- https://github.com/grpc/grpc-dotnet/issues/2358
Using the tests 🧩
The repository contains a number of test cases for Google AI and Vertex AI. You will find them in the tests folder. They are part of the [GenerativeAI solution].
To run the tests, either enter the relevant information into the appsettings.json, create a new appsettings.user.json file with the same JSON structure in the tests folder, or define the following environment variables
- GOOGLE_API_KEY
- GOOGLE_PROJECT_ID
- GOOGLE_REGION
- GOOGLE_ACCESS_TOKEN (optional: if absent, gcloud auth application-default print-access-tokenis executed)
The test cases should provide more insights and use cases on how to use the Mscc.GenerativeAI package in your .NET projects.
Timeout Configuration ⏱
You have two ways to configure timeouts for API requests:
Instance Default Timeout
You can set a default timeout for all operations on a GenerativeModel instance by setting its Timeout property (inherited from BaseModel). This should ideally be done after creating the model instance and before its first use:
var model = new GenerativeModel(...); 
model.Timeout = TimeSpan.FromSeconds(60);
Per-Request Timeout
For finer-grained control, you can specify a timeout for individual API calls using the RequestOptions parameter available on methods like GenerateContent, CountTokens, etc. This timeout works via cancellation:
var options = new RequestOptions { Timeout = TimeSpan.FromMilliseconds(500) }; 
await model.GenerateContent(prompt, requestOptions: options);
Resource Management (IDisposable) 🗑
GenerativeModel (via BaseModel) now implements IDisposable to manage the lifecycle of the underlying resources. It is recommended to dispose of GenerativeModel instances when they are no longer needed. This can be done using a using statement or by manually calling Dispose().
Example:
using (var model = new GenerativeModel(...))
{
    // use model
}
// model is automatically disposed here
Or manually:
var model = new GenerativeModel(...);
try
{
    // use model
}
finally
{
    model.Dispose();
}
Try it out 🤩
The following link opens an instance of the code repository in Google Project IDX.
<a href="https://idx.google.com/import?url=https%3A%2F%2Fgithub.com%2Fmscraftsman%2Fgenerative-ai"> <picture> <source media="(prefers-color-scheme: dark)" srcset="https://cdn.idx.dev/btn/try_dark_32.svg"> <source media="(prefers-color-scheme: light)" srcset="https://cdn.idx.dev/btn/try_light_32.svg"> <img height="32" alt="Try in IDX" src="https://cdn.idx.dev/btn/try_purple_32.svg"> </picture> </a>
This lets you work instantly with the code base without having to install anything.
Feedback and Contributions 🤝
For support and feedback kindly create issues at the https://github.com/mscraftsman/generative-ai repository. We encourage the community to contribute to this project! If there are additional features, interfaces, or improvements you would like to see, feel free to submit a pull request. Contributions of any kind are highly appreciated.
How to Contribute 📝
- Clone or fork the repository.
- Create a new branch for your feature or bugfix.
- Commit your changes and push the branch to GitHub.
- Submit a pull request, and we will review it as soon as possible.
Star History 🌟
<a href="https://www.star-history.com/#mscraftsman/generative-ai&Date"> <picture> <source media="(prefers-color-scheme: dark)" srcset="https://api.star-history.com/svg?repos=mscraftsman/generative-ai&type=Date&theme=dark" /> <source media="(prefers-color-scheme: light)" srcset="https://api.star-history.com/svg?repos=mscraftsman/generative-ai&type=Date" /> <img alt="Star History Chart" src="https://api.star-history.com/svg?repos=mscraftsman/generative-ai&type=Date" /> </picture> </a>
License 📜
This project is licensed under the Apache-2.0 License - see the LICENSE file for details.
Citation 📚
If you use Mscc.GenerativeAI in your research project, kindly cite as follows
@misc{Mscc.GenerativeAI,
  author = {Kirstätter, J and MSCraftsman},
  title = {Mscc.GenerativeAI - Gemini AI Client for .NET and ASP.NET Core},
  year = {2024},
  publisher = {GitHub},
  journal = {GitHub repository},
  note = {https://github.com/mscraftsman/generative-ai}
}
Created by Jochen Kirstätter.
| 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 is compatible. 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. net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.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. | 
- 
                                                    .NETStandard 2.0- JsonSchema.Net.Generation (>= 5.0.0)
- Microsoft.Bcl.AsyncInterfaces (>= 9.0.9)
- Microsoft.Extensions.Configuration.Abstractions (>= 9.0.9)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 9.0.9)
- Microsoft.Extensions.Http (>= 9.0.9)
- Microsoft.Extensions.Logging (>= 9.0.9)
- Microsoft.Extensions.Options (>= 9.0.9)
- Nullable (>= 1.3.1)
- System.Text.Encodings.Web (>= 9.0.9)
- System.Text.Json (>= 9.0.9)
 
- 
                                                    net8.0- JsonSchema.Net.Generation (>= 5.0.0)
- Microsoft.Extensions.Configuration.Abstractions (>= 9.0.9)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 9.0.9)
- Microsoft.Extensions.Http (>= 9.0.9)
- Microsoft.Extensions.Logging (>= 9.0.9)
- Microsoft.Extensions.Options (>= 9.0.9)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 9.0.9)
- System.Text.Encodings.Web (>= 9.0.9)
- System.Text.Json (>= 9.0.9)
 
- 
                                                    net9.0- JsonSchema.Net.Generation (>= 5.0.0)
- Microsoft.Extensions.Configuration.Abstractions (>= 9.0.9)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 9.0.9)
- Microsoft.Extensions.Http (>= 9.0.9)
- Microsoft.Extensions.Logging (>= 9.0.9)
- Microsoft.Extensions.Options (>= 9.0.9)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 9.0.9)
- System.Text.Json (>= 9.0.9)
 
NuGet packages (6)
Showing the top 5 NuGet packages that depend on Mscc.GenerativeAI:
| Package | Downloads | 
|---|---|
| Mscc.GenerativeAI.Google Gemini AI Client for .NET | |
| Mscc.GenerativeAI.Web A client for ASP.NET Core designed to consume Gemini AI. | |
| Mscc.GenerativeAI.Microsoft Gemini AI Client for .NET | |
| MedbaseLibrary Shared code for Medbase projects. | |
| fsEnsemble Package Description | 
GitHub repositories (2)
Showing the top 2 popular GitHub repositories that depend on Mscc.GenerativeAI:
| Repository | Stars | 
|---|---|
| sdcb/chats 
                                                            User-friendly Enterprise Ready AI Interface (Supports Ollama, OpenAI API, DeepSeek...)
                                                         | |
| JasonBock/Rocks 
                                                            A mocking library based on the Compiler APIs (Roslyn + Mocks)
                                                         | 
| Version | Downloads | Last Updated | 
|---|---|---|
| 2.8.19 | 1,776 | 10/20/2025 | 
| 2.8.18 | 610 | 10/17/2025 | 
| 2.8.17 | 1,147 | 10/13/2025 | 
| 2.8.16 | 988 | 10/8/2025 | 
| 2.8.15 | 1,429 | 10/2/2025 | 
| 2.8.14 | 1,644 | 9/30/2025 | 
| 2.8.13 | 723 | 9/29/2025 | 
| 2.8.12 | 733 | 9/26/2025 | 
| 2.8.11 | 510 | 9/25/2025 | 
| 2.8.10 | 1,575 | 9/22/2025 | 
| 2.8.9 | 3,163 | 9/12/2025 | 
| 2.8.8 | 242 | 9/12/2025 | 
| 2.8.7 | 1,290 | 9/9/2025 | 
| 2.8.6 | 180 | 9/9/2025 | 
| 2.8.5 | 1,050 | 9/9/2025 | 
| 2.8.4 | 317 | 9/8/2025 | 
| 2.8.3 | 4,838 | 8/28/2025 | 
| 2.8.2 | 407 | 8/26/2025 | 
| 2.8.1 | 1,543 | 8/26/2025 | 
| 2.8.0 | 358 | 8/25/2025 | 
| 2.7.1 | 969 | 8/20/2025 | 
| 2.7.0 | 779 | 8/18/2025 | 
| 2.6.13 | 482 | 8/16/2025 | 
| 2.6.12 | 350 | 8/15/2025 | 
| 2.6.11 | 137 | 8/15/2025 | 
| 2.6.10 | 217 | 8/15/2025 | 
| 2.6.9 | 1,745 | 8/8/2025 | 
| 2.6.8 | 5,704 | 7/21/2025 | 
| 2.6.7 | 2,800 | 7/16/2025 | 
| 2.6.6 | 963 | 7/15/2025 | 
| 2.6.5 | 891 | 7/11/2025 | 
| 2.6.4 | 2,362 | 6/26/2025 | 
| 2.6.3 | 4,619 | 6/5/2025 | 
| 2.6.2 | 3,056 | 6/3/2025 | 
| 2.6.1 | 1,447 | 5/26/2025 | 
| 2.6.0 | 756 | 5/23/2025 | 
| 2.5.6 | 1,312 | 5/16/2025 | 
| 2.5.5 | 2,485 | 5/8/2025 | 
| 2.5.4 | 1,184 | 5/8/2025 | 
| 2.5.3 | 955 | 4/28/2025 | 
| 2.5.2 | 7,269 | 4/19/2025 | 
| 2.5.1 | 156 | 4/19/2025 | 
| 2.5.0 | 2,012 | 4/11/2025 | 
| 2.4.1 | 1,305 | 4/2/2025 | 
| 2.4.0 | 3,941 | 3/25/2025 | 
| 2.3.6 | 563 | 3/16/2025 | 
| 2.3.5 | 212 | 3/16/2025 | 
| 2.3.4 | 4,703 | 3/12/2025 | 
| 2.3.3 | 547 | 3/12/2025 | 
| 2.3.2 | 613 | 3/8/2025 | 
| 2.3.1 | 211 | 3/8/2025 | 
| 2.3.0 | 375 | 3/7/2025 | 
| 2.2.11 | 2,818 | 2/27/2025 | 
| 2.2.10 | 176 | 2/26/2025 | 
| 2.2.9 | 3,121 | 2/24/2025 | 
| 2.2.8 | 172 | 2/24/2025 | 
| 2.2.7 | 979 | 2/20/2025 | 
| 2.2.6 | 182 | 2/20/2025 | 
| 2.2.5 | 267 | 2/18/2025 | 
| 2.2.4 | 799 | 2/17/2025 | 
| 2.2.3 | 4,736 | 2/13/2025 | 
| 2.2.2 | 1,199 | 2/12/2025 | 
| 2.2.1 | 485 | 2/11/2025 | 
| 2.2.0 | 1,713 | 2/7/2025 | 
| 2.1.8 | 212 | 2/7/2025 | 
| 2.1.7 | 658 | 2/6/2025 | 
| 2.1.6 | 206 | 2/3/2025 | 
| 2.1.5 | 342 | 2/3/2025 | 
| 2.1.4 | 166 | 2/3/2025 | 
| 2.1.3 | 1,409 | 1/28/2025 | 
| 2.1.2 | 236 | 1/27/2025 | 
| 2.1.1 | 1,554 | 1/17/2025 | 
| 2.1.0 | 258 | 1/16/2025 | 
| 2.0.2 | 2,335 | 1/6/2025 | 
| 2.0.1 | 3,620 | 12/11/2024 | 
| 2.0.0 | 776 | 12/11/2024 | 
| 1.9.7 | 588 | 12/6/2024 | 
| 1.9.6 | 1,082 | 11/26/2024 | 
| 1.9.5 | 349 | 11/22/2024 | 
| 1.9.4 | 202 | 11/21/2024 | 
| 1.9.3 | 593 | 11/20/2024 | 
| 1.9.2 | 644 | 11/18/2024 | 
| 1.9.1 | 298 | 11/13/2024 | 
| 1.9.0 | 1,249 | 11/4/2024 | 
| 1.8.3 | 1,552 | 11/1/2024 | 
| 1.8.2 | 606 | 10/31/2024 | 
| 1.8.1 | 3,428 | 10/30/2024 | 
| 1.8.0 | 1,981 | 10/29/2024 | 
| 1.7.0 | 632 | 10/14/2024 | 
| 1.6.5 | 1,923 | 10/13/2024 | 
| 1.6.4 | 2,231 | 10/9/2024 | 
| 1.6.3 | 1,893 | 9/24/2024 | 
| 1.6.2 | 225 | 9/19/2024 | 
| 1.6.1 | 339 | 9/18/2024 | 
| 1.6.0 | 1,193 | 8/29/2024 | 
| 1.5.1 | 634 | 7/31/2024 | 
| 1.5.0 | 4,766 | 5/15/2024 | 
| 1.4.0 | 484 | 4/22/2024 | 
| 1.3.0 | 224 | 4/18/2024 | 
| 1.2.0 | 369 | 4/16/2024 | 
| 1.1.4 | 231 | 4/15/2024 | 
| 1.1.3 | 198 | 4/12/2024 | 
| 1.1.2 | 181 | 4/11/2024 | 
| 1.1.1 | 2,716 | 4/10/2024 | 
| 1.1.0 | 195 | 4/9/2024 | 
| 1.0.1 | 424 | 4/1/2024 | 
| 1.0.0 | 213 | 3/30/2024 | 
| 0.9.4 | 420 | 3/29/2024 | 
| 0.9.3 | 325 | 3/28/2024 | 
| 0.9.1 | 305 | 3/26/2024 | 
| 0.9.0 | 319 | 3/23/2024 | 
| 0.8.4 | 312 | 3/21/2024 | 
| 0.8.3 | 352 | 3/20/2024 | 
| 0.8.2 | 323 | 3/20/2024 | 
| 0.8.1 | 331 | 3/20/2024 | 
| 0.8.0 | 333 | 3/20/2024 | 
| 0.7.2 | 170 | 3/18/2024 | 
| 0.7.1 | 164 | 3/18/2024 | 
| 0.7.0 | 194 | 3/15/2024 | 
| 0.6.1 | 662 | 3/11/2024 | 
| 0.6.0 | 199 | 3/11/2024 | 
| 0.5.4 | 216 | 3/7/2024 | 
| 0.5.3 | 230 | 3/7/2024 | 
| 0.5.2 | 181 | 3/6/2024 | 
| 0.5.1 | 182 | 3/5/2024 | 
| 0.5.0 | 261 | 3/5/2024 | 
| 0.4.5 | 301 | 3/3/2024 | 
| 0.4.4 | 199 | 3/1/2024 | 
| 0.4.3 | 197 | 3/1/2024 | 
| 0.4.2 | 196 | 3/1/2024 | 
| 0.4.1 | 200 | 2/29/2024 | 
| 0.3.2 | 187 | 2/29/2024 | 
| 0.3.1 | 199 | 2/29/2024 | 
| 0.2.1 | 246 | 2/29/2024 | 
# Release Notes
## 2.8.16
### Added
- re-add timeout mapping w/o retry (ac8f1ef)
- add parameter `requestOptions` (07c101e)
- add model `gemini-2.5-computer-use-preview-10-2025` (56d892f)
- add `Launch Day` (987b06b)
- add test for `ImageConfig` and aspect ratios (8da4020)
- What The Banana!?! (125ff8f)
### Changed
- Update IChatClient to utilize newer surface area (0377aa1)
- upgrade NuGet packages (20b585b)
## Changelog
Changes across all versions have been documented in the [Changelog](CHANGELOG.md).