diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.BatchesUpdateEmbedContentBatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.BatchesUpdateEmbedContentBatch.g.cs index f49f1de..ae8c8fa 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.BatchesUpdateEmbedContentBatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.BatchesUpdateEmbedContentBatch.g.cs @@ -397,14 +397,11 @@ partial void ProcessBatchesUpdateEmbedContentBatchResponseContent( /// /// /// - /// - /// Required. The user-defined name of this batch. - /// /// /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// Required. The user-defined name of this batch. /// /// /// Configures the input to the batch request. @@ -412,6 +409,9 @@ partial void ProcessBatchesUpdateEmbedContentBatchResponseContent( /// /// Stats about the batch. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// /// /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// @@ -421,22 +421,22 @@ partial void ProcessBatchesUpdateEmbedContentBatchResponseContent( public async global::System.Threading.Tasks.Task BatchesUpdateEmbedContentBatchAsync( string batchesId, string? updateMask = default, - string? displayName = default, global::Google.Gemini.EmbedContentBatchOutput? output = default, - string? model = default, + string? displayName = default, global::Google.Gemini.InputEmbedContentConfig? inputConfig = default, global::Google.Gemini.EmbedContentBatchStats? batchStats = default, + string? model = default, string? priority = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.EmbedContentBatch { - DisplayName = displayName, Output = output, - Model = model, + DisplayName = displayName, InputConfig = inputConfig, BatchStats = batchStats, + Model = model, Priority = priority, }; diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.BatchesUpdateGenerateContentBatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.BatchesUpdateGenerateContentBatch.g.cs index ed49383..3cb1831 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.BatchesUpdateGenerateContentBatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.BatchesUpdateGenerateContentBatch.g.cs @@ -400,21 +400,21 @@ partial void ProcessBatchesUpdateGenerateContentBatchResponseContent( /// /// Required. The user-defined name of this batch. /// - /// - /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// /// /// Configures the input to the batch request. /// /// /// Stats about the batch. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// /// /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// + /// + /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// @@ -422,22 +422,22 @@ partial void ProcessBatchesUpdateGenerateContentBatchResponseContent( string batchesId, string? updateMask = default, string? displayName = default, - global::Google.Gemini.GenerateContentBatchOutput? output = default, - string? model = default, global::Google.Gemini.InputConfig? inputConfig = default, global::Google.Gemini.BatchStats? batchStats = default, + string? model = default, string? priority = default, + global::Google.Gemini.GenerateContentBatchOutput? output = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentBatch { DisplayName = displayName, - Output = output, - Model = model, InputConfig = inputConfig, BatchStats = batchStats, + Model = model, Priority = priority, + Output = output, }; return await BatchesUpdateGenerateContentBatchAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CachedContentsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CachedContentsCreate.g.cs index 43557e6..3713d7b 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CachedContentsCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CachedContentsCreate.g.cs @@ -383,57 +383,57 @@ partial void ProcessCachedContentsCreateResponseContent( /// /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// - /// - /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. - /// /// /// Input only. New TTL for this resource, input only. /// + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// /// /// Optional. Input only. Immutable. The content to cache. /// /// /// Metadata on the usage of the cached content. /// - /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response - /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` /// + /// + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task CachedContentsCreateAsync( string? expireTime = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - string? displayName = default, string? ttl = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.Content? systemInstruction = default, + global::System.Collections.Generic.IList? tools = default, global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - global::System.Collections.Generic.IList? tools = default, string? model = default, + string? displayName = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.CachedContent { ExpireTime = expireTime, - ToolConfig = toolConfig, - DisplayName = displayName, Ttl = ttl, + ToolConfig = toolConfig, SystemInstruction = systemInstruction, + Tools = tools, Contents = contents, UsageMetadata = usageMetadata, - Tools = tools, Model = model, + DisplayName = displayName, }; return await CachedContentsCreateAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CachedContentsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CachedContentsPatch.g.cs index c914da8..44e8d85 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CachedContentsPatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CachedContentsPatch.g.cs @@ -400,30 +400,30 @@ partial void ProcessCachedContentsPatchResponseContent( /// /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// - /// - /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. - /// /// /// Input only. New TTL for this resource, input only. /// + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// /// /// Optional. Input only. Immutable. The content to cache. /// /// /// Metadata on the usage of the cached content. /// - /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response - /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` /// + /// + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// @@ -431,28 +431,28 @@ partial void ProcessCachedContentsPatchResponseContent( string cachedContentsId, string? updateMask = default, string? expireTime = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - string? displayName = default, string? ttl = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.Content? systemInstruction = default, + global::System.Collections.Generic.IList? tools = default, global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - global::System.Collections.Generic.IList? tools = default, string? model = default, + string? displayName = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.CachedContent { ExpireTime = expireTime, - ToolConfig = toolConfig, - DisplayName = displayName, Ttl = ttl, + ToolConfig = toolConfig, SystemInstruction = systemInstruction, + Tools = tools, Contents = contents, UsageMetadata = usageMetadata, - Tools = tools, Model = model, + DisplayName = displayName, }; return await CachedContentsPatchAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicGenerateContent.g.cs index 4478c8a..db16133 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicGenerateContent.g.cs @@ -387,23 +387,17 @@ partial void ProcessDynamicGenerateContentResponseContent( /// Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. - /// /// /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. @@ -411,8 +405,14 @@ partial void ProcessDynamicGenerateContentResponseContent( /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. @@ -422,30 +422,30 @@ partial void ProcessDynamicGenerateContentResponseContent( /// public async global::System.Threading.Tasks.Task DynamicGenerateContentAsync( string dynamicId, - bool? store = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? contents = default, string? cachedContent = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.Content? systemInstruction = default, + bool? store = default, global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Store = store, - SystemInstruction = systemInstruction, - Contents = contents, CachedContent = cachedContent, - Model = model, - Tools = tools, + ToolConfig = toolConfig, + SystemInstruction = systemInstruction, + Store = store, GenerationConfig = generationConfig, ServiceTier = serviceTier, - ToolConfig = toolConfig, + Contents = contents, + Tools = tools, + Model = model, SafetySettings = safetySettings, }; diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicStreamGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicStreamGenerateContent.g.cs index 75b3916..4eb464e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicStreamGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicStreamGenerateContent.g.cs @@ -387,23 +387,17 @@ partial void ProcessDynamicStreamGenerateContentResponseContent( /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. - /// /// /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. @@ -411,8 +405,14 @@ partial void ProcessDynamicStreamGenerateContentResponseContent( /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. @@ -422,30 +422,30 @@ partial void ProcessDynamicStreamGenerateContentResponseContent( /// public async global::System.Threading.Tasks.Task DynamicStreamGenerateContentAsync( string dynamicId, - bool? store = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? contents = default, string? cachedContent = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.Content? systemInstruction = default, + bool? store = default, global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Store = store, - SystemInstruction = systemInstruction, - Contents = contents, CachedContent = cachedContent, - Model = model, - Tools = tools, + ToolConfig = toolConfig, + SystemInstruction = systemInstruction, + Store = store, GenerationConfig = generationConfig, ServiceTier = serviceTier, - ToolConfig = toolConfig, + Contents = contents, + Tools = tools, + Model = model, SafetySettings = safetySettings, }; diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicStreamGenerateContentAsStream.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicStreamGenerateContentAsStream.g.cs index 6695306..939d652 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicStreamGenerateContentAsStream.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicStreamGenerateContentAsStream.g.cs @@ -360,23 +360,17 @@ partial void ProcessDynamicStreamGenerateContentAsStreamResponse( /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. - /// /// /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. @@ -384,8 +378,14 @@ partial void ProcessDynamicStreamGenerateContentAsStreamResponse( /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. @@ -395,30 +395,30 @@ partial void ProcessDynamicStreamGenerateContentAsStreamResponse( /// public async global::System.Collections.Generic.IAsyncEnumerable DynamicStreamGenerateContentAsStreamAsync( string dynamicId, - bool? store = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? contents = default, string? cachedContent = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.Content? systemInstruction = default, + bool? store = default, global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, [global::System.Runtime.CompilerServices.EnumeratorCancellation] global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Store = store, - SystemInstruction = systemInstruction, - Contents = contents, CachedContent = cachedContent, - Model = model, - Tools = tools, + ToolConfig = toolConfig, + SystemInstruction = systemInstruction, + Store = store, GenerationConfig = generationConfig, ServiceTier = serviceTier, - ToolConfig = toolConfig, + Contents = contents, + Tools = tools, + Model = model, SafetySettings = safetySettings, }; diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresImportFile.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresImportFile.g.cs index e30d395..5324eaa 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresImportFile.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresImportFile.g.cs @@ -387,31 +387,31 @@ partial void ProcessFileSearchStoresImportFileResponseContent( /// Imports a `File` from File Service to a `FileSearchStore`. /// /// - /// - /// Custom metadata to be associated with the file. - /// /// /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto /// /// /// Required. The name of the `File` to import. Example: `files/abc-123` /// + /// + /// Custom metadata to be associated with the file. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task FileSearchStoresImportFileAsync( string fileSearchStoresId, - global::System.Collections.Generic.IList? customMetadata = default, global::Google.Gemini.ChunkingConfig? chunkingConfig = default, string? fileName = default, + global::System.Collections.Generic.IList? customMetadata = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.ImportFileRequest { - CustomMetadata = customMetadata, ChunkingConfig = chunkingConfig, FileName = fileName, + CustomMetadata = customMetadata, }; return await FileSearchStoresImportFileAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.MediaUploadToFileSearchStore.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.MediaUploadToFileSearchStore.g.cs index 6390481..6ee3f99 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.MediaUploadToFileSearchStore.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.MediaUploadToFileSearchStore.g.cs @@ -387,36 +387,36 @@ partial void ProcessMediaUploadToFileSearchStoreResponseContent( /// Uploads data to a FileSearchStore, preprocesses and chunks before storing it in a FileSearchStore Document. /// /// + /// + /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto + /// /// /// Optional. Display name of the created document. /// - /// - /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. - /// /// /// Custom metadata to be associated with the data. /// - /// - /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto + /// + /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task MediaUploadToFileSearchStoreAsync( string fileSearchStoresId, + global::Google.Gemini.ChunkingConfig? chunkingConfig = default, string? displayName = default, - string? mimeType = default, global::System.Collections.Generic.IList? customMetadata = default, - global::Google.Gemini.ChunkingConfig? chunkingConfig = default, + string? mimeType = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.UploadToFileSearchStoreRequest { + ChunkingConfig = chunkingConfig, DisplayName = displayName, - MimeType = mimeType, CustomMetadata = customMetadata, - ChunkingConfig = chunkingConfig, + MimeType = mimeType, }; return await MediaUploadToFileSearchStoreAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsEmbedContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsEmbedContent.g.cs index 35f9c14..a11104c 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsEmbedContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsEmbedContent.g.cs @@ -387,18 +387,18 @@ partial void ProcessModelsEmbedContentResponseContent( /// Generates a text embedding vector from the input `Content` using the specified [Gemini Embedding model](https://ai.google.dev/gemini-api/docs/models/gemini#text-embedding). /// /// - /// - /// Optional. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`). - /// - /// - /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` - /// /// /// Optional. Optional reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. Supported by newer models since 2024 only. You cannot set this value if using the earlier model (`models/embedding-001`). /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// + /// + /// Optional. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`). + /// + /// + /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` + /// /// /// Optional. An optional title for the text. Only applicable when TaskType is `RETRIEVAL_DOCUMENT`. Note: Specifying a `title` for `RETRIEVAL_DOCUMENT` provides better quality embeddings for retrieval. /// @@ -407,20 +407,20 @@ partial void ProcessModelsEmbedContentResponseContent( /// public async global::System.Threading.Tasks.Task ModelsEmbedContentAsync( string modelsId, - global::Google.Gemini.EmbedContentRequestTaskType? taskType = default, - string? model = default, int? outputDimensionality = default, global::Google.Gemini.Content? content = default, + global::Google.Gemini.EmbedContentRequestTaskType? taskType = default, + string? model = default, string? title = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.EmbedContentRequest { - TaskType = taskType, - Model = model, OutputDimensionality = outputDimensionality, Content = content, + TaskType = taskType, + Model = model, Title = title, }; diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsGenerateContent.g.cs index 3ebec30..018aeef 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsGenerateContent.g.cs @@ -387,23 +387,17 @@ partial void ProcessModelsGenerateContentResponseContent( /// Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. - /// /// /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. @@ -411,8 +405,14 @@ partial void ProcessModelsGenerateContentResponseContent( /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. @@ -422,30 +422,30 @@ partial void ProcessModelsGenerateContentResponseContent( /// public async global::System.Threading.Tasks.Task ModelsGenerateContentAsync( string modelsId, - bool? store = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? contents = default, string? cachedContent = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.Content? systemInstruction = default, + bool? store = default, global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Store = store, - SystemInstruction = systemInstruction, - Contents = contents, CachedContent = cachedContent, - Model = model, - Tools = tools, + ToolConfig = toolConfig, + SystemInstruction = systemInstruction, + Store = store, GenerationConfig = generationConfig, ServiceTier = serviceTier, - ToolConfig = toolConfig, + Contents = contents, + Tools = tools, + Model = model, SafetySettings = safetySettings, }; diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsStreamGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsStreamGenerateContent.g.cs index c2be354..ecb79af 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsStreamGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsStreamGenerateContent.g.cs @@ -387,23 +387,17 @@ partial void ProcessModelsStreamGenerateContentResponseContent( /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. - /// /// /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. @@ -411,8 +405,14 @@ partial void ProcessModelsStreamGenerateContentResponseContent( /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. @@ -422,30 +422,30 @@ partial void ProcessModelsStreamGenerateContentResponseContent( /// public async global::System.Threading.Tasks.Task ModelsStreamGenerateContentAsync( string modelsId, - bool? store = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? contents = default, string? cachedContent = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.Content? systemInstruction = default, + bool? store = default, global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Store = store, - SystemInstruction = systemInstruction, - Contents = contents, CachedContent = cachedContent, - Model = model, - Tools = tools, + ToolConfig = toolConfig, + SystemInstruction = systemInstruction, + Store = store, GenerationConfig = generationConfig, ServiceTier = serviceTier, - ToolConfig = toolConfig, + Contents = contents, + Tools = tools, + Model = model, SafetySettings = safetySettings, }; diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsStreamGenerateContentAsStream.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsStreamGenerateContentAsStream.g.cs index c095ea5..06ba66b 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsStreamGenerateContentAsStream.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsStreamGenerateContentAsStream.g.cs @@ -360,23 +360,17 @@ partial void ProcessModelsStreamGenerateContentAsStreamResponse( /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. - /// /// /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. @@ -384,8 +378,14 @@ partial void ProcessModelsStreamGenerateContentAsStreamResponse( /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. @@ -395,30 +395,30 @@ partial void ProcessModelsStreamGenerateContentAsStreamResponse( /// public async global::System.Collections.Generic.IAsyncEnumerable ModelsStreamGenerateContentAsStreamAsync( string modelsId, - bool? store = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? contents = default, string? cachedContent = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.Content? systemInstruction = default, + bool? store = default, global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, [global::System.Runtime.CompilerServices.EnumeratorCancellation] global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Store = store, - SystemInstruction = systemInstruction, - Contents = contents, CachedContent = cachedContent, - Model = model, - Tools = tools, + ToolConfig = toolConfig, + SystemInstruction = systemInstruction, + Store = store, GenerationConfig = generationConfig, ServiceTier = serviceTier, - ToolConfig = toolConfig, + Contents = contents, + Tools = tools, + Model = model, SafetySettings = safetySettings, }; diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsCreate.g.cs index 4399fc8..6e400b0 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsCreate.g.cs @@ -390,6 +390,12 @@ partial void ProcessTunedModelsCreateResponseContent( /// Creates a tuned model. Check intermediate tuning progress (if any) through the [google.longrunning.Operations] service. Access status and results through the Operations service. Example: GET /v1/tunedModels/az2mb0bpw6i/operations/000-111-222 /// /// + /// + /// Optional. List of project numbers that have read access to the tuned model. + /// + /// + /// Tuning tasks that create tuned models. + /// /// /// Tuned model as a source for training a new model. /// @@ -399,52 +405,46 @@ partial void ProcessTunedModelsCreateResponseContent( /// /// Optional. A short description of this model. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. - /// - /// - /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. - /// /// /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Tuning tasks that create tuned models. + /// + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// /// /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. + /// + /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task TunedModelsCreateAsync( string? tunedModelId = default, + global::System.Collections.Generic.IList? readerProjectNumbers = default, + global::Google.Gemini.TuningTask? tuningTask = default, global::Google.Gemini.TunedModelSource? tunedModelSource = default, string? baseModel = default, string? description = default, - global::System.Collections.Generic.IList? readerProjectNumbers = default, - float? temperature = default, float? topP = default, - global::Google.Gemini.TuningTask? tuningTask = default, - int? topK = default, string? displayName = default, + int? topK = default, + float? temperature = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.TunedModel { + ReaderProjectNumbers = readerProjectNumbers, + TuningTask = tuningTask, TunedModelSource = tunedModelSource, BaseModel = baseModel, Description = description, - ReaderProjectNumbers = readerProjectNumbers, - Temperature = temperature, TopP = topP, - TuningTask = tuningTask, - TopK = topK, DisplayName = displayName, + TopK = topK, + Temperature = temperature, }; return await TunedModelsCreateAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsGenerateContent.g.cs index 728654c..acf7c5d 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsGenerateContent.g.cs @@ -387,23 +387,17 @@ partial void ProcessTunedModelsGenerateContentResponseContent( /// Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. - /// /// /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. @@ -411,8 +405,14 @@ partial void ProcessTunedModelsGenerateContentResponseContent( /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. @@ -422,30 +422,30 @@ partial void ProcessTunedModelsGenerateContentResponseContent( /// public async global::System.Threading.Tasks.Task TunedModelsGenerateContentAsync( string tunedModelsId, - bool? store = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? contents = default, string? cachedContent = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.Content? systemInstruction = default, + bool? store = default, global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Store = store, - SystemInstruction = systemInstruction, - Contents = contents, CachedContent = cachedContent, - Model = model, - Tools = tools, + ToolConfig = toolConfig, + SystemInstruction = systemInstruction, + Store = store, GenerationConfig = generationConfig, ServiceTier = serviceTier, - ToolConfig = toolConfig, + Contents = contents, + Tools = tools, + Model = model, SafetySettings = safetySettings, }; diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPatch.g.cs index f1f0156..28e96f6 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPatch.g.cs @@ -397,6 +397,12 @@ partial void ProcessTunedModelsPatchResponseContent( /// /// /// + /// + /// Optional. List of project numbers that have read access to the tuned model. + /// + /// + /// Tuning tasks that create tuned models. + /// /// /// Tuned model as a source for training a new model. /// @@ -406,23 +412,17 @@ partial void ProcessTunedModelsPatchResponseContent( /// /// Optional. A short description of this model. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. - /// - /// - /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. - /// /// /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Tuning tasks that create tuned models. + /// + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// /// /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. + /// + /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -430,29 +430,29 @@ partial void ProcessTunedModelsPatchResponseContent( public async global::System.Threading.Tasks.Task TunedModelsPatchAsync( string tunedModelsId, string? updateMask = default, + global::System.Collections.Generic.IList? readerProjectNumbers = default, + global::Google.Gemini.TuningTask? tuningTask = default, global::Google.Gemini.TunedModelSource? tunedModelSource = default, string? baseModel = default, string? description = default, - global::System.Collections.Generic.IList? readerProjectNumbers = default, - float? temperature = default, float? topP = default, - global::Google.Gemini.TuningTask? tuningTask = default, - int? topK = default, string? displayName = default, + int? topK = default, + float? temperature = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.TunedModel { + ReaderProjectNumbers = readerProjectNumbers, + TuningTask = tuningTask, TunedModelSource = tunedModelSource, BaseModel = baseModel, Description = description, - ReaderProjectNumbers = readerProjectNumbers, - Temperature = temperature, TopP = topP, - TuningTask = tuningTask, - TopK = topK, DisplayName = displayName, + TopK = topK, + Temperature = temperature, }; return await TunedModelsPatchAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsStreamGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsStreamGenerateContent.g.cs index bd3b5b9..1040cea 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsStreamGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsStreamGenerateContent.g.cs @@ -387,23 +387,17 @@ partial void ProcessTunedModelsStreamGenerateContentResponseContent( /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. - /// /// /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. @@ -411,8 +405,14 @@ partial void ProcessTunedModelsStreamGenerateContentResponseContent( /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. @@ -422,30 +422,30 @@ partial void ProcessTunedModelsStreamGenerateContentResponseContent( /// public async global::System.Threading.Tasks.Task TunedModelsStreamGenerateContentAsync( string tunedModelsId, - bool? store = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? contents = default, string? cachedContent = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.Content? systemInstruction = default, + bool? store = default, global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Store = store, - SystemInstruction = systemInstruction, - Contents = contents, CachedContent = cachedContent, - Model = model, - Tools = tools, + ToolConfig = toolConfig, + SystemInstruction = systemInstruction, + Store = store, GenerationConfig = generationConfig, ServiceTier = serviceTier, - ToolConfig = toolConfig, + Contents = contents, + Tools = tools, + Model = model, SafetySettings = safetySettings, }; diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsStreamGenerateContentAsStream.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsStreamGenerateContentAsStream.g.cs index 9f7fefc..b64c9f6 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsStreamGenerateContentAsStream.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsStreamGenerateContentAsStream.g.cs @@ -360,23 +360,17 @@ partial void ProcessTunedModelsStreamGenerateContentAsStreamResponse( /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. - /// /// /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. @@ -384,8 +378,14 @@ partial void ProcessTunedModelsStreamGenerateContentAsStreamResponse( /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. @@ -395,30 +395,30 @@ partial void ProcessTunedModelsStreamGenerateContentAsStreamResponse( /// public async global::System.Collections.Generic.IAsyncEnumerable TunedModelsStreamGenerateContentAsStreamAsync( string tunedModelsId, - bool? store = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? contents = default, string? cachedContent = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.Content? systemInstruction = default, + bool? store = default, global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, [global::System.Runtime.CompilerServices.EnumeratorCancellation] global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Store = store, - SystemInstruction = systemInstruction, - Contents = contents, CachedContent = cachedContent, - Model = model, - Tools = tools, + ToolConfig = toolConfig, + SystemInstruction = systemInstruction, + Store = store, GenerationConfig = generationConfig, ServiceTier = serviceTier, - ToolConfig = toolConfig, + Contents = contents, + Tools = tools, + Model = model, SafetySettings = safetySettings, }; diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.BatchesUpdateEmbedContentBatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.BatchesUpdateEmbedContentBatch.g.cs index ea2b593..ac4915a 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.BatchesUpdateEmbedContentBatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.BatchesUpdateEmbedContentBatch.g.cs @@ -25,14 +25,11 @@ public partial interface IGeminiClient /// /// /// - /// - /// Required. The user-defined name of this batch. - /// /// /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// Required. The user-defined name of this batch. /// /// /// Configures the input to the batch request. @@ -40,6 +37,9 @@ public partial interface IGeminiClient /// /// Stats about the batch. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// /// /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// @@ -49,11 +49,11 @@ public partial interface IGeminiClient global::System.Threading.Tasks.Task BatchesUpdateEmbedContentBatchAsync( string batchesId, string? updateMask = default, - string? displayName = default, global::Google.Gemini.EmbedContentBatchOutput? output = default, - string? model = default, + string? displayName = default, global::Google.Gemini.InputEmbedContentConfig? inputConfig = default, global::Google.Gemini.EmbedContentBatchStats? batchStats = default, + string? model = default, string? priority = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.BatchesUpdateGenerateContentBatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.BatchesUpdateGenerateContentBatch.g.cs index 8baafde..60a3559 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.BatchesUpdateGenerateContentBatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.BatchesUpdateGenerateContentBatch.g.cs @@ -28,21 +28,21 @@ public partial interface IGeminiClient /// /// Required. The user-defined name of this batch. /// - /// - /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// /// /// Configures the input to the batch request. /// /// /// Stats about the batch. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// /// /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// + /// + /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// @@ -50,11 +50,11 @@ public partial interface IGeminiClient string batchesId, string? updateMask = default, string? displayName = default, - global::Google.Gemini.GenerateContentBatchOutput? output = default, - string? model = default, global::Google.Gemini.InputConfig? inputConfig = default, global::Google.Gemini.BatchStats? batchStats = default, + string? model = default, string? priority = default, + global::Google.Gemini.GenerateContentBatchOutput? output = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsCreate.g.cs index d06e657..b795375 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsCreate.g.cs @@ -22,43 +22,43 @@ public partial interface IGeminiClient /// /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// - /// - /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. - /// /// /// Input only. New TTL for this resource, input only. /// + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// /// /// Optional. Input only. Immutable. The content to cache. /// /// /// Metadata on the usage of the cached content. /// - /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response - /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` /// + /// + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task CachedContentsCreateAsync( string? expireTime = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - string? displayName = default, string? ttl = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.Content? systemInstruction = default, + global::System.Collections.Generic.IList? tools = default, global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - global::System.Collections.Generic.IList? tools = default, string? model = default, + string? displayName = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsPatch.g.cs index 40747b3..8b2d94b 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsPatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsPatch.g.cs @@ -28,30 +28,30 @@ public partial interface IGeminiClient /// /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// - /// - /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. - /// /// /// Input only. New TTL for this resource, input only. /// + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// /// /// Optional. Input only. Immutable. The content to cache. /// /// /// Metadata on the usage of the cached content. /// - /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response - /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` /// + /// + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// @@ -59,14 +59,14 @@ public partial interface IGeminiClient string cachedContentsId, string? updateMask = default, string? expireTime = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - string? displayName = default, string? ttl = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.Content? systemInstruction = default, + global::System.Collections.Generic.IList? tools = default, global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - global::System.Collections.Generic.IList? tools = default, string? model = default, + string? displayName = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicGenerateContent.g.cs index ae39bed..79989ea 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicGenerateContent.g.cs @@ -22,23 +22,17 @@ public partial interface IGeminiClient /// Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. - /// /// /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. @@ -46,8 +40,14 @@ public partial interface IGeminiClient /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. @@ -57,15 +57,15 @@ public partial interface IGeminiClient /// global::System.Threading.Tasks.Task DynamicGenerateContentAsync( string dynamicId, - bool? store = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? contents = default, string? cachedContent = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.Content? systemInstruction = default, + bool? store = default, global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContent.g.cs index 5acb438..5c0bc61 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContent.g.cs @@ -22,23 +22,17 @@ public partial interface IGeminiClient /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. - /// /// /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. @@ -46,8 +40,14 @@ public partial interface IGeminiClient /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. @@ -57,15 +57,15 @@ public partial interface IGeminiClient /// global::System.Threading.Tasks.Task DynamicStreamGenerateContentAsync( string dynamicId, - bool? store = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? contents = default, string? cachedContent = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.Content? systemInstruction = default, + bool? store = default, global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContentAsStream.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContentAsStream.g.cs index 52eb9ef..4a3e4a5 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContentAsStream.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContentAsStream.g.cs @@ -22,23 +22,17 @@ public partial interface IGeminiClient /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. - /// /// /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. @@ -46,8 +40,14 @@ public partial interface IGeminiClient /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. @@ -57,15 +57,15 @@ public partial interface IGeminiClient /// global::System.Collections.Generic.IAsyncEnumerable DynamicStreamGenerateContentAsStreamAsync( string dynamicId, - bool? store = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? contents = default, string? cachedContent = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.Content? systemInstruction = default, + bool? store = default, global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresImportFile.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresImportFile.g.cs index 5a2b2d7..1f5210d 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresImportFile.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresImportFile.g.cs @@ -22,23 +22,23 @@ public partial interface IGeminiClient /// Imports a `File` from File Service to a `FileSearchStore`. /// /// - /// - /// Custom metadata to be associated with the file. - /// /// /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto /// /// /// Required. The name of the `File` to import. Example: `files/abc-123` /// + /// + /// Custom metadata to be associated with the file. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task FileSearchStoresImportFileAsync( string fileSearchStoresId, - global::System.Collections.Generic.IList? customMetadata = default, global::Google.Gemini.ChunkingConfig? chunkingConfig = default, string? fileName = default, + global::System.Collections.Generic.IList? customMetadata = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.MediaUploadToFileSearchStore.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.MediaUploadToFileSearchStore.g.cs index 2a47541..370910e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.MediaUploadToFileSearchStore.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.MediaUploadToFileSearchStore.g.cs @@ -22,27 +22,27 @@ public partial interface IGeminiClient /// Uploads data to a FileSearchStore, preprocesses and chunks before storing it in a FileSearchStore Document. /// /// + /// + /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto + /// /// /// Optional. Display name of the created document. /// - /// - /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. - /// /// /// Custom metadata to be associated with the data. /// - /// - /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto + /// + /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task MediaUploadToFileSearchStoreAsync( string fileSearchStoresId, + global::Google.Gemini.ChunkingConfig? chunkingConfig = default, string? displayName = default, - string? mimeType = default, global::System.Collections.Generic.IList? customMetadata = default, - global::Google.Gemini.ChunkingConfig? chunkingConfig = default, + string? mimeType = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsEmbedContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsEmbedContent.g.cs index fcd07ed..f452a13 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsEmbedContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsEmbedContent.g.cs @@ -22,18 +22,18 @@ public partial interface IGeminiClient /// Generates a text embedding vector from the input `Content` using the specified [Gemini Embedding model](https://ai.google.dev/gemini-api/docs/models/gemini#text-embedding). /// /// - /// - /// Optional. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`). - /// - /// - /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` - /// /// /// Optional. Optional reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. Supported by newer models since 2024 only. You cannot set this value if using the earlier model (`models/embedding-001`). /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// + /// + /// Optional. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`). + /// + /// + /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` + /// /// /// Optional. An optional title for the text. Only applicable when TaskType is `RETRIEVAL_DOCUMENT`. Note: Specifying a `title` for `RETRIEVAL_DOCUMENT` provides better quality embeddings for retrieval. /// @@ -42,10 +42,10 @@ public partial interface IGeminiClient /// global::System.Threading.Tasks.Task ModelsEmbedContentAsync( string modelsId, - global::Google.Gemini.EmbedContentRequestTaskType? taskType = default, - string? model = default, int? outputDimensionality = default, global::Google.Gemini.Content? content = default, + global::Google.Gemini.EmbedContentRequestTaskType? taskType = default, + string? model = default, string? title = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsGenerateContent.g.cs index cb1362f..db93bfc 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsGenerateContent.g.cs @@ -22,23 +22,17 @@ public partial interface IGeminiClient /// Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. - /// /// /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. @@ -46,8 +40,14 @@ public partial interface IGeminiClient /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. @@ -57,15 +57,15 @@ public partial interface IGeminiClient /// global::System.Threading.Tasks.Task ModelsGenerateContentAsync( string modelsId, - bool? store = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? contents = default, string? cachedContent = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.Content? systemInstruction = default, + bool? store = default, global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContent.g.cs index 5d51b32..e212568 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContent.g.cs @@ -22,23 +22,17 @@ public partial interface IGeminiClient /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. - /// /// /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. @@ -46,8 +40,14 @@ public partial interface IGeminiClient /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. @@ -57,15 +57,15 @@ public partial interface IGeminiClient /// global::System.Threading.Tasks.Task ModelsStreamGenerateContentAsync( string modelsId, - bool? store = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? contents = default, string? cachedContent = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.Content? systemInstruction = default, + bool? store = default, global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContentAsStream.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContentAsStream.g.cs index 7898c79..537c8cf 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContentAsStream.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContentAsStream.g.cs @@ -22,23 +22,17 @@ public partial interface IGeminiClient /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. - /// /// /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. @@ -46,8 +40,14 @@ public partial interface IGeminiClient /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. @@ -57,15 +57,15 @@ public partial interface IGeminiClient /// global::System.Collections.Generic.IAsyncEnumerable ModelsStreamGenerateContentAsStreamAsync( string modelsId, - bool? store = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? contents = default, string? cachedContent = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.Content? systemInstruction = default, + bool? store = default, global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsCreate.g.cs index 4a25ab6..c88b52d 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsCreate.g.cs @@ -22,6 +22,12 @@ public partial interface IGeminiClient /// Creates a tuned model. Check intermediate tuning progress (if any) through the [google.longrunning.Operations] service. Access status and results through the Operations service. Example: GET /v1/tunedModels/az2mb0bpw6i/operations/000-111-222 /// /// + /// + /// Optional. List of project numbers that have read access to the tuned model. + /// + /// + /// Tuning tasks that create tuned models. + /// /// /// Tuned model as a source for training a new model. /// @@ -31,38 +37,32 @@ public partial interface IGeminiClient /// /// Optional. A short description of this model. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. - /// - /// - /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. - /// /// /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Tuning tasks that create tuned models. + /// + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// /// /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. + /// + /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task TunedModelsCreateAsync( string? tunedModelId = default, + global::System.Collections.Generic.IList? readerProjectNumbers = default, + global::Google.Gemini.TuningTask? tuningTask = default, global::Google.Gemini.TunedModelSource? tunedModelSource = default, string? baseModel = default, string? description = default, - global::System.Collections.Generic.IList? readerProjectNumbers = default, - float? temperature = default, float? topP = default, - global::Google.Gemini.TuningTask? tuningTask = default, - int? topK = default, string? displayName = default, + int? topK = default, + float? temperature = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsGenerateContent.g.cs index d8e9b9b..7563b5c 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsGenerateContent.g.cs @@ -22,23 +22,17 @@ public partial interface IGeminiClient /// Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. - /// /// /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. @@ -46,8 +40,14 @@ public partial interface IGeminiClient /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. @@ -57,15 +57,15 @@ public partial interface IGeminiClient /// global::System.Threading.Tasks.Task TunedModelsGenerateContentAsync( string tunedModelsId, - bool? store = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? contents = default, string? cachedContent = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.Content? systemInstruction = default, + bool? store = default, global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPatch.g.cs index d2f963f..e9cfe7d 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPatch.g.cs @@ -25,6 +25,12 @@ public partial interface IGeminiClient /// /// /// + /// + /// Optional. List of project numbers that have read access to the tuned model. + /// + /// + /// Tuning tasks that create tuned models. + /// /// /// Tuned model as a source for training a new model. /// @@ -34,23 +40,17 @@ public partial interface IGeminiClient /// /// Optional. A short description of this model. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. - /// - /// - /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. - /// /// /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Tuning tasks that create tuned models. + /// + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// /// /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. + /// + /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -58,15 +58,15 @@ public partial interface IGeminiClient global::System.Threading.Tasks.Task TunedModelsPatchAsync( string tunedModelsId, string? updateMask = default, + global::System.Collections.Generic.IList? readerProjectNumbers = default, + global::Google.Gemini.TuningTask? tuningTask = default, global::Google.Gemini.TunedModelSource? tunedModelSource = default, string? baseModel = default, string? description = default, - global::System.Collections.Generic.IList? readerProjectNumbers = default, - float? temperature = default, float? topP = default, - global::Google.Gemini.TuningTask? tuningTask = default, - int? topK = default, string? displayName = default, + int? topK = default, + float? temperature = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContent.g.cs index 6640190..a33bd0e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContent.g.cs @@ -22,23 +22,17 @@ public partial interface IGeminiClient /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. - /// /// /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. @@ -46,8 +40,14 @@ public partial interface IGeminiClient /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. @@ -57,15 +57,15 @@ public partial interface IGeminiClient /// global::System.Threading.Tasks.Task TunedModelsStreamGenerateContentAsync( string tunedModelsId, - bool? store = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? contents = default, string? cachedContent = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.Content? systemInstruction = default, + bool? store = default, global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContentAsStream.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContentAsStream.g.cs index fba4682..920dce7 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContentAsStream.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContentAsStream.g.cs @@ -22,23 +22,17 @@ public partial interface IGeminiClient /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. - /// /// /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. @@ -46,8 +40,14 @@ public partial interface IGeminiClient /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. @@ -57,15 +57,15 @@ public partial interface IGeminiClient /// global::System.Collections.Generic.IAsyncEnumerable TunedModelsStreamGenerateContentAsStreamAsync( string tunedModelsId, - bool? store = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? contents = default, string? cachedContent = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.Content? systemInstruction = default, + bool? store = default, global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContext.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContext.g.cs index ad4db1c..d4cb160 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContext.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContext.g.cs @@ -13,57 +13,45 @@ namespace Google.Gemini DefaultIgnoreCondition = global::System.Text.Json.Serialization.JsonIgnoreCondition.WhenWritingNull, Converters = new global::System.Type[] { - typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelNullableJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusJsonConverter), + typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DocumentStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DocumentStateNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorJsonConverter), typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeNullableJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.DocumentStateJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.DocumentStateNullableJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.SchemaTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SchemaTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.TunedModelStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierJsonConverter), - typeof(global::Google.Gemini.JsonConverters.TunedModelStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonJsonConverter), - typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityJsonConverter), @@ -73,359 +61,371 @@ namespace Google.Gemini typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PermissionRoleJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PermissionRoleNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileSourceJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileSourceNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonJsonConverter), + typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusJsonConverter), - typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.TunedModelStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.TunedModelStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileSourceJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileSourceNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionRoleJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionRoleNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeNullableJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateNullableJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelNullableJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.SchemaTypeJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.SchemaTypeNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.UnixTimestampJsonConverter), })] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.JsonSerializerContextTypes))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Part))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Blob))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCall))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(byte[]))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(string))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileData))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VideoMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCode))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(object))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCall))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResult))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(bool))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Image))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListFilesResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.File))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchGenerateContentRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListTunedModelsResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModel))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ThinkingConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(int))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ThinkingConfigThinkingLevel), TypeInfoPropertyName = "ThinkingConfigThinkingLevel2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CitationMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CitationSource))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AsyncBatchEmbedContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(string))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResultOutcome), TypeInfoPropertyName = "CodeExecutionResultOutcome2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatch))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchOutput))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchState), TypeInfoPropertyName = "EmbedContentBatchState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InputEmbedContentConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchStats))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.WhiteSpaceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(int))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentResponses))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Tool))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionDeclaration))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecution))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUse))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlContext))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.McpServer))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleSearchRetrieval))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleMaps))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListDocumentsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Document))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListFilesResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.File))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CustomMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DocumentState), TypeInfoPropertyName = "DocumentState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Empty))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CountTokensResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModalityTokenCount))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LogprobsResult))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(float))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LogprobsResultCandidate))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TopCandidates))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Interval))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SearchTypes))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Maps))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PlaceAnswerSources))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlMetadataUrlRetrievalStatus), TypeInfoPropertyName = "UrlMetadataUrlRetrievalStatus2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedResponses))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Model))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(float))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.StreamableHttpTransport))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(bool))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.Dictionary))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(object))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Schema))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfigMediaResolution), TypeInfoPropertyName = "GenerationConfigMediaResolution2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfigResponseModalitie), TypeInfoPropertyName = "GenerationConfigResponseModalitie2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SpeechConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecution))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.MultiSpeakerVoiceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SpeakerVoiceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.WebSearch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageSearch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SearchEntryPoint))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionDeclaration))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionDeclarationBehavior), TypeInfoPropertyName = "FunctionDeclarationBehavior2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievedContext))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkCustomMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunk))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Web))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Maps))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Image))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlContextMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlMetadata))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Operation))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Status))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GeneratedFile))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GeneratedFileState), TypeInfoPropertyName = "GeneratedFileState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponsePart))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponseScheduling), TypeInfoPropertyName = "FunctionResponseScheduling2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SearchEntryPoint))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievalMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CachedContent))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Content))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CachedContentUsageMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Tool))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CountTokensRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchStats))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunk))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievalMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlContext))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCallingConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCallingConfigMode), TypeInfoPropertyName = "FunctionCallingConfigMode2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Document))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CustomMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DocumentState), TypeInfoPropertyName = "DocumentState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListOperationsResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchEmbedContentsRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchEmbedContentsResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ContentEmbedding))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbeddingUsageMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchGenerateContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VideoMetadata))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(double))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SchemaType), TypeInfoPropertyName = "SchemaType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.Dictionary))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentResponse))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UsageMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatus))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedback))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Candidate))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedback))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponsePart))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponseBlob))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListModelsResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListCorporaResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Corpus))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImportFileRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ChunkingConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatusModelStage), TypeInfoPropertyName = "ModelStatusModelStage2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GeneratedFile))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GeneratedFileState), TypeInfoPropertyName = "GeneratedFileState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatchOutput))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatchState), TypeInfoPropertyName = "GenerateContentBatchState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InputConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatus))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetySetting))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetySettingThreshold), TypeInfoPropertyName = "SafetySettingThreshold2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetySettingCategory), TypeInfoPropertyName = "SafetySettingCategory2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Content))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentRequestServiceTier), TypeInfoPropertyName = "GenerateContentRequestServiceTier2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCallingConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievalConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedRequest))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListFileSearchStoresResponse))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSearchStore))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TopCandidates))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LogprobsResultCandidate))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ReviewSnippet))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SemanticRetrieverChunk))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Web))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkCustomMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkStringList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingAttribution))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AttributionSourceId))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CustomLongRunningOperation))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PrebuiltVoiceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlContextMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModelSource))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModelState), TypeInfoPropertyName = "TunedModelState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningTask))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedRequests))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningExample))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResultOutcome), TypeInfoPropertyName = "CodeExecutionResultOutcome2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LogprobsResult))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.WhiteSpaceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponseBlob))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedbackBlockReason), TypeInfoPropertyName = "PromptFeedbackBlockReason2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetyRating))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileData))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PrebuiltVoiceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListCachedContentsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CachedContent))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetyRatingProbability), TypeInfoPropertyName = "SafetyRatingProbability2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetyRatingCategory), TypeInfoPropertyName = "SafetyRatingCategory2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Hyperparameters))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.StreamableHttpTransport))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.Dictionary))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievalConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.McpServer))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingPassageId))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchEmbedContentsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbeddingUsageMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ContentEmbedding))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VideoFileMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCall))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCallToolType), TypeInfoPropertyName = "ToolCallToolType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DynamicRetrievalConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UploadToFileSearchStoreRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ChunkingConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PlaceAnswerSources))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ReviewSnippet))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Model))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListPermissionsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Permission))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Dataset))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningExamples))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponseScheduling), TypeInfoPropertyName = "FunctionResponseScheduling2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetySetting))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetySettingThreshold), TypeInfoPropertyName = "SafetySettingThreshold2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetySettingCategory), TypeInfoPropertyName = "SafetySettingCategory2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CitationSource))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Part))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Blob))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCall))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCode))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(byte[]))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PermissionGranteeType), TypeInfoPropertyName = "PermissionGranteeType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PermissionRole), TypeInfoPropertyName = "PermissionRole2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SpeechConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VoiceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.MultiSpeakerVoiceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileState), TypeInfoPropertyName = "FileState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSource), TypeInfoPropertyName = "FileSource2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CachedContentUsageMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningTask))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningSnapshot))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Hyperparameters))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchEmbedContentsRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImportFileRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlMetadataUrlRetrievalStatus), TypeInfoPropertyName = "UrlMetadataUrlRetrievalStatus2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.WebSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchStats))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModel))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModelSource))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModelState), TypeInfoPropertyName = "TunedModelState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DynamicRetrievalConfigMode), TypeInfoPropertyName = "DynamicRetrievalConfigMode2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListTunedModelsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatusModelStage), TypeInfoPropertyName = "ModelStatusModelStage2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponseToolType), TypeInfoPropertyName = "ToolResponseToolType2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentRequests))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LatLng))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CustomLongRunningOperation))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SpeakerVoiceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AsyncBatchEmbedContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfigResponseModalitie), TypeInfoPropertyName = "GenerationConfigResponseModalitie2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ThinkingConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfigMediaResolution), TypeInfoPropertyName = "GenerationConfigMediaResolution2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AttributionSourceId))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingPassageId))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SemanticRetrieverChunk))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCallingConfigMode), TypeInfoPropertyName = "FunctionCallingConfigMode2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CountTokensRequest))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCodeLanguage), TypeInfoPropertyName = "ExecutableCodeLanguage2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUseEnvironment), TypeInfoPropertyName = "ComputerUseEnvironment2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VoiceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListCachedContentsResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListDocumentsResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CandidateFinishReason), TypeInfoPropertyName = "CandidateFinishReason2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentRequestTaskType), TypeInfoPropertyName = "EmbedContentRequestTaskType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentRequestServiceTier), TypeInfoPropertyName = "GenerateContentRequestServiceTier2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LatLng))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModalityTokenCount))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingAttribution))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CitationMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CandidateFinishReason), TypeInfoPropertyName = "CandidateFinishReason2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedResponses))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListModelsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUseEnvironment), TypeInfoPropertyName = "ComputerUseEnvironment2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModalityTokenCountModality), TypeInfoPropertyName = "ModalityTokenCountModality2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Dataset))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningSnapshot))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleSearchRetrieval))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DynamicRetrievalConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VideoFileMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSource), TypeInfoPropertyName = "FileSource2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileState), TypeInfoPropertyName = "FileState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleMaps))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSearch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentRequestTaskType), TypeInfoPropertyName = "EmbedContentRequestTaskType2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.StringList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCallToolType), TypeInfoPropertyName = "ToolCallToolType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DynamicRetrievalConfigMode), TypeInfoPropertyName = "DynamicRetrievalConfigMode2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchStats))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CountTokensResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponseToolType), TypeInfoPropertyName = "ToolResponseToolType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InputEmbedContentConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Corpus))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListOperationsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InputConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatchState), TypeInfoPropertyName = "GenerateContentBatchState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatchOutput))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListGeneratedFilesResponse))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Permission))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PermissionGranteeType), TypeInfoPropertyName = "PermissionGranteeType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PermissionRole), TypeInfoPropertyName = "PermissionRole2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UploadToFileSearchStoreRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedbackBlockReason), TypeInfoPropertyName = "PromptFeedbackBlockReason2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Empty))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListPermissionsResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchState), TypeInfoPropertyName = "EmbedContentBatchState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievedContext))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedRequests))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningExample))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ThinkingConfigThinkingLevel), TypeInfoPropertyName = "ThinkingConfigThinkingLevel2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkStringList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.Dictionary))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SchemaType), TypeInfoPropertyName = "SchemaType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListCorporaResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] public sealed partial class SourceGenerationContext : global::System.Text.Json.Serialization.JsonSerializerContext { } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContextTypes.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContextTypes.g.cs index f644d00..32552b3 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContextTypes.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContextTypes.g.cs @@ -28,1060 +28,1060 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - public global::Google.Gemini.Part? Type0 { get; set; } + public global::Google.Gemini.CodeExecutionResult? Type0 { get; set; } /// /// /// - public global::Google.Gemini.Blob? Type1 { get; set; } + public string? Type1 { get; set; } /// /// /// - public global::Google.Gemini.ToolCall? Type2 { get; set; } + public global::Google.Gemini.CodeExecutionResultOutcome? Type2 { get; set; } /// /// /// - public byte[]? Type3 { get; set; } + public global::Google.Gemini.EmbedContentBatch? Type3 { get; set; } /// /// /// - public string? Type4 { get; set; } + public global::Google.Gemini.EmbedContentBatchOutput? Type4 { get; set; } /// /// /// - public global::Google.Gemini.FileData? Type5 { get; set; } + public global::Google.Gemini.EmbedContentBatchState? Type5 { get; set; } /// /// /// - public global::Google.Gemini.VideoMetadata? Type6 { get; set; } + public global::Google.Gemini.InputEmbedContentConfig? Type6 { get; set; } /// /// /// - public global::Google.Gemini.ToolResponse? Type7 { get; set; } + public global::Google.Gemini.EmbedContentBatchStats? Type7 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponse? Type8 { get; set; } + public global::Google.Gemini.WhiteSpaceConfig? Type8 { get; set; } /// /// /// - public global::Google.Gemini.ExecutableCode? Type9 { get; set; } + public int? Type9 { get; set; } /// /// /// - public object? Type10 { get; set; } + public global::Google.Gemini.InlinedEmbedContentResponses? Type10 { get; set; } /// /// /// - public global::Google.Gemini.FunctionCall? Type11 { get; set; } + public global::System.Collections.Generic.IList? Type11 { get; set; } /// /// /// - public global::Google.Gemini.CodeExecutionResult? Type12 { get; set; } + public global::Google.Gemini.InlinedEmbedContentResponse? Type12 { get; set; } /// /// /// - public bool? Type13 { get; set; } + public global::Google.Gemini.Tool? Type13 { get; set; } /// /// /// - public global::Google.Gemini.Image? Type14 { get; set; } + public global::System.Collections.Generic.IList? Type14 { get; set; } /// /// /// - public global::Google.Gemini.ListFilesResponse? Type15 { get; set; } + public global::Google.Gemini.FunctionDeclaration? Type15 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type16 { get; set; } + public global::Google.Gemini.CodeExecution? Type16 { get; set; } /// /// /// - public global::Google.Gemini.File? Type17 { get; set; } + public global::Google.Gemini.ComputerUse? Type17 { get; set; } /// /// /// - public global::Google.Gemini.BatchGenerateContentRequest? Type18 { get; set; } + public global::Google.Gemini.GoogleSearch? Type18 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentBatch? Type19 { get; set; } + public global::Google.Gemini.UrlContext? Type19 { get; set; } /// /// /// - public global::Google.Gemini.ListTunedModelsResponse? Type20 { get; set; } + public global::Google.Gemini.FileSearch? Type20 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type21 { get; set; } + public global::System.Collections.Generic.IList? Type21 { get; set; } /// /// /// - public global::Google.Gemini.TunedModel? Type22 { get; set; } + public global::Google.Gemini.McpServer? Type22 { get; set; } /// /// /// - public global::Google.Gemini.ThinkingConfig? Type23 { get; set; } + public global::Google.Gemini.GoogleSearchRetrieval? Type23 { get; set; } /// /// /// - public int? Type24 { get; set; } + public global::Google.Gemini.GoogleMaps? Type24 { get; set; } /// /// /// - public global::Google.Gemini.ThinkingConfigThinkingLevel? Type25 { get; set; } + public global::Google.Gemini.ListDocumentsResponse? Type25 { get; set; } /// /// /// - public global::Google.Gemini.CreateFileResponse? Type26 { get; set; } + public global::System.Collections.Generic.IList? Type26 { get; set; } /// /// /// - public global::Google.Gemini.CitationMetadata? Type27 { get; set; } + public global::Google.Gemini.Document? Type27 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type28 { get; set; } + public global::Google.Gemini.ListFilesResponse? Type28 { get; set; } /// /// /// - public global::Google.Gemini.CitationSource? Type29 { get; set; } + public global::System.Collections.Generic.IList? Type29 { get; set; } /// /// /// - public global::Google.Gemini.AsyncBatchEmbedContentRequest? Type30 { get; set; } + public global::Google.Gemini.File? Type30 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatch? Type31 { get; set; } + public global::System.Collections.Generic.IList? Type31 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatchOutput? Type32 { get; set; } + public global::Google.Gemini.CustomMetadata? Type32 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentResponses? Type33 { get; set; } + public global::Google.Gemini.DocumentState? Type33 { get; set; } /// /// /// - public global::Google.Gemini.GoogleSearch? Type34 { get; set; } + public global::Google.Gemini.Empty? Type34 { get; set; } /// /// /// - public global::Google.Gemini.Interval? Type35 { get; set; } + public global::Google.Gemini.CountTokensResponse? Type35 { get; set; } /// /// /// - public global::Google.Gemini.SearchTypes? Type36 { get; set; } + public global::System.Collections.Generic.IList? Type36 { get; set; } /// /// /// - public global::Google.Gemini.Maps? Type37 { get; set; } + public global::Google.Gemini.ModalityTokenCount? Type37 { get; set; } /// /// /// - public global::Google.Gemini.PlaceAnswerSources? Type38 { get; set; } + public global::Google.Gemini.LogprobsResult? Type38 { get; set; } /// /// /// - public global::Google.Gemini.UrlMetadata? Type39 { get; set; } + public float? Type39 { get; set; } /// /// /// - public global::Google.Gemini.UrlMetadataUrlRetrievalStatus? Type40 { get; set; } + public global::System.Collections.Generic.IList? Type40 { get; set; } /// /// /// - public global::Google.Gemini.InlinedResponses? Type41 { get; set; } + public global::Google.Gemini.LogprobsResultCandidate? Type41 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type42 { get; set; } + public global::System.Collections.Generic.IList? Type42 { get; set; } /// /// /// - public global::Google.Gemini.InlinedResponse? Type43 { get; set; } + public global::Google.Gemini.TopCandidates? Type43 { get; set; } /// /// /// - public global::Google.Gemini.Model? Type44 { get; set; } + public global::Google.Gemini.Interval? Type44 { get; set; } /// /// /// - public float? Type45 { get; set; } + public global::Google.Gemini.SearchTypes? Type45 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type46 { get; set; } + public global::Google.Gemini.StreamableHttpTransport? Type46 { get; set; } /// /// /// - public global::Google.Gemini.GenerationConfig? Type47 { get; set; } + public bool? Type47 { get; set; } /// /// /// - public global::Google.Gemini.Schema? Type48 { get; set; } + public global::System.Collections.Generic.Dictionary? Type48 { get; set; } /// /// /// - public global::Google.Gemini.GenerationConfigMediaResolution? Type49 { get; set; } + public object? Type49 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type50 { get; set; } + public global::Google.Gemini.Schema? Type50 { get; set; } /// /// /// - public global::Google.Gemini.GenerationConfigResponseModalitie? Type51 { get; set; } + public global::Google.Gemini.FunctionDeclarationBehavior? Type51 { get; set; } /// /// /// - public global::Google.Gemini.SpeechConfig? Type52 { get; set; } + public global::Google.Gemini.RetrievedContext? Type52 { get; set; } /// /// /// - public global::Google.Gemini.ImageConfig? Type53 { get; set; } + public global::System.Collections.Generic.IList? Type53 { get; set; } /// /// /// - public global::Google.Gemini.CodeExecution? Type54 { get; set; } + public global::Google.Gemini.GroundingChunkCustomMetadata? Type54 { get; set; } /// /// /// - public global::Google.Gemini.MultiSpeakerVoiceConfig? Type55 { get; set; } + public global::Google.Gemini.GroundingChunk? Type55 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type56 { get; set; } + public global::Google.Gemini.Web? Type56 { get; set; } /// /// /// - public global::Google.Gemini.SpeakerVoiceConfig? Type57 { get; set; } + public global::Google.Gemini.Maps? Type57 { get; set; } /// /// /// - public global::Google.Gemini.WebSearch? Type58 { get; set; } + public global::Google.Gemini.Image? Type58 { get; set; } /// /// /// - public global::Google.Gemini.ImageSearch? Type59 { get; set; } + public global::Google.Gemini.UrlContextMetadata? Type59 { get; set; } /// /// /// - public global::Google.Gemini.SearchEntryPoint? Type60 { get; set; } + public global::System.Collections.Generic.IList? Type60 { get; set; } /// /// /// - public global::Google.Gemini.FunctionDeclaration? Type61 { get; set; } + public global::Google.Gemini.UrlMetadata? Type61 { get; set; } /// /// /// - public global::Google.Gemini.FunctionDeclarationBehavior? Type62 { get; set; } + public global::Google.Gemini.Operation? Type62 { get; set; } /// /// /// - public global::Google.Gemini.Operation? Type63 { get; set; } + public global::Google.Gemini.Status? Type63 { get; set; } /// /// /// - public global::Google.Gemini.Status? Type64 { get; set; } + public global::Google.Gemini.GeneratedFile? Type64 { get; set; } /// /// /// - public global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? Type65 { get; set; } + public global::Google.Gemini.GeneratedFileState? Type65 { get; set; } /// /// /// - public global::Google.Gemini.TransferOwnershipResponse? Type66 { get; set; } + public global::Google.Gemini.ImageConfig? Type66 { get; set; } /// /// /// - public global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport? Type67 { get; set; } + public global::Google.Gemini.FunctionResponse? Type67 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type68 { get; set; } + public global::System.Collections.Generic.IList? Type68 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type69 { get; set; } + public global::Google.Gemini.FunctionResponsePart? Type69 { get; set; } /// /// /// - public global::Google.Gemini.CachedContent? Type70 { get; set; } + public global::Google.Gemini.FunctionResponseScheduling? Type70 { get; set; } /// /// /// - public global::Google.Gemini.ToolConfig? Type71 { get; set; } + public global::Google.Gemini.GroundingMetadata? Type71 { get; set; } /// /// /// - public global::Google.Gemini.Content? Type72 { get; set; } + public global::Google.Gemini.SearchEntryPoint? Type72 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type73 { get; set; } + public global::Google.Gemini.RetrievalMetadata? Type73 { get; set; } /// /// /// - public global::Google.Gemini.CachedContentUsageMetadata? Type74 { get; set; } + public global::System.Collections.Generic.IList? Type74 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type75 { get; set; } + public global::System.Collections.Generic.IList? Type75 { get; set; } /// /// /// - public global::Google.Gemini.Tool? Type76 { get; set; } + public global::System.Collections.Generic.IList? Type76 { get; set; } /// /// /// - public global::Google.Gemini.CountTokensRequest? Type77 { get; set; } + public global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport? Type77 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentRequest? Type78 { get; set; } + public global::Google.Gemini.BatchGenerateContentRequest? Type78 { get; set; } /// /// /// - public global::Google.Gemini.BatchStats? Type79 { get; set; } + public global::Google.Gemini.GenerateContentBatch? Type79 { get; set; } /// /// /// - public global::Google.Gemini.GroundingMetadata? Type80 { get; set; } + public global::Google.Gemini.VideoMetadata? Type80 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type81 { get; set; } + public double? Type81 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type82 { get; set; } + public global::Google.Gemini.GenerateContentResponse? Type82 { get; set; } /// /// /// - public global::Google.Gemini.GroundingChunk? Type83 { get; set; } + public global::Google.Gemini.UsageMetadata? Type83 { get; set; } /// /// /// - public global::Google.Gemini.RetrievalMetadata? Type84 { get; set; } + public global::Google.Gemini.PromptFeedback? Type84 { get; set; } /// /// /// - public global::Google.Gemini.InlinedRequest? Type85 { get; set; } + public global::System.Collections.Generic.IList? Type85 { get; set; } /// /// /// - public global::Google.Gemini.UrlContext? Type86 { get; set; } + public global::Google.Gemini.Candidate? Type86 { get; set; } /// /// /// - public global::Google.Gemini.FunctionCallingConfig? Type87 { get; set; } + public global::Google.Gemini.ModelStatus? Type87 { get; set; } /// /// /// - public global::Google.Gemini.FunctionCallingConfigMode? Type88 { get; set; } + public global::Google.Gemini.SafetySetting? Type88 { get; set; } /// /// /// - public global::Google.Gemini.Document? Type89 { get; set; } + public global::Google.Gemini.SafetySettingThreshold? Type89 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type90 { get; set; } + public global::Google.Gemini.SafetySettingCategory? Type90 { get; set; } /// /// /// - public global::Google.Gemini.CustomMetadata? Type91 { get; set; } + public global::Google.Gemini.GenerateContentRequest? Type91 { get; set; } /// /// /// - public global::Google.Gemini.DocumentState? Type92 { get; set; } + public global::Google.Gemini.ToolConfig? Type92 { get; set; } /// /// /// - public global::Google.Gemini.ListOperationsResponse? Type93 { get; set; } + public global::Google.Gemini.Content? Type93 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type94 { get; set; } + public global::Google.Gemini.GenerationConfig? Type94 { get; set; } /// /// /// - public global::Google.Gemini.BatchEmbedContentsRequest? Type95 { get; set; } + public global::Google.Gemini.GenerateContentRequestServiceTier? Type95 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type96 { get; set; } + public global::System.Collections.Generic.IList? Type96 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentRequest? Type97 { get; set; } + public global::System.Collections.Generic.IList? Type97 { get; set; } /// /// /// - public global::Google.Gemini.BatchEmbedContentsResponse? Type98 { get; set; } + public global::System.Collections.Generic.IList? Type98 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type99 { get; set; } + public global::Google.Gemini.CreateFileResponse? Type99 { get; set; } /// /// /// - public global::Google.Gemini.ContentEmbedding? Type100 { get; set; } + public global::Google.Gemini.FunctionCallingConfig? Type100 { get; set; } /// /// /// - public global::Google.Gemini.EmbeddingUsageMetadata? Type101 { get; set; } + public global::Google.Gemini.RetrievalConfig? Type101 { get; set; } /// /// /// - public double? Type102 { get; set; } + public global::Google.Gemini.InlinedRequest? Type102 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type103 { get; set; } + public global::Google.Gemini.ListFileSearchStoresResponse? Type103 { get; set; } /// /// /// - public global::Google.Gemini.SchemaType? Type104 { get; set; } + public global::System.Collections.Generic.IList? Type104 { get; set; } /// /// /// - public global::System.Collections.Generic.Dictionary? Type105 { get; set; } + public global::Google.Gemini.FileSearchStore? Type105 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentResponse? Type106 { get; set; } + public global::Google.Gemini.FunctionResponseBlob? Type106 { get; set; } /// /// /// - public global::Google.Gemini.UsageMetadata? Type107 { get; set; } + public global::Google.Gemini.InlinedResponse? Type107 { get; set; } /// /// /// - public global::Google.Gemini.ModelStatus? Type108 { get; set; } + public global::Google.Gemini.PromptFeedbackBlockReason? Type108 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type109 { get; set; } + public global::System.Collections.Generic.IList? Type109 { get; set; } /// /// /// - public global::Google.Gemini.Candidate? Type110 { get; set; } + public global::Google.Gemini.SafetyRating? Type110 { get; set; } /// /// /// - public global::Google.Gemini.PromptFeedback? Type111 { get; set; } + public global::Google.Gemini.FileData? Type111 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponsePart? Type112 { get; set; } + public global::Google.Gemini.PrebuiltVoiceConfig? Type112 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponseBlob? Type113 { get; set; } + public global::Google.Gemini.ListCachedContentsResponse? Type113 { get; set; } /// /// /// - public global::Google.Gemini.ListModelsResponse? Type114 { get; set; } + public global::System.Collections.Generic.IList? Type114 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type115 { get; set; } + public global::Google.Gemini.CachedContent? Type115 { get; set; } /// /// /// - public global::Google.Gemini.ListCorporaResponse? Type116 { get; set; } + public global::Google.Gemini.SafetyRatingProbability? Type116 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type117 { get; set; } + public global::Google.Gemini.SafetyRatingCategory? Type117 { get; set; } /// /// /// - public global::Google.Gemini.Corpus? Type118 { get; set; } + public global::Google.Gemini.BatchEmbedContentsResponse? Type118 { get; set; } /// /// /// - public global::Google.Gemini.ImportFileRequest? Type119 { get; set; } + public global::Google.Gemini.EmbeddingUsageMetadata? Type119 { get; set; } /// /// /// - public global::Google.Gemini.ChunkingConfig? Type120 { get; set; } + public global::System.Collections.Generic.IList? Type120 { get; set; } /// /// /// - public global::Google.Gemini.ModelStatusModelStage? Type121 { get; set; } + public global::Google.Gemini.ContentEmbedding? Type121 { get; set; } /// /// /// - public global::Google.Gemini.GeneratedFile? Type122 { get; set; } + public global::Google.Gemini.VideoFileMetadata? Type122 { get; set; } /// /// /// - public global::Google.Gemini.GeneratedFileState? Type123 { get; set; } + public global::Google.Gemini.ToolCall? Type123 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentBatchOutput? Type124 { get; set; } + public global::Google.Gemini.ToolCallToolType? Type124 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentBatchState? Type125 { get; set; } + public global::Google.Gemini.DynamicRetrievalConfig? Type125 { get; set; } /// /// /// - public global::Google.Gemini.InputConfig? Type126 { get; set; } + public global::Google.Gemini.UploadToFileSearchStoreRequest? Type126 { get; set; } /// /// /// - public global::Google.Gemini.RegisterFilesResponse? Type127 { get; set; } + public global::Google.Gemini.ChunkingConfig? Type127 { get; set; } /// /// /// - public global::Google.Gemini.ListFileSearchStoresResponse? Type128 { get; set; } + public global::Google.Gemini.PlaceAnswerSources? Type128 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type129 { get; set; } + public global::System.Collections.Generic.IList? Type129 { get; set; } /// /// /// - public global::Google.Gemini.FileSearchStore? Type130 { get; set; } + public global::Google.Gemini.ReviewSnippet? Type130 { get; set; } /// /// /// - public global::Google.Gemini.TopCandidates? Type131 { get; set; } + public global::Google.Gemini.EmbedContentResponse? Type131 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type132 { get; set; } + public global::Google.Gemini.Model? Type132 { get; set; } /// /// /// - public global::Google.Gemini.LogprobsResultCandidate? Type133 { get; set; } + public global::Google.Gemini.ListPermissionsResponse? Type133 { get; set; } /// /// /// - public global::Google.Gemini.ReviewSnippet? Type134 { get; set; } + public global::System.Collections.Generic.IList? Type134 { get; set; } /// /// /// - public global::Google.Gemini.SemanticRetrieverChunk? Type135 { get; set; } + public global::Google.Gemini.Permission? Type135 { get; set; } /// /// /// - public global::Google.Gemini.Web? Type136 { get; set; } + public global::Google.Gemini.TransferOwnershipResponse? Type136 { get; set; } /// /// /// - public global::Google.Gemini.GroundingChunkCustomMetadata? Type137 { get; set; } + public global::Google.Gemini.Dataset? Type137 { get; set; } /// /// /// - public global::Google.Gemini.GroundingChunkStringList? Type138 { get; set; } + public global::Google.Gemini.TuningExamples? Type138 { get; set; } /// /// /// - public global::Google.Gemini.GroundingAttribution? Type139 { get; set; } + public global::Google.Gemini.CitationSource? Type139 { get; set; } /// /// /// - public global::Google.Gemini.AttributionSourceId? Type140 { get; set; } + public global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? Type140 { get; set; } /// /// /// - public global::Google.Gemini.CustomLongRunningOperation? Type141 { get; set; } + public global::Google.Gemini.Part? Type141 { get; set; } /// /// /// - public global::Google.Gemini.PrebuiltVoiceConfig? Type142 { get; set; } + public global::Google.Gemini.Blob? Type142 { get; set; } /// /// /// - public global::Google.Gemini.UrlContextMetadata? Type143 { get; set; } + public global::Google.Gemini.FunctionCall? Type143 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type144 { get; set; } + public global::Google.Gemini.ExecutableCode? Type144 { get; set; } /// /// /// - public global::Google.Gemini.TransferOwnershipRequest? Type145 { get; set; } + public global::Google.Gemini.ToolResponse? Type145 { get; set; } /// /// /// - public global::Google.Gemini.TunedModelSource? Type146 { get; set; } + public byte[]? Type146 { get; set; } /// /// /// - public global::Google.Gemini.TunedModelState? Type147 { get; set; } + public global::Google.Gemini.PermissionGranteeType? Type147 { get; set; } /// /// /// - public global::Google.Gemini.TuningTask? Type148 { get; set; } + public global::Google.Gemini.PermissionRole? Type148 { get; set; } /// /// /// - public global::Google.Gemini.InlinedRequests? Type149 { get; set; } + public global::Google.Gemini.SpeechConfig? Type149 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type150 { get; set; } + public global::Google.Gemini.VoiceConfig? Type150 { get; set; } /// /// /// - public global::Google.Gemini.CreateFileRequest? Type151 { get; set; } + public global::Google.Gemini.MultiSpeakerVoiceConfig? Type151 { get; set; } /// /// /// - public global::Google.Gemini.TuningExample? Type152 { get; set; } + public global::Google.Gemini.FileState? Type152 { get; set; } /// /// /// - public global::Google.Gemini.CodeExecutionResultOutcome? Type153 { get; set; } + public global::Google.Gemini.FileSource? Type153 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type154 { get; set; } + public global::Google.Gemini.CachedContentUsageMetadata? Type154 { get; set; } /// /// /// - public global::Google.Gemini.LogprobsResult? Type155 { get; set; } + public global::Google.Gemini.TuningTask? Type155 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type156 { get; set; } + public global::System.Collections.Generic.IList? Type156 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type157 { get; set; } + public global::Google.Gemini.TuningSnapshot? Type157 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentResponse? Type158 { get; set; } + public global::Google.Gemini.Hyperparameters? Type158 { get; set; } /// /// /// - public global::Google.Gemini.WhiteSpaceConfig? Type159 { get; set; } + public global::System.Collections.Generic.IList? Type159 { get; set; } /// /// /// - public global::Google.Gemini.SafetyRating? Type160 { get; set; } + public global::Google.Gemini.BatchEmbedContentsRequest? Type160 { get; set; } /// /// /// - public global::Google.Gemini.SafetyRatingProbability? Type161 { get; set; } + public global::System.Collections.Generic.IList? Type161 { get; set; } /// /// /// - public global::Google.Gemini.SafetyRatingCategory? Type162 { get; set; } + public global::Google.Gemini.EmbedContentRequest? Type162 { get; set; } /// /// /// - public global::Google.Gemini.Hyperparameters? Type163 { get; set; } + public global::System.Collections.Generic.IList? Type163 { get; set; } /// /// /// - public global::Google.Gemini.StreamableHttpTransport? Type164 { get; set; } + public global::System.Collections.Generic.IList? Type164 { get; set; } /// /// /// - public global::System.Collections.Generic.Dictionary? Type165 { get; set; } + public global::Google.Gemini.ImportFileRequest? Type165 { get; set; } /// /// /// - public global::Google.Gemini.RetrievalConfig? Type166 { get; set; } + public global::Google.Gemini.UrlMetadataUrlRetrievalStatus? Type166 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type167 { get; set; } + public global::Google.Gemini.WebSearch? Type167 { get; set; } /// /// /// - public global::Google.Gemini.McpServer? Type168 { get; set; } + public global::Google.Gemini.ImageSearch? Type168 { get; set; } /// /// /// - public global::Google.Gemini.GroundingPassageId? Type169 { get; set; } + public global::Google.Gemini.BatchStats? Type169 { get; set; } /// /// /// - public global::Google.Gemini.TuningExamples? Type170 { get; set; } + public global::Google.Gemini.TunedModel? Type170 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type171 { get; set; } + public global::Google.Gemini.TunedModelSource? Type171 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type172 { get; set; } + public global::Google.Gemini.TunedModelState? Type172 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponseScheduling? Type173 { get; set; } + public global::Google.Gemini.DynamicRetrievalConfigMode? Type173 { get; set; } /// /// /// - public global::Google.Gemini.SafetySetting? Type174 { get; set; } + public global::Google.Gemini.ListTunedModelsResponse? Type174 { get; set; } /// /// /// - public global::Google.Gemini.SafetySettingThreshold? Type175 { get; set; } + public global::System.Collections.Generic.IList? Type175 { get; set; } /// /// /// - public global::Google.Gemini.SafetySettingCategory? Type176 { get; set; } + public global::Google.Gemini.ModelStatusModelStage? Type176 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentRequests? Type177 { get; set; } + public global::Google.Gemini.ToolResponseToolType? Type177 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type178 { get; set; } + public global::Google.Gemini.InlinedEmbedContentRequests? Type178 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentRequest? Type179 { get; set; } + public global::System.Collections.Generic.IList? Type179 { get; set; } /// /// /// - public global::Google.Gemini.ExecutableCodeLanguage? Type180 { get; set; } + public global::Google.Gemini.InlinedEmbedContentRequest? Type180 { get; set; } /// /// /// - public global::Google.Gemini.ComputerUse? Type181 { get; set; } + public global::Google.Gemini.LatLng? Type181 { get; set; } /// /// /// - public global::Google.Gemini.ComputerUseEnvironment? Type182 { get; set; } + public global::Google.Gemini.TransferOwnershipRequest? Type182 { get; set; } /// /// /// - public global::Google.Gemini.VoiceConfig? Type183 { get; set; } + public global::Google.Gemini.CustomLongRunningOperation? Type183 { get; set; } /// /// /// - public global::Google.Gemini.ListCachedContentsResponse? Type184 { get; set; } + public global::System.Collections.Generic.IList? Type184 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type185 { get; set; } + public global::Google.Gemini.SpeakerVoiceConfig? Type185 { get; set; } /// /// /// - public global::Google.Gemini.RegisterFilesRequest? Type186 { get; set; } + public global::Google.Gemini.CreateFileRequest? Type186 { get; set; } /// /// /// - public global::Google.Gemini.ListDocumentsResponse? Type187 { get; set; } + public global::Google.Gemini.AsyncBatchEmbedContentRequest? Type187 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type188 { get; set; } + public global::System.Collections.Generic.IList? Type188 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type189 { get; set; } + public global::Google.Gemini.GenerationConfigResponseModalitie? Type189 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type190 { get; set; } + public global::Google.Gemini.ThinkingConfig? Type190 { get; set; } /// /// /// - public global::Google.Gemini.CandidateFinishReason? Type191 { get; set; } + public global::Google.Gemini.GenerationConfigMediaResolution? Type191 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type192 { get; set; } + public global::Google.Gemini.RegisterFilesResponse? Type192 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentRequestTaskType? Type193 { get; set; } + public global::Google.Gemini.AttributionSourceId? Type193 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentRequestServiceTier? Type194 { get; set; } + public global::Google.Gemini.GroundingPassageId? Type194 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type195 { get; set; } + public global::Google.Gemini.SemanticRetrieverChunk? Type195 { get; set; } /// /// /// - public global::Google.Gemini.LatLng? Type196 { get; set; } + public global::Google.Gemini.FunctionCallingConfigMode? Type196 { get; set; } /// /// /// - public global::Google.Gemini.ModalityTokenCount? Type197 { get; set; } + public global::Google.Gemini.CountTokensRequest? Type197 { get; set; } /// /// /// - public global::Google.Gemini.ModalityTokenCountModality? Type198 { get; set; } + public global::Google.Gemini.ExecutableCodeLanguage? Type198 { get; set; } /// /// /// - public global::Google.Gemini.Dataset? Type199 { get; set; } + public global::System.Collections.Generic.IList? Type199 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type200 { get; set; } + public global::Google.Gemini.GroundingAttribution? Type200 { get; set; } /// /// /// - public global::Google.Gemini.TuningSnapshot? Type201 { get; set; } + public global::Google.Gemini.CitationMetadata? Type201 { get; set; } /// /// /// - public global::Google.Gemini.GoogleSearchRetrieval? Type202 { get; set; } + public global::Google.Gemini.CandidateFinishReason? Type202 { get; set; } /// /// /// - public global::Google.Gemini.DynamicRetrievalConfig? Type203 { get; set; } + public global::Google.Gemini.InlinedResponses? Type203 { get; set; } /// /// /// - public global::Google.Gemini.VideoFileMetadata? Type204 { get; set; } + public global::System.Collections.Generic.IList? Type204 { get; set; } /// /// /// - public global::Google.Gemini.FileSource? Type205 { get; set; } + public global::Google.Gemini.ListModelsResponse? Type205 { get; set; } /// /// /// - public global::Google.Gemini.FileState? Type206 { get; set; } + public global::System.Collections.Generic.IList? Type206 { get; set; } /// /// /// - public global::Google.Gemini.GoogleMaps? Type207 { get; set; } + public global::Google.Gemini.ComputerUseEnvironment? Type207 { get; set; } /// /// /// - public global::Google.Gemini.FileSearch? Type208 { get; set; } + public global::Google.Gemini.ModalityTokenCountModality? Type208 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type209 { get; set; } + public global::Google.Gemini.EmbedContentRequestTaskType? Type209 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type210 { get; set; } + public global::Google.Gemini.StringList? Type210 { get; set; } /// /// /// - public global::Google.Gemini.StringList? Type211 { get; set; } + public global::Google.Gemini.Corpus? Type211 { get; set; } /// /// /// - public global::Google.Gemini.ToolCallToolType? Type212 { get; set; } + public global::Google.Gemini.ListOperationsResponse? Type212 { get; set; } /// /// /// - public global::Google.Gemini.DynamicRetrievalConfigMode? Type213 { get; set; } + public global::System.Collections.Generic.IList? Type213 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatchStats? Type214 { get; set; } + public global::Google.Gemini.InputConfig? Type214 { get; set; } /// /// /// - public global::Google.Gemini.CountTokensResponse? Type215 { get; set; } + public global::Google.Gemini.GenerateContentBatchState? Type215 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type216 { get; set; } + public global::Google.Gemini.GenerateContentBatchOutput? Type216 { get; set; } /// /// /// - public global::Google.Gemini.ToolResponseToolType? Type217 { get; set; } + public global::System.Collections.Generic.IList? Type217 { get; set; } /// /// /// - public global::Google.Gemini.InputEmbedContentConfig? Type218 { get; set; } + public global::Google.Gemini.ListGeneratedFilesResponse? Type218 { get; set; } /// /// /// - public global::Google.Gemini.ListGeneratedFilesResponse? Type219 { get; set; } + public global::System.Collections.Generic.IList? Type219 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type220 { get; set; } + public global::Google.Gemini.InlinedRequests? Type220 { get; set; } /// /// /// - public global::Google.Gemini.Permission? Type221 { get; set; } + public global::Google.Gemini.TuningExample? Type221 { get; set; } /// /// /// - public global::Google.Gemini.PermissionGranteeType? Type222 { get; set; } + public global::Google.Gemini.RegisterFilesRequest? Type222 { get; set; } /// /// /// - public global::Google.Gemini.PermissionRole? Type223 { get; set; } + public global::Google.Gemini.ThinkingConfigThinkingLevel? Type223 { get; set; } /// /// /// - public global::Google.Gemini.UploadToFileSearchStoreRequest? Type224 { get; set; } + public global::Google.Gemini.GroundingChunkStringList? Type224 { get; set; } /// /// /// - public global::Google.Gemini.PromptFeedbackBlockReason? Type225 { get; set; } + public global::System.Collections.Generic.IList? Type225 { get; set; } /// /// /// - public global::Google.Gemini.Empty? Type226 { get; set; } + public global::System.Collections.Generic.Dictionary? Type226 { get; set; } /// /// /// - public global::Google.Gemini.ListPermissionsResponse? Type227 { get; set; } + public global::Google.Gemini.SchemaType? Type227 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type228 { get; set; } + public global::System.Collections.Generic.IList? Type228 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentResponse? Type229 { get; set; } + public global::System.Collections.Generic.IList? Type229 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatchState? Type230 { get; set; } + public global::System.Collections.Generic.IList? Type230 { get; set; } /// /// /// - public global::Google.Gemini.RetrievedContext? Type231 { get; set; } + public global::Google.Gemini.ListCorporaResponse? Type231 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type232 { get; set; } + public global::System.Collections.Generic.IList? Type232 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType0 { get; set; } + public global::System.Collections.Generic.List? ListType0 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType1 { get; set; } + public global::System.Collections.Generic.List? ListType1 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType2 { get; set; } + public global::System.Collections.Generic.List? ListType2 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType3 { get; set; } + public global::System.Collections.Generic.List? ListType3 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType4 { get; set; } + public global::System.Collections.Generic.List? ListType4 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType5 { get; set; } + public global::System.Collections.Generic.List? ListType5 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType6 { get; set; } + public global::System.Collections.Generic.List? ListType6 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType7 { get; set; } + public global::System.Collections.Generic.List? ListType7 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType8 { get; set; } + public global::System.Collections.Generic.List? ListType8 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType9 { get; set; } + public global::System.Collections.Generic.List? ListType9 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType10 { get; set; } + public global::System.Collections.Generic.List? ListType10 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType11 { get; set; } + public global::System.Collections.Generic.List? ListType11 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType12 { get; set; } + public global::System.Collections.Generic.List? ListType12 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType13 { get; set; } + public global::System.Collections.Generic.List? ListType13 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType14 { get; set; } + public global::System.Collections.Generic.List? ListType14 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType15 { get; set; } + public global::System.Collections.Generic.List? ListType15 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType16 { get; set; } + public global::System.Collections.Generic.List? ListType16 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType17 { get; set; } + public global::System.Collections.Generic.List? ListType17 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType18 { get; set; } + public global::System.Collections.Generic.List? ListType18 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType19 { get; set; } + public global::System.Collections.Generic.List? ListType19 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType20 { get; set; } + public global::System.Collections.Generic.List? ListType20 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType21 { get; set; } + public global::System.Collections.Generic.List? ListType21 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType22 { get; set; } + public global::System.Collections.Generic.List? ListType22 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType23 { get; set; } + public global::System.Collections.Generic.List? ListType23 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType24 { get; set; } + public global::System.Collections.Generic.List? ListType24 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType25 { get; set; } + public global::System.Collections.Generic.List? ListType25 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType26 { get; set; } + public global::System.Collections.Generic.List? ListType26 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType27 { get; set; } + public global::System.Collections.Generic.List? ListType27 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType28 { get; set; } + public global::System.Collections.Generic.List? ListType28 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType29 { get; set; } + public global::System.Collections.Generic.List? ListType29 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType30 { get; set; } + public global::System.Collections.Generic.List? ListType30 { get; set; } /// /// /// @@ -1089,54 +1089,54 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - public global::System.Collections.Generic.List? ListType32 { get; set; } + public global::System.Collections.Generic.List? ListType32 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType33 { get; set; } + public global::System.Collections.Generic.List? ListType33 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType34 { get; set; } + public global::System.Collections.Generic.List? ListType34 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType35 { get; set; } + public global::System.Collections.Generic.List? ListType35 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType36 { get; set; } + public global::System.Collections.Generic.List? ListType36 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType37 { get; set; } + public global::System.Collections.Generic.List? ListType37 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType38 { get; set; } + public global::System.Collections.Generic.List? ListType38 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType39 { get; set; } + public global::System.Collections.Generic.List? ListType39 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType40 { get; set; } + public global::System.Collections.Generic.List? ListType40 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType41 { get; set; } + public global::System.Collections.Generic.List? ListType41 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType42 { get; set; } + public global::System.Collections.Generic.List? ListType42 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType43 { get; set; } + public global::System.Collections.Generic.List? ListType43 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType44 { get; set; } + public global::System.Collections.Generic.List? ListType44 { get; set; } } } \ No newline at end of file diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchEmbedContentsResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchEmbedContentsResponse.g.cs index aa89d87..1c4f263 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchEmbedContentsResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchEmbedContentsResponse.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class BatchEmbedContentsResponse { + /// + /// Metadata on the usage of the embedding request. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] + public global::Google.Gemini.EmbeddingUsageMetadata? UsageMetadata { get; set; } + /// /// Output only. The embeddings for each request, in the same order as provided in the batch request.
/// Included only in responses @@ -15,12 +21,6 @@ public sealed partial class BatchEmbedContentsResponse [global::System.Text.Json.Serialization.JsonPropertyName("embeddings")] public global::System.Collections.Generic.IList? Embeddings { get; set; } - /// - /// Metadata on the usage of the embedding request. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] - public global::Google.Gemini.EmbeddingUsageMetadata? UsageMetadata { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,22 +30,22 @@ public sealed partial class BatchEmbedContentsResponse /// /// Initializes a new instance of the class. /// + /// + /// Metadata on the usage of the embedding request. + /// /// /// Output only. The embeddings for each request, in the same order as provided in the batch request.
/// Included only in responses /// - /// - /// Metadata on the usage of the embedding request. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public BatchEmbedContentsResponse( - global::System.Collections.Generic.IList? embeddings, - global::Google.Gemini.EmbeddingUsageMetadata? usageMetadata) + global::Google.Gemini.EmbeddingUsageMetadata? usageMetadata, + global::System.Collections.Generic.IList? embeddings) { - this.Embeddings = embeddings; this.UsageMetadata = usageMetadata; + this.Embeddings = embeddings; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchStats.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchStats.g.cs index 29afbb3..72da3cc 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchStats.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchStats.g.cs @@ -15,6 +15,13 @@ public sealed partial class BatchStats [global::System.Text.Json.Serialization.JsonPropertyName("requestCount")] public string? RequestCount { get; set; } + /// + /// Output only. The number of requests that failed to be processed.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("failedRequestCount")] + public string? FailedRequestCount { get; set; } + /// /// Output only. The number of requests that are still pending processing.
/// Included only in responses @@ -29,13 +36,6 @@ public sealed partial class BatchStats [global::System.Text.Json.Serialization.JsonPropertyName("successfulRequestCount")] public string? SuccessfulRequestCount { get; set; } - /// - /// Output only. The number of requests that failed to be processed.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("failedRequestCount")] - public string? FailedRequestCount { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -49,6 +49,10 @@ public sealed partial class BatchStats /// Output only. The number of requests in the batch.
/// Included only in responses /// + /// + /// Output only. The number of requests that failed to be processed.
+ /// Included only in responses + /// /// /// Output only. The number of requests that are still pending processing.
/// Included only in responses @@ -57,23 +61,19 @@ public sealed partial class BatchStats /// Output only. The number of requests that were successfully processed.
/// Included only in responses /// - /// - /// Output only. The number of requests that failed to be processed.
- /// Included only in responses - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public BatchStats( string? requestCount, + string? failedRequestCount, string? pendingRequestCount, - string? successfulRequestCount, - string? failedRequestCount) + string? successfulRequestCount) { this.RequestCount = requestCount; + this.FailedRequestCount = failedRequestCount; this.PendingRequestCount = pendingRequestCount; this.SuccessfulRequestCount = successfulRequestCount; - this.FailedRequestCount = failedRequestCount; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CachedContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CachedContent.g.cs index 0c4edee..4a31ac3 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CachedContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CachedContent.g.cs @@ -15,11 +15,10 @@ public sealed partial class CachedContent public string? ExpireTime { get; set; } /// - /// Output only. When the cache entry was last updated in UTC time.
- /// Included only in responses + /// Input only. New TTL for this resource, input only. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("ttl")] + public string? Ttl { get; set; } /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. @@ -28,23 +27,23 @@ public sealed partial class CachedContent public global::Google.Gemini.ToolConfig? ToolConfig { get; set; } /// - /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("systemInstruction")] + public global::Google.Gemini.Content? SystemInstruction { get; set; } /// - /// Input only. New TTL for this resource, input only. + /// Output only. When the cache entry was last updated in UTC time.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("ttl")] - public string? Ttl { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } /// - /// Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`
- /// Included only in responses + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("tools")] + public global::System.Collections.Generic.IList? Tools { get; set; } /// /// Output only. Creation time of the cache entry.
@@ -53,12 +52,6 @@ public sealed partial class CachedContent [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] public string? CreateTime { get; set; } - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("systemInstruction")] - public global::Google.Gemini.Content? SystemInstruction { get; set; } - /// /// Optional. Input only. Immutable. The content to cache. /// @@ -72,10 +65,11 @@ public sealed partial class CachedContent public global::Google.Gemini.CachedContentUsageMetadata? UsageMetadata { get; set; } /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("tools")] - public global::System.Collections.Generic.IList? Tools { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` @@ -83,6 +77,12 @@ public sealed partial class CachedContent [global::System.Text.Json.Serialization.JsonPropertyName("model")] public string? Model { get; set; } + /// + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -95,71 +95,71 @@ public sealed partial class CachedContent /// /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// - /// - /// Output only. When the cache entry was last updated in UTC time.
- /// Included only in responses + /// + /// Input only. New TTL for this resource, input only. /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. - /// - /// - /// Input only. New TTL for this resource, input only. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// - /// - /// Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`
+ /// + /// Output only. When the cache entry was last updated in UTC time.
/// Included only in responses /// + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// /// /// Output only. Creation time of the cache entry.
/// Included only in responses /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// /// /// Optional. Input only. Immutable. The content to cache. /// /// /// Metadata on the usage of the cached content. /// - /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`
+ /// Included only in responses /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` /// + /// + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CachedContent( string? expireTime, - string? updateTime, - global::Google.Gemini.ToolConfig? toolConfig, - string? displayName, string? ttl, - string? name, - string? createTime, + global::Google.Gemini.ToolConfig? toolConfig, global::Google.Gemini.Content? systemInstruction, + string? updateTime, + global::System.Collections.Generic.IList? tools, + string? createTime, global::System.Collections.Generic.IList? contents, global::Google.Gemini.CachedContentUsageMetadata? usageMetadata, - global::System.Collections.Generic.IList? tools, - string? model) + string? name, + string? model, + string? displayName) { this.ExpireTime = expireTime; - this.UpdateTime = updateTime; - this.ToolConfig = toolConfig; - this.DisplayName = displayName; this.Ttl = ttl; - this.Name = name; - this.CreateTime = createTime; + this.ToolConfig = toolConfig; this.SystemInstruction = systemInstruction; + this.UpdateTime = updateTime; + this.Tools = tools; + this.CreateTime = createTime; this.Contents = contents; this.UsageMetadata = usageMetadata; - this.Tools = tools; + this.Name = name; this.Model = model; + this.DisplayName = displayName; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Candidate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Candidate.g.cs index 103f5a5..95753a2 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Candidate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Candidate.g.cs @@ -9,10 +9,24 @@ namespace Google.Gemini public sealed partial class Candidate { /// - /// Logprobs Result + /// Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("logprobsResult")] - public global::Google.Gemini.LogprobsResult? LogprobsResult { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("finishMessage")] + public string? FinishMessage { get; set; } + + /// + /// Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("groundingAttributions")] + public global::System.Collections.Generic.IList? GroundingAttributions { get; set; } + + /// + /// Metadata returned to client when grounding is enabled. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("groundingMetadata")] + public global::Google.Gemini.GroundingMetadata? GroundingMetadata { get; set; } /// /// A collection of source attributions for a piece of content. @@ -21,23 +35,18 @@ public sealed partial class Candidate public global::Google.Gemini.CitationMetadata? CitationMetadata { get; set; } /// - /// Output only. Token count for this candidate.
+ /// Output only. Average log probability score of the candidate.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("tokenCount")] - public int? TokenCount { get; set; } - - /// - /// List of ratings for the safety of a response candidate. There is at most one rating per category. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("safetyRatings")] - public global::System.Collections.Generic.IList? SafetyRatings { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("avgLogprobs")] + public double? AvgLogprobs { get; set; } /// - /// Metadata related to url context retrieval tool. + /// Output only. Index of the candidate in the list of response candidates.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("urlContextMetadata")] - public global::Google.Gemini.UrlContextMetadata? UrlContextMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("index")] + public int? Index { get; set; } /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. @@ -46,46 +55,37 @@ public sealed partial class Candidate public global::Google.Gemini.Content? Content { get; set; } /// - /// Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.
+ /// Output only. Token count for this candidate.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("finishReason")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonJsonConverter))] - public global::Google.Gemini.CandidateFinishReason? FinishReason { get; set; } - - /// - /// Metadata returned to client when grounding is enabled. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("groundingMetadata")] - public global::Google.Gemini.GroundingMetadata? GroundingMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("tokenCount")] + public int? TokenCount { get; set; } /// - /// Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.
+ /// Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("finishMessage")] - public string? FinishMessage { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("finishReason")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonJsonConverter))] + public global::Google.Gemini.CandidateFinishReason? FinishReason { get; set; } /// - /// Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.
- /// Included only in responses + /// List of ratings for the safety of a response candidate. There is at most one rating per category. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("groundingAttributions")] - public global::System.Collections.Generic.IList? GroundingAttributions { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("safetyRatings")] + public global::System.Collections.Generic.IList? SafetyRatings { get; set; } /// - /// Output only. Average log probability score of the candidate.
- /// Included only in responses + /// Logprobs Result ///
- [global::System.Text.Json.Serialization.JsonPropertyName("avgLogprobs")] - public double? AvgLogprobs { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("logprobsResult")] + public global::Google.Gemini.LogprobsResult? LogprobsResult { get; set; } /// - /// Output only. Index of the candidate in the list of response candidates.
- /// Included only in responses + /// Metadata related to url context retrieval tool. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("index")] - public int? Index { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("urlContextMetadata")] + public global::Google.Gemini.UrlContextMetadata? UrlContextMetadata { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -96,77 +96,77 @@ public sealed partial class Candidate /// /// Initializes a new instance of the class. /// - /// - /// Logprobs Result + /// + /// Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.
+ /// Included only in responses + /// + /// + /// Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.
+ /// Included only in responses + /// + /// + /// Metadata returned to client when grounding is enabled. /// /// /// A collection of source attributions for a piece of content. /// - /// - /// Output only. Token count for this candidate.
+ /// + /// Output only. Average log probability score of the candidate.
/// Included only in responses /// - /// - /// List of ratings for the safety of a response candidate. There is at most one rating per category. - /// - /// - /// Metadata related to url context retrieval tool. + /// + /// Output only. Index of the candidate in the list of response candidates.
+ /// Included only in responses /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// - /// - /// Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.
+ /// + /// Output only. Token count for this candidate.
/// Included only in responses /// - /// - /// Metadata returned to client when grounding is enabled. - /// - /// - /// Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.
+ /// + /// Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.
/// Included only in responses /// - /// - /// Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.
- /// Included only in responses + /// + /// List of ratings for the safety of a response candidate. There is at most one rating per category. /// - /// - /// Output only. Average log probability score of the candidate.
- /// Included only in responses + /// + /// Logprobs Result /// - /// - /// Output only. Index of the candidate in the list of response candidates.
- /// Included only in responses + /// + /// Metadata related to url context retrieval tool. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Candidate( - global::Google.Gemini.LogprobsResult? logprobsResult, - global::Google.Gemini.CitationMetadata? citationMetadata, - int? tokenCount, - global::System.Collections.Generic.IList? safetyRatings, - global::Google.Gemini.UrlContextMetadata? urlContextMetadata, - global::Google.Gemini.Content? content, - global::Google.Gemini.CandidateFinishReason? finishReason, - global::Google.Gemini.GroundingMetadata? groundingMetadata, string? finishMessage, global::System.Collections.Generic.IList? groundingAttributions, + global::Google.Gemini.GroundingMetadata? groundingMetadata, + global::Google.Gemini.CitationMetadata? citationMetadata, double? avgLogprobs, - int? index) + int? index, + global::Google.Gemini.Content? content, + int? tokenCount, + global::Google.Gemini.CandidateFinishReason? finishReason, + global::System.Collections.Generic.IList? safetyRatings, + global::Google.Gemini.LogprobsResult? logprobsResult, + global::Google.Gemini.UrlContextMetadata? urlContextMetadata) { - this.LogprobsResult = logprobsResult; - this.CitationMetadata = citationMetadata; - this.TokenCount = tokenCount; - this.SafetyRatings = safetyRatings; - this.UrlContextMetadata = urlContextMetadata; - this.Content = content; - this.FinishReason = finishReason; - this.GroundingMetadata = groundingMetadata; this.FinishMessage = finishMessage; this.GroundingAttributions = groundingAttributions; + this.GroundingMetadata = groundingMetadata; + this.CitationMetadata = citationMetadata; this.AvgLogprobs = avgLogprobs; this.Index = index; + this.Content = content; + this.TokenCount = tokenCount; + this.FinishReason = finishReason; + this.SafetyRatings = safetyRatings; + this.LogprobsResult = logprobsResult; + this.UrlContextMetadata = urlContextMetadata; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CitationSource.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CitationSource.g.cs index 1b24d0a..d8025ec 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CitationSource.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CitationSource.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class CitationSource { - /// - /// Optional. Start of segment of the response that is attributed to this source. Index indicates the start of the segment, measured in bytes. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("startIndex")] - public int? StartIndex { get; set; } - /// /// Optional. End of the attributed segment, exclusive. /// @@ -26,6 +20,12 @@ public sealed partial class CitationSource [global::System.Text.Json.Serialization.JsonPropertyName("uri")] public string? Uri { get; set; } + /// + /// Optional. Start of segment of the response that is attributed to this source. Index indicates the start of the segment, measured in bytes. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("startIndex")] + public int? StartIndex { get; set; } + /// /// Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations. /// @@ -41,15 +41,15 @@ public sealed partial class CitationSource /// /// Initializes a new instance of the class. /// - /// - /// Optional. Start of segment of the response that is attributed to this source. Index indicates the start of the segment, measured in bytes. - /// /// /// Optional. End of the attributed segment, exclusive. /// /// /// Optional. URI that is attributed as a source for a portion of the text. /// + /// + /// Optional. Start of segment of the response that is attributed to this source. Index indicates the start of the segment, measured in bytes. + /// /// /// Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations. /// @@ -57,14 +57,14 @@ public sealed partial class CitationSource [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CitationSource( - int? startIndex, int? endIndex, string? uri, + int? startIndex, string? license) { - this.StartIndex = startIndex; this.EndIndex = endIndex; this.Uri = uri; + this.StartIndex = startIndex; this.License = license; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CodeExecutionResult.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CodeExecutionResult.g.cs index a004072..ed77a91 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CodeExecutionResult.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CodeExecutionResult.g.cs @@ -8,13 +8,6 @@ namespace Google.Gemini ///
public sealed partial class CodeExecutionResult { - /// - /// Required. Outcome of the code execution. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("outcome")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeJsonConverter))] - public global::Google.Gemini.CodeExecutionResultOutcome? Outcome { get; set; } - /// /// Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id. /// @@ -27,6 +20,13 @@ public sealed partial class CodeExecutionResult [global::System.Text.Json.Serialization.JsonPropertyName("output")] public string? Output { get; set; } + /// + /// Required. Outcome of the code execution. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("outcome")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeJsonConverter))] + public global::Google.Gemini.CodeExecutionResultOutcome? Outcome { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -36,26 +36,26 @@ public sealed partial class CodeExecutionResult /// /// Initializes a new instance of the class. /// - /// - /// Required. Outcome of the code execution. - /// /// /// Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id. /// /// /// Optional. Contains stdout when code execution is successful, stderr or other description otherwise. /// + /// + /// Required. Outcome of the code execution. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CodeExecutionResult( - global::Google.Gemini.CodeExecutionResultOutcome? outcome, string? id, - string? output) + string? output, + global::Google.Gemini.CodeExecutionResultOutcome? outcome) { - this.Outcome = outcome; this.Id = id; this.Output = output; + this.Outcome = outcome; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ComputerUse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ComputerUse.g.cs index ee37506..391e4a1 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ComputerUse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ComputerUse.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class ComputerUse { + /// + /// Optional. By default, predefined functions are included in the final model call. Some of them can be explicitly excluded from being automatically included. This can serve two purposes: 1. Using a more restricted / different action space. 2. Improving the definitions / instructions of predefined functions. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("excludedPredefinedFunctions")] + public global::System.Collections.Generic.IList? ExcludedPredefinedFunctions { get; set; } + /// /// Required. The environment being operated. /// @@ -15,12 +21,6 @@ public sealed partial class ComputerUse [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentJsonConverter))] public global::Google.Gemini.ComputerUseEnvironment? Environment { get; set; } - /// - /// Optional. By default, predefined functions are included in the final model call. Some of them can be explicitly excluded from being automatically included. This can serve two purposes: 1. Using a more restricted / different action space. 2. Improving the definitions / instructions of predefined functions. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("excludedPredefinedFunctions")] - public global::System.Collections.Generic.IList? ExcludedPredefinedFunctions { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,21 +30,21 @@ public sealed partial class ComputerUse /// /// Initializes a new instance of the class. /// - /// - /// Required. The environment being operated. - /// /// /// Optional. By default, predefined functions are included in the final model call. Some of them can be explicitly excluded from being automatically included. This can serve two purposes: 1. Using a more restricted / different action space. 2. Improving the definitions / instructions of predefined functions. /// + /// + /// Required. The environment being operated. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ComputerUse( - global::Google.Gemini.ComputerUseEnvironment? environment, - global::System.Collections.Generic.IList? excludedPredefinedFunctions) + global::System.Collections.Generic.IList? excludedPredefinedFunctions, + global::Google.Gemini.ComputerUseEnvironment? environment) { - this.Environment = environment; this.ExcludedPredefinedFunctions = excludedPredefinedFunctions; + this.Environment = environment; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Content.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Content.g.cs index 37c75a4..2c1f1be 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Content.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Content.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class Content { - /// - /// Ordered `Parts` that constitute a single message. Parts may have different MIME types. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("parts")] - public global::System.Collections.Generic.IList? Parts { get; set; } - /// /// Optional. The producer of the content. Must be either 'user' or 'model'. Useful to set for multi-turn conversations, otherwise can be left blank or unset. /// [global::System.Text.Json.Serialization.JsonPropertyName("role")] public string? Role { get; set; } + /// + /// Ordered `Parts` that constitute a single message. Parts may have different MIME types. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("parts")] + public global::System.Collections.Generic.IList? Parts { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class Content /// /// Initializes a new instance of the class. /// - /// - /// Ordered `Parts` that constitute a single message. Parts may have different MIME types. - /// /// /// Optional. The producer of the content. Must be either 'user' or 'model'. Useful to set for multi-turn conversations, otherwise can be left blank or unset. /// + /// + /// Ordered `Parts` that constitute a single message. Parts may have different MIME types. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Content( - global::System.Collections.Generic.IList? parts, - string? role) + string? role, + global::System.Collections.Generic.IList? parts) { - this.Parts = parts; this.Role = role; + this.Parts = parts; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Corpus.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Corpus.g.cs index 11fa487..b15c2f0 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Corpus.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Corpus.g.cs @@ -8,13 +8,6 @@ namespace Google.Gemini /// public sealed partial class Corpus { - /// - /// Output only. Immutable. Identifier. The `Corpus` resource name. The ID (name excluding the "corpora/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `corpora/my-awesome-corpora-123a456b789c`
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } - /// /// Optional. The human-readable display name for the `Corpus`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" /// @@ -22,18 +15,25 @@ public sealed partial class Corpus public string? DisplayName { get; set; } /// - /// Output only. The Timestamp of when the `Corpus` was last updated.
+ /// Output only. The Timestamp of when the `Corpus` was created.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } /// - /// Output only. The Timestamp of when the `Corpus` was created.
+ /// Output only. Immutable. Identifier. The `Corpus` resource name. The ID (name excluding the "corpora/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `corpora/my-awesome-corpora-123a456b789c`
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } + + /// + /// Output only. The Timestamp of when the `Corpus` was last updated.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -44,34 +44,34 @@ public sealed partial class Corpus /// /// Initializes a new instance of the class. /// + /// + /// Optional. The human-readable display name for the `Corpus`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" + /// + /// + /// Output only. The Timestamp of when the `Corpus` was created.
+ /// Included only in responses + /// /// /// Output only. Immutable. Identifier. The `Corpus` resource name. The ID (name excluding the "corpora/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `corpora/my-awesome-corpora-123a456b789c`
/// Included only in responses /// - /// - /// Optional. The human-readable display name for the `Corpus`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" - /// /// /// Output only. The Timestamp of when the `Corpus` was last updated.
/// Included only in responses /// - /// - /// Output only. The Timestamp of when the `Corpus` was created.
- /// Included only in responses - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Corpus( - string? name, string? displayName, - string? updateTime, - string? createTime) + string? createTime, + string? name, + string? updateTime) { - this.Name = name; this.DisplayName = displayName; - this.UpdateTime = updateTime; this.CreateTime = createTime; + this.Name = name; + this.UpdateTime = updateTime; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CountTokensResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CountTokensResponse.g.cs index ad3760e..387bd46 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CountTokensResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CountTokensResponse.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class CountTokensResponse { + /// + /// The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("totalTokens")] + public int? TotalTokens { get; set; } + /// /// Number of tokens in the cached part of the prompt (the cached content). /// @@ -28,12 +34,6 @@ public sealed partial class CountTokensResponse [global::System.Text.Json.Serialization.JsonPropertyName("cacheTokensDetails")] public global::System.Collections.Generic.IList? CacheTokensDetails { get; set; } - /// - /// The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("totalTokens")] - public int? TotalTokens { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -43,6 +43,9 @@ public sealed partial class CountTokensResponse /// /// Initializes a new instance of the class. /// + /// + /// The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative. + /// /// /// Number of tokens in the cached part of the prompt (the cached content). /// @@ -54,22 +57,19 @@ public sealed partial class CountTokensResponse /// Output only. List of modalities that were processed in the cached content.
/// Included only in responses /// - /// - /// The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CountTokensResponse( + int? totalTokens, int? cachedContentTokenCount, global::System.Collections.Generic.IList? promptTokensDetails, - global::System.Collections.Generic.IList? cacheTokensDetails, - int? totalTokens) + global::System.Collections.Generic.IList? cacheTokensDetails) { + this.TotalTokens = totalTokens; this.CachedContentTokenCount = cachedContentTokenCount; this.PromptTokensDetails = promptTokensDetails; this.CacheTokensDetails = cacheTokensDetails; - this.TotalTokens = totalTokens; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomLongRunningOperation.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomLongRunningOperation.g.cs index 355b4cd..166ebb5 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomLongRunningOperation.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomLongRunningOperation.g.cs @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class CustomLongRunningOperation { /// - /// If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available. + /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. /// - [global::System.Text.Json.Serialization.JsonPropertyName("done")] - public bool? Done { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] + public object? Metadata { get; set; } /// /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. @@ -20,12 +20,6 @@ public sealed partial class CustomLongRunningOperation [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("error")] - public global::Google.Gemini.Status? Error { get; set; } - /// /// The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. /// @@ -33,10 +27,16 @@ public sealed partial class CustomLongRunningOperation public object? Response { get; set; } /// - /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// - [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] - public object? Metadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("error")] + public global::Google.Gemini.Status? Error { get; set; } + + /// + /// If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("done")] + public bool? Done { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -47,36 +47,36 @@ public sealed partial class CustomLongRunningOperation /// /// Initializes a new instance of the class. /// - /// - /// If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available. + /// + /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. /// /// /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. /// - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). - /// /// /// The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. /// - /// - /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. + /// + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). + /// + /// + /// If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CustomLongRunningOperation( - bool? done, + object? metadata, string? name, - global::Google.Gemini.Status? error, object? response, - object? metadata) + global::Google.Gemini.Status? error, + bool? done) { - this.Done = done; + this.Metadata = metadata; this.Name = name; - this.Error = error; this.Response = response; - this.Metadata = metadata; + this.Error = error; + this.Done = done; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomMetadata.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomMetadata.g.cs index 7186c28..7daa08f 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomMetadata.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomMetadata.g.cs @@ -14,18 +14,18 @@ public sealed partial class CustomMetadata [global::System.Text.Json.Serialization.JsonPropertyName("stringValue")] public string? StringValue { get; set; } - /// - /// Required. The key of the metadata to store. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("key")] - public string? Key { get; set; } - /// /// The numeric value of the metadata to store. /// [global::System.Text.Json.Serialization.JsonPropertyName("numericValue")] public float? NumericValue { get; set; } + /// + /// Required. The key of the metadata to store. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("key")] + public string? Key { get; set; } + /// /// User provided string values assigned to a single metadata key. /// @@ -44,12 +44,12 @@ public sealed partial class CustomMetadata /// /// The string value of the metadata to store. /// - /// - /// Required. The key of the metadata to store. - /// /// /// The numeric value of the metadata to store. /// + /// + /// Required. The key of the metadata to store. + /// /// /// User provided string values assigned to a single metadata key. /// @@ -58,13 +58,13 @@ public sealed partial class CustomMetadata #endif public CustomMetadata( string? stringValue, - string? key, float? numericValue, + string? key, global::Google.Gemini.StringList? stringListValue) { this.StringValue = stringValue; - this.Key = key; this.NumericValue = numericValue; + this.Key = key; this.StringListValue = stringListValue; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Document.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Document.g.cs index 94e94f4..e8f1721 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Document.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Document.g.cs @@ -9,11 +9,17 @@ namespace Google.Gemini public sealed partial class Document { /// - /// Output only. The Timestamp of when the `Document` was last updated.
+ /// Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`. + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] + public global::System.Collections.Generic.IList? CustomMetadata { get; set; } + + /// + /// Output only. The Timestamp of when the `Document` was created.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } /// /// Output only. The mime type of the Document.
@@ -23,16 +29,19 @@ public sealed partial class Document public string? MimeType { get; set; } /// - /// Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`. + /// Output only. Current state of the `Document`.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] - public global::System.Collections.Generic.IList? CustomMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("state")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.DocumentStateJsonConverter))] + public global::Google.Gemini.DocumentState? State { get; set; } /// - /// Immutable. Identifier. The `Document` resource name. The ID (name excluding the "fileSearchStores/*/documents/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/{file_search_store_id}/documents/my-awesome-doc-123a456b789c` + /// Output only. The Timestamp of when the `Document` was last updated.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } /// /// Optional. The human-readable display name for the `Document`. The display name must be no more than 512 characters in length, including spaces. Example: "Semantic Retriever Documentation" @@ -40,14 +49,6 @@ public sealed partial class Document [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] public string? DisplayName { get; set; } - /// - /// Output only. Current state of the `Document`.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("state")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.DocumentStateJsonConverter))] - public global::Google.Gemini.DocumentState? State { get; set; } - /// /// Output only. The size of raw bytes ingested into the Document.
/// Included only in responses @@ -56,11 +57,10 @@ public sealed partial class Document public string? SizeBytes { get; set; } /// - /// Output only. The Timestamp of when the `Document` was created.
- /// Included only in responses + /// Immutable. Identifier. The `Document` resource name. The ID (name excluding the "fileSearchStores/*/documents/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/{file_search_store_id}/documents/my-awesome-doc-123a456b789c` ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -71,56 +71,56 @@ public sealed partial class Document /// /// Initializes a new instance of the class. /// - /// - /// Output only. The Timestamp of when the `Document` was last updated.
+ /// + /// Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`. + /// + /// + /// Output only. The Timestamp of when the `Document` was created.
/// Included only in responses /// /// /// Output only. The mime type of the Document.
/// Included only in responses /// - /// - /// Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`. + /// + /// Output only. Current state of the `Document`.
+ /// Included only in responses /// - /// - /// Immutable. Identifier. The `Document` resource name. The ID (name excluding the "fileSearchStores/*/documents/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/{file_search_store_id}/documents/my-awesome-doc-123a456b789c` + /// + /// Output only. The Timestamp of when the `Document` was last updated.
+ /// Included only in responses /// /// /// Optional. The human-readable display name for the `Document`. The display name must be no more than 512 characters in length, including spaces. Example: "Semantic Retriever Documentation" /// - /// - /// Output only. Current state of the `Document`.
- /// Included only in responses - /// /// /// Output only. The size of raw bytes ingested into the Document.
/// Included only in responses /// - /// - /// Output only. The Timestamp of when the `Document` was created.
- /// Included only in responses + /// + /// Immutable. Identifier. The `Document` resource name. The ID (name excluding the "fileSearchStores/*/documents/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/{file_search_store_id}/documents/my-awesome-doc-123a456b789c` /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Document( - string? updateTime, - string? mimeType, global::System.Collections.Generic.IList? customMetadata, - string? name, - string? displayName, + string? createTime, + string? mimeType, global::Google.Gemini.DocumentState? state, + string? updateTime, + string? displayName, string? sizeBytes, - string? createTime) + string? name) { - this.UpdateTime = updateTime; - this.MimeType = mimeType; this.CustomMetadata = customMetadata; - this.Name = name; - this.DisplayName = displayName; + this.CreateTime = createTime; + this.MimeType = mimeType; this.State = state; + this.UpdateTime = updateTime; + this.DisplayName = displayName; this.SizeBytes = sizeBytes; - this.CreateTime = createTime; + this.Name = name; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.DynamicRetrievalConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.DynamicRetrievalConfig.g.cs index 2646267..a57fba7 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.DynamicRetrievalConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.DynamicRetrievalConfig.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class DynamicRetrievalConfig { - /// - /// The threshold to be used in dynamic retrieval. If not set, a system default value is used. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("dynamicThreshold")] - public float? DynamicThreshold { get; set; } - /// /// The mode of the predictor to be used in dynamic retrieval. /// @@ -21,6 +15,12 @@ public sealed partial class DynamicRetrievalConfig [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeJsonConverter))] public global::Google.Gemini.DynamicRetrievalConfigMode? Mode { get; set; } + /// + /// The threshold to be used in dynamic retrieval. If not set, a system default value is used. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("dynamicThreshold")] + public float? DynamicThreshold { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,21 +30,21 @@ public sealed partial class DynamicRetrievalConfig /// /// Initializes a new instance of the class. /// - /// - /// The threshold to be used in dynamic retrieval. If not set, a system default value is used. - /// /// /// The mode of the predictor to be used in dynamic retrieval. /// + /// + /// The threshold to be used in dynamic retrieval. If not set, a system default value is used. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public DynamicRetrievalConfig( - float? dynamicThreshold, - global::Google.Gemini.DynamicRetrievalConfigMode? mode) + global::Google.Gemini.DynamicRetrievalConfigMode? mode, + float? dynamicThreshold) { - this.DynamicThreshold = dynamicThreshold; this.Mode = mode; + this.DynamicThreshold = dynamicThreshold; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatch.g.cs index 89f108c..cce77e6 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatch.g.cs @@ -9,17 +9,17 @@ namespace Google.Gemini public sealed partial class EmbedContentBatch { /// - /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
- /// Included only in responses + /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("output")] + public global::Google.Gemini.EmbedContentBatchOutput? Output { get; set; } /// - /// Required. The user-defined name of this batch. + /// Output only. The time at which the batch processing completed.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] + public string? EndTime { get; set; } /// /// Output only. The time at which the batch was created.
@@ -29,10 +29,12 @@ public sealed partial class EmbedContentBatch public string? CreateTime { get; set; } /// - /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. + /// Output only. The state of the batch.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("output")] - public global::Google.Gemini.EmbedContentBatchOutput? Output { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("state")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateJsonConverter))] + public global::Google.Gemini.EmbedContentBatchState? State { get; set; } /// /// Output only. The time at which the batch was last updated.
@@ -42,25 +44,10 @@ public sealed partial class EmbedContentBatch public string? UpdateTime { get; set; } /// - /// Output only. The time at which the batch processing completed.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] - public string? EndTime { get; set; } - - /// - /// Output only. The state of the batch.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("state")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateJsonConverter))] - public global::Google.Gemini.EmbedContentBatchState? State { get; set; } - - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// Required. The user-defined name of this batch. /// - [global::System.Text.Json.Serialization.JsonPropertyName("model")] - public string? Model { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// /// Configures the input to the batch request. @@ -74,6 +61,19 @@ public sealed partial class EmbedContentBatch [global::System.Text.Json.Serialization.JsonPropertyName("batchStats")] public global::Google.Gemini.EmbedContentBatchStats? BatchStats { get; set; } + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("model")] + public string? Model { get; set; } + + /// + /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } + /// /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// @@ -89,34 +89,27 @@ public sealed partial class EmbedContentBatch /// /// Initializes a new instance of the class. /// - /// - /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
- /// Included only in responses - /// - /// - /// Required. The user-defined name of this batch. - /// - /// - /// Output only. The time at which the batch was created.
- /// Included only in responses - /// /// /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. /// - /// - /// Output only. The time at which the batch was last updated.
- /// Included only in responses - /// /// /// Output only. The time at which the batch processing completed.
/// Included only in responses /// + /// + /// Output only. The time at which the batch was created.
+ /// Included only in responses + /// /// /// Output only. The state of the batch.
/// Included only in responses /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// Output only. The time at which the batch was last updated.
+ /// Included only in responses + /// + /// + /// Required. The user-defined name of this batch. /// /// /// Configures the input to the batch request. @@ -124,6 +117,13 @@ public sealed partial class EmbedContentBatch /// /// Stats about the batch. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
+ /// Included only in responses + /// /// /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// @@ -131,28 +131,28 @@ public sealed partial class EmbedContentBatch [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentBatch( - string? name, - string? displayName, - string? createTime, global::Google.Gemini.EmbedContentBatchOutput? output, - string? updateTime, string? endTime, + string? createTime, global::Google.Gemini.EmbedContentBatchState? state, - string? model, + string? updateTime, + string? displayName, global::Google.Gemini.InputEmbedContentConfig? inputConfig, global::Google.Gemini.EmbedContentBatchStats? batchStats, + string? model, + string? name, string? priority) { - this.Name = name; - this.DisplayName = displayName; - this.CreateTime = createTime; this.Output = output; - this.UpdateTime = updateTime; this.EndTime = endTime; + this.CreateTime = createTime; this.State = state; - this.Model = model; + this.UpdateTime = updateTime; + this.DisplayName = displayName; this.InputConfig = inputConfig; this.BatchStats = batchStats; + this.Model = model; + this.Name = name; this.Priority = priority; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatchOutput.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatchOutput.g.cs index 973d484..c7ac9b5 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatchOutput.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatchOutput.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini ///
public sealed partial class EmbedContentBatchOutput { - /// - /// The responses to the requests in the batch. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("inlinedResponses")] - public global::Google.Gemini.InlinedEmbedContentResponses? InlinedResponses { get; set; } - /// /// Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `EmbedContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests.
/// Included only in responses @@ -21,6 +15,12 @@ public sealed partial class EmbedContentBatchOutput [global::System.Text.Json.Serialization.JsonPropertyName("responsesFile")] public string? ResponsesFile { get; set; } + /// + /// The responses to the requests in the batch. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("inlinedResponses")] + public global::Google.Gemini.InlinedEmbedContentResponses? InlinedResponses { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,22 +30,22 @@ public sealed partial class EmbedContentBatchOutput /// /// Initializes a new instance of the class. /// - /// - /// The responses to the requests in the batch. - /// /// /// Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `EmbedContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests.
/// Included only in responses /// + /// + /// The responses to the requests in the batch. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentBatchOutput( - global::Google.Gemini.InlinedEmbedContentResponses? inlinedResponses, - string? responsesFile) + string? responsesFile, + global::Google.Gemini.InlinedEmbedContentResponses? inlinedResponses) { - this.InlinedResponses = inlinedResponses; this.ResponsesFile = responsesFile; + this.InlinedResponses = inlinedResponses; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatchStats.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatchStats.g.cs index 531be7a..5265822 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatchStats.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatchStats.g.cs @@ -9,18 +9,18 @@ namespace Google.Gemini public sealed partial class EmbedContentBatchStats { /// - /// Output only. The number of requests that are still pending processing.
+ /// Output only. The number of requests in the batch.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("pendingRequestCount")] - public string? PendingRequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("requestCount")] + public string? RequestCount { get; set; } /// - /// Output only. The number of requests in the batch.
+ /// Output only. The number of requests that failed to be processed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("requestCount")] - public string? RequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("failedRequestCount")] + public string? FailedRequestCount { get; set; } /// /// Output only. The number of requests that were successfully processed.
@@ -30,11 +30,11 @@ public sealed partial class EmbedContentBatchStats public string? SuccessfulRequestCount { get; set; } /// - /// Output only. The number of requests that failed to be processed.
+ /// Output only. The number of requests that are still pending processing.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("failedRequestCount")] - public string? FailedRequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("pendingRequestCount")] + public string? PendingRequestCount { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -45,35 +45,35 @@ public sealed partial class EmbedContentBatchStats /// /// Initializes a new instance of the class. /// - /// - /// Output only. The number of requests that are still pending processing.
- /// Included only in responses - /// /// /// Output only. The number of requests in the batch.
/// Included only in responses /// + /// + /// Output only. The number of requests that failed to be processed.
+ /// Included only in responses + /// /// /// Output only. The number of requests that were successfully processed.
/// Included only in responses /// - /// - /// Output only. The number of requests that failed to be processed.
+ /// + /// Output only. The number of requests that are still pending processing.
/// Included only in responses /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentBatchStats( - string? pendingRequestCount, string? requestCount, + string? failedRequestCount, string? successfulRequestCount, - string? failedRequestCount) + string? pendingRequestCount) { - this.PendingRequestCount = pendingRequestCount; this.RequestCount = requestCount; - this.SuccessfulRequestCount = successfulRequestCount; this.FailedRequestCount = failedRequestCount; + this.SuccessfulRequestCount = successfulRequestCount; + this.PendingRequestCount = pendingRequestCount; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentRequest.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentRequest.g.cs index 3757744..54a2f78 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentRequest.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentRequest.g.cs @@ -8,6 +8,18 @@ namespace Google.Gemini /// public sealed partial class EmbedContentRequest { + /// + /// Optional. Optional reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. Supported by newer models since 2024 only. You cannot set this value if using the earlier model (`models/embedding-001`). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("outputDimensionality")] + public int? OutputDimensionality { get; set; } + + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("content")] + public global::Google.Gemini.Content? Content { get; set; } + /// /// Optional. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`). /// @@ -21,18 +33,6 @@ public sealed partial class EmbedContentRequest [global::System.Text.Json.Serialization.JsonPropertyName("model")] public string? Model { get; set; } - /// - /// Optional. Optional reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. Supported by newer models since 2024 only. You cannot set this value if using the earlier model (`models/embedding-001`). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("outputDimensionality")] - public int? OutputDimensionality { get; set; } - - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("content")] - public global::Google.Gemini.Content? Content { get; set; } - /// /// Optional. An optional title for the text. Only applicable when TaskType is `RETRIEVAL_DOCUMENT`. Note: Specifying a `title` for `RETRIEVAL_DOCUMENT` provides better quality embeddings for retrieval. /// @@ -48,18 +48,18 @@ public sealed partial class EmbedContentRequest /// /// Initializes a new instance of the class. /// - /// - /// Optional. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`). - /// - /// - /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` - /// /// /// Optional. Optional reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. Supported by newer models since 2024 only. You cannot set this value if using the earlier model (`models/embedding-001`). /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// + /// + /// Optional. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`). + /// + /// + /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` + /// /// /// Optional. An optional title for the text. Only applicable when TaskType is `RETRIEVAL_DOCUMENT`. Note: Specifying a `title` for `RETRIEVAL_DOCUMENT` provides better quality embeddings for retrieval. /// @@ -67,16 +67,16 @@ public sealed partial class EmbedContentRequest [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentRequest( - global::Google.Gemini.EmbedContentRequestTaskType? taskType, - string? model, int? outputDimensionality, global::Google.Gemini.Content? content, + global::Google.Gemini.EmbedContentRequestTaskType? taskType, + string? model, string? title) { - this.TaskType = taskType; - this.Model = model; this.OutputDimensionality = outputDimensionality; this.Content = content; + this.TaskType = taskType; + this.Model = model; this.Title = title; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ExecutableCode.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ExecutableCode.g.cs index 1de5992..f9f4e11 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ExecutableCode.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ExecutableCode.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini ///
public sealed partial class ExecutableCode { + /// + /// Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("id")] + public string? Id { get; set; } + /// /// Required. Programming language of the `code`. /// @@ -21,12 +27,6 @@ public sealed partial class ExecutableCode [global::System.Text.Json.Serialization.JsonPropertyName("code")] public string? Code { get; set; } - /// - /// Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("id")] - public string? Id { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -36,26 +36,26 @@ public sealed partial class ExecutableCode /// /// Initializes a new instance of the class. /// + /// + /// Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`. + /// /// /// Required. Programming language of the `code`. /// /// /// Required. The code to be executed. /// - /// - /// Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ExecutableCode( + string? id, global::Google.Gemini.ExecutableCodeLanguage? language, - string? code, - string? id) + string? code) { + this.Id = id; this.Language = language; this.Code = code; - this.Id = id; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.File.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.File.g.cs index 8ba6309..2373ec5 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.File.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.File.g.cs @@ -9,17 +9,11 @@ namespace Google.Gemini public sealed partial class File { /// - /// Output only. MIME type of the file.
+ /// Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] - public string? MimeType { get; set; } - - /// - /// Metadata for a video `File`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("videoMetadata")] - public global::Google.Gemini.VideoFileMetadata? VideoMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("expirationTime")] + public string? ExpirationTime { get; set; } /// /// Output only. The timestamp of when the `File` was created.
@@ -29,24 +23,17 @@ public sealed partial class File public string? CreateTime { get; set; } /// - /// Output only. Size of the file in bytes.
+ /// Output only. The download uri of the `File`.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] - public string? SizeBytes { get; set; } - - /// - /// Source of the File. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("source")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FileSourceJsonConverter))] - public global::Google.Gemini.FileSource? Source { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("downloadUri")] + public string? DownloadUri { get; set; } /// - /// Optional. The human-readable display name for the `File`. The display name must be no more than 512 characters in length, including spaces. Example: "Welcome Image" + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("error")] + public global::Google.Gemini.Status? Error { get; set; } /// /// Immutable. Identifier. The `File` resource name. The ID (name excluding the "files/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be generated. Example: `files/123-456` @@ -55,24 +42,32 @@ public sealed partial class File public string? Name { get; set; } /// - /// Output only. The download uri of the `File`.
+ /// Optional. The human-readable display name for the `File`. The display name must be no more than 512 characters in length, including spaces. Example: "Welcome Image" + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } + + /// + /// Output only. SHA-256 hash of the uploaded bytes.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("downloadUri")] - public string? DownloadUri { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sha256Hash")] + public byte[]? Sha256Hash { get; set; } /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). + /// Output only. MIME type of the file.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("error")] - public global::Google.Gemini.Status? Error { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] + public string? MimeType { get; set; } /// - /// Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.
+ /// Output only. Processing state of the File.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("expirationTime")] - public string? ExpirationTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("state")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FileStateJsonConverter))] + public global::Google.Gemini.FileState? State { get; set; } /// /// Output only. The timestamp of when the `File` was last updated.
@@ -82,19 +77,24 @@ public sealed partial class File public string? UpdateTime { get; set; } /// - /// Output only. SHA-256 hash of the uploaded bytes.
+ /// Output only. Size of the file in bytes.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("sha256Hash")] - public byte[]? Sha256Hash { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] + public string? SizeBytes { get; set; } /// - /// Output only. Processing state of the File.
- /// Included only in responses + /// Source of the File. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("state")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FileStateJsonConverter))] - public global::Google.Gemini.FileState? State { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("source")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FileSourceJsonConverter))] + public global::Google.Gemini.FileSource? Source { get; set; } + + /// + /// Metadata for a video `File`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("videoMetadata")] + public global::Google.Gemini.VideoFileMetadata? VideoMetadata { get; set; } /// /// Output only. The uri of the `File`.
@@ -112,52 +112,52 @@ public sealed partial class File /// /// Initializes a new instance of the class. /// - /// - /// Output only. MIME type of the file.
+ /// + /// Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.
/// Included only in responses /// - /// - /// Metadata for a video `File`. - /// /// /// Output only. The timestamp of when the `File` was created.
/// Included only in responses /// - /// - /// Output only. Size of the file in bytes.
+ /// + /// Output only. The download uri of the `File`.
/// Included only in responses /// - /// - /// Source of the File. - /// - /// - /// Optional. The human-readable display name for the `File`. The display name must be no more than 512 characters in length, including spaces. Example: "Welcome Image" + /// + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// /// /// Immutable. Identifier. The `File` resource name. The ID (name excluding the "files/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be generated. Example: `files/123-456` /// - /// - /// Output only. The download uri of the `File`.
+ /// + /// Optional. The human-readable display name for the `File`. The display name must be no more than 512 characters in length, including spaces. Example: "Welcome Image" + /// + /// + /// Output only. SHA-256 hash of the uploaded bytes.
/// Included only in responses /// - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). + /// + /// Output only. MIME type of the file.
+ /// Included only in responses /// - /// - /// Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.
+ /// + /// Output only. Processing state of the File.
/// Included only in responses /// /// /// Output only. The timestamp of when the `File` was last updated.
/// Included only in responses /// - /// - /// Output only. SHA-256 hash of the uploaded bytes.
+ /// + /// Output only. Size of the file in bytes.
/// Included only in responses /// - /// - /// Output only. Processing state of the File.
- /// Included only in responses + /// + /// Source of the File. + /// + /// + /// Metadata for a video `File`. /// /// /// Output only. The uri of the `File`.
@@ -167,34 +167,34 @@ public sealed partial class File [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public File( - string? mimeType, - global::Google.Gemini.VideoFileMetadata? videoMetadata, + string? expirationTime, string? createTime, - string? sizeBytes, - global::Google.Gemini.FileSource? source, - string? displayName, - string? name, string? downloadUri, global::Google.Gemini.Status? error, - string? expirationTime, - string? updateTime, + string? name, + string? displayName, byte[]? sha256Hash, + string? mimeType, global::Google.Gemini.FileState? state, + string? updateTime, + string? sizeBytes, + global::Google.Gemini.FileSource? source, + global::Google.Gemini.VideoFileMetadata? videoMetadata, string? uri) { - this.MimeType = mimeType; - this.VideoMetadata = videoMetadata; + this.ExpirationTime = expirationTime; this.CreateTime = createTime; - this.SizeBytes = sizeBytes; - this.Source = source; - this.DisplayName = displayName; - this.Name = name; this.DownloadUri = downloadUri; this.Error = error; - this.ExpirationTime = expirationTime; - this.UpdateTime = updateTime; + this.Name = name; + this.DisplayName = displayName; this.Sha256Hash = sha256Hash; + this.MimeType = mimeType; this.State = state; + this.UpdateTime = updateTime; + this.SizeBytes = sizeBytes; + this.Source = source; + this.VideoMetadata = videoMetadata; this.Uri = uri; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileSearchStore.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileSearchStore.g.cs index b5fe72d..e1608f4 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileSearchStore.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileSearchStore.g.cs @@ -9,25 +9,18 @@ namespace Google.Gemini public sealed partial class FileSearchStore { /// - /// Output only. The number of documents in the `FileSearchStore` that have failed processing.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("failedDocumentsCount")] - public string? FailedDocumentsCount { get; set; } - - /// - /// Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.
+ /// Output only. Immutable. Identifier. The `FileSearchStore` resource name. It is an ID (name excluding the "fileSearchStores/" prefix) that can contain up to 40 characters that are lowercase alphanumeric or dashes (-). It is output only. The unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/my-awesome-file-search-store-123a456b789c` If `display_name` is not provided, the name will be randomly generated.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("activeDocumentsCount")] - public string? ActiveDocumentsCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// - /// Output only. The Timestamp of when the `FileSearchStore` was last updated.
+ /// Output only. The number of documents in the `FileSearchStore` that are being processed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("pendingDocumentsCount")] + public string? PendingDocumentsCount { get; set; } /// /// Output only. The size of raw bytes ingested into the `FileSearchStore`. This is the total size of all the documents in the `FileSearchStore`.
@@ -37,31 +30,38 @@ public sealed partial class FileSearchStore public string? SizeBytes { get; set; } /// - /// Output only. The Timestamp of when the `FileSearchStore` was created.
+ /// Output only. The number of documents in the `FileSearchStore` that have failed processing.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("failedDocumentsCount")] + public string? FailedDocumentsCount { get; set; } /// - /// Output only. Immutable. Identifier. The `FileSearchStore` resource name. It is an ID (name excluding the "fileSearchStores/" prefix) that can contain up to 40 characters that are lowercase alphanumeric or dashes (-). It is output only. The unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/my-awesome-file-search-store-123a456b789c` If `display_name` is not provided, the name will be randomly generated.
+ /// Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } + + /// + /// Output only. The Timestamp of when the `FileSearchStore` was last updated.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } /// - /// Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" + /// Output only. The Timestamp of when the `FileSearchStore` was created.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } /// - /// Output only. The number of documents in the `FileSearchStore` that are being processed.
+ /// Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("pendingDocumentsCount")] - public string? PendingDocumentsCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("activeDocumentsCount")] + public string? ActiveDocumentsCount { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -72,58 +72,58 @@ public sealed partial class FileSearchStore /// /// Initializes a new instance of the class. /// - /// - /// Output only. The number of documents in the `FileSearchStore` that have failed processing.
- /// Included only in responses - /// - /// - /// Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.
+ /// + /// Output only. Immutable. Identifier. The `FileSearchStore` resource name. It is an ID (name excluding the "fileSearchStores/" prefix) that can contain up to 40 characters that are lowercase alphanumeric or dashes (-). It is output only. The unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/my-awesome-file-search-store-123a456b789c` If `display_name` is not provided, the name will be randomly generated.
/// Included only in responses /// - /// - /// Output only. The Timestamp of when the `FileSearchStore` was last updated.
+ /// + /// Output only. The number of documents in the `FileSearchStore` that are being processed.
/// Included only in responses /// /// /// Output only. The size of raw bytes ingested into the `FileSearchStore`. This is the total size of all the documents in the `FileSearchStore`.
/// Included only in responses /// - /// - /// Output only. The Timestamp of when the `FileSearchStore` was created.
- /// Included only in responses - /// - /// - /// Output only. Immutable. Identifier. The `FileSearchStore` resource name. It is an ID (name excluding the "fileSearchStores/" prefix) that can contain up to 40 characters that are lowercase alphanumeric or dashes (-). It is output only. The unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/my-awesome-file-search-store-123a456b789c` If `display_name` is not provided, the name will be randomly generated.
+ /// + /// Output only. The number of documents in the `FileSearchStore` that have failed processing.
/// Included only in responses /// /// /// Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" /// - /// - /// Output only. The number of documents in the `FileSearchStore` that are being processed.
+ /// + /// Output only. The Timestamp of when the `FileSearchStore` was last updated.
+ /// Included only in responses + /// + /// + /// Output only. The Timestamp of when the `FileSearchStore` was created.
+ /// Included only in responses + /// + /// + /// Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.
/// Included only in responses /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FileSearchStore( + string? name, + string? pendingDocumentsCount, + string? sizeBytes, string? failedDocumentsCount, - string? activeDocumentsCount, + string? displayName, string? updateTime, - string? sizeBytes, string? createTime, - string? name, - string? displayName, - string? pendingDocumentsCount) + string? activeDocumentsCount) { + this.Name = name; + this.PendingDocumentsCount = pendingDocumentsCount; + this.SizeBytes = sizeBytes; this.FailedDocumentsCount = failedDocumentsCount; - this.ActiveDocumentsCount = activeDocumentsCount; + this.DisplayName = displayName; this.UpdateTime = updateTime; - this.SizeBytes = sizeBytes; this.CreateTime = createTime; - this.Name = name; - this.DisplayName = displayName; - this.PendingDocumentsCount = pendingDocumentsCount; + this.ActiveDocumentsCount = activeDocumentsCount; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionCall.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionCall.g.cs index d8965a5..e2ad38a 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionCall.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionCall.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class FunctionCall { - /// - /// Optional. Unique identifier of the function call. If populated, the client to execute the `function_call` and return the response with the matching `id`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("id")] - public string? Id { get; set; } - /// /// Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128. /// [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } + /// + /// Optional. Unique identifier of the function call. If populated, the client to execute the `function_call` and return the response with the matching `id`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("id")] + public string? Id { get; set; } + /// /// Optional. The function parameters and values in JSON object format. /// @@ -35,12 +35,12 @@ public sealed partial class FunctionCall /// /// Initializes a new instance of the class. /// - /// - /// Optional. Unique identifier of the function call. If populated, the client to execute the `function_call` and return the response with the matching `id`. - /// /// /// Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128. /// + /// + /// Optional. Unique identifier of the function call. If populated, the client to execute the `function_call` and return the response with the matching `id`. + /// /// /// Optional. The function parameters and values in JSON object format. /// @@ -48,12 +48,12 @@ public sealed partial class FunctionCall [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionCall( - string? id, string? name, + string? id, object? args) { - this.Id = id; this.Name = name; + this.Id = id; this.Args = args; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionDeclaration.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionDeclaration.g.cs index 32f229a..0707c31 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionDeclaration.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionDeclaration.g.cs @@ -9,22 +9,22 @@ namespace Google.Gemini public sealed partial class FunctionDeclaration { /// - /// Optional. Describes the parameters to the function in JSON Schema format. The schema must describe an object where the properties are the parameters to the function. For example: ``` { "type": "object", "properties": { "name": { "type": "string" }, "age": { "type": "integer" } }, "additionalProperties": false, "required": ["name", "age"], "propertyOrdering": ["name", "age"] } ``` This field is mutually exclusive with `parameters`. + /// Optional. Describes the output from this function in JSON Schema format. The value specified by the schema is the response value of the function. This field is mutually exclusive with `response`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("parametersJsonSchema")] - public object? ParametersJsonSchema { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseJsonSchema")] + public object? ResponseJsonSchema { get; set; } /// - /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). + /// Required. The name of the function. Must be a-z, A-Z, 0-9, or contain underscores, colons, dots, and dashes, with a maximum length of 128. /// - [global::System.Text.Json.Serialization.JsonPropertyName("parameters")] - public global::Google.Gemini.Schema? Parameters { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// - /// Optional. Describes the output from this function in JSON Schema format. The value specified by the schema is the response value of the function. This field is mutually exclusive with `response`. + /// Optional. Describes the parameters to the function in JSON Schema format. The schema must describe an object where the properties are the parameters to the function. For example: ``` { "type": "object", "properties": { "name": { "type": "string" }, "age": { "type": "integer" } }, "additionalProperties": false, "required": ["name", "age"], "propertyOrdering": ["name", "age"] } ``` This field is mutually exclusive with `parameters`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseJsonSchema")] - public object? ResponseJsonSchema { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("parametersJsonSchema")] + public object? ParametersJsonSchema { get; set; } /// /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). @@ -46,10 +46,10 @@ public sealed partial class FunctionDeclaration public global::Google.Gemini.FunctionDeclarationBehavior? Behavior { get; set; } /// - /// Required. The name of the function. Must be a-z, A-Z, 0-9, or contain underscores, colons, dots, and dashes, with a maximum length of 128. + /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). /// - [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("parameters")] + public global::Google.Gemini.Schema? Parameters { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -60,15 +60,15 @@ public sealed partial class FunctionDeclaration /// /// Initializes a new instance of the class. /// - /// - /// Optional. Describes the parameters to the function in JSON Schema format. The schema must describe an object where the properties are the parameters to the function. For example: ``` { "type": "object", "properties": { "name": { "type": "string" }, "age": { "type": "integer" } }, "additionalProperties": false, "required": ["name", "age"], "propertyOrdering": ["name", "age"] } ``` This field is mutually exclusive with `parameters`. - /// - /// - /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). - /// /// /// Optional. Describes the output from this function in JSON Schema format. The value specified by the schema is the response value of the function. This field is mutually exclusive with `response`. /// + /// + /// Required. The name of the function. Must be a-z, A-Z, 0-9, or contain underscores, colons, dots, and dashes, with a maximum length of 128. + /// + /// + /// Optional. Describes the parameters to the function in JSON Schema format. The schema must describe an object where the properties are the parameters to the function. For example: ``` { "type": "object", "properties": { "name": { "type": "string" }, "age": { "type": "integer" } }, "additionalProperties": false, "required": ["name", "age"], "propertyOrdering": ["name", "age"] } ``` This field is mutually exclusive with `parameters`. + /// /// /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). /// @@ -78,28 +78,28 @@ public sealed partial class FunctionDeclaration /// /// Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method. /// - /// - /// Required. The name of the function. Must be a-z, A-Z, 0-9, or contain underscores, colons, dots, and dashes, with a maximum length of 128. + /// + /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionDeclaration( - object? parametersJsonSchema, - global::Google.Gemini.Schema? parameters, object? responseJsonSchema, + string? name, + object? parametersJsonSchema, global::Google.Gemini.Schema? response, string? description, global::Google.Gemini.FunctionDeclarationBehavior? behavior, - string? name) + global::Google.Gemini.Schema? parameters) { - this.ParametersJsonSchema = parametersJsonSchema; - this.Parameters = parameters; this.ResponseJsonSchema = responseJsonSchema; + this.Name = name; + this.ParametersJsonSchema = parametersJsonSchema; this.Response = response; this.Description = description; this.Behavior = behavior; - this.Name = name; + this.Parameters = parameters; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponse.g.cs index c14ac79..7055601 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponse.g.cs @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class FunctionResponse { /// - /// Optional. Signals that function call continues, and more responses will be returned, turning the function call into a generator. Is only applicable to NON_BLOCKING function calls, is ignored otherwise. If set to false, future responses will not be considered. It is allowed to return empty `response` with `will_continue=False` to signal that the function call is finished. This may still trigger the model generation. To avoid triggering the generation and finish the function call, additionally set `scheduling` to `SILENT`. + /// Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("willContinue")] - public bool? WillContinue { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("id")] + public string? Id { get; set; } /// /// Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types. @@ -21,16 +21,10 @@ public sealed partial class FunctionResponse public global::System.Collections.Generic.IList? Parts { get; set; } /// - /// Required. The function response in JSON object format. Callers can use any keys of their choice that fit the function's syntax to return the function output, e.g. "output", "result", etc. In particular, if the function call failed to execute, the response can have an "error" key to return error details to the model. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("response")] - public object? Response { get; set; } - - /// - /// Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`. + /// Optional. Signals that function call continues, and more responses will be returned, turning the function call into a generator. Is only applicable to NON_BLOCKING function calls, is ignored otherwise. If set to false, future responses will not be considered. It is allowed to return empty `response` with `will_continue=False` to signal that the function call is finished. This may still trigger the model generation. To avoid triggering the generation and finish the function call, additionally set `scheduling` to `SILENT`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("id")] - public string? Id { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("willContinue")] + public bool? WillContinue { get; set; } /// /// Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128. @@ -45,6 +39,12 @@ public sealed partial class FunctionResponse [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingJsonConverter))] public global::Google.Gemini.FunctionResponseScheduling? Scheduling { get; set; } + /// + /// Required. The function response in JSON object format. Callers can use any keys of their choice that fit the function's syntax to return the function output, e.g. "output", "result", etc. In particular, if the function call failed to execute, the response can have an "error" key to return error details to the model. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("response")] + public object? Response { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -54,17 +54,14 @@ public sealed partial class FunctionResponse /// /// Initializes a new instance of the class. /// - /// - /// Optional. Signals that function call continues, and more responses will be returned, turning the function call into a generator. Is only applicable to NON_BLOCKING function calls, is ignored otherwise. If set to false, future responses will not be considered. It is allowed to return empty `response` with `will_continue=False` to signal that the function call is finished. This may still trigger the model generation. To avoid triggering the generation and finish the function call, additionally set `scheduling` to `SILENT`. + /// + /// Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`. /// /// /// Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types. /// - /// - /// Required. The function response in JSON object format. Callers can use any keys of their choice that fit the function's syntax to return the function output, e.g. "output", "result", etc. In particular, if the function call failed to execute, the response can have an "error" key to return error details to the model. - /// - /// - /// Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`. + /// + /// Optional. Signals that function call continues, and more responses will be returned, turning the function call into a generator. Is only applicable to NON_BLOCKING function calls, is ignored otherwise. If set to false, future responses will not be considered. It is allowed to return empty `response` with `will_continue=False` to signal that the function call is finished. This may still trigger the model generation. To avoid triggering the generation and finish the function call, additionally set `scheduling` to `SILENT`. /// /// /// Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128. @@ -72,23 +69,26 @@ public sealed partial class FunctionResponse /// /// Optional. Specifies how the response should be scheduled in the conversation. Only applicable to NON_BLOCKING function calls, is ignored otherwise. Defaults to WHEN_IDLE. /// + /// + /// Required. The function response in JSON object format. Callers can use any keys of their choice that fit the function's syntax to return the function output, e.g. "output", "result", etc. In particular, if the function call failed to execute, the response can have an "error" key to return error details to the model. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionResponse( - bool? willContinue, - global::System.Collections.Generic.IList? parts, - object? response, string? id, + global::System.Collections.Generic.IList? parts, + bool? willContinue, string? name, - global::Google.Gemini.FunctionResponseScheduling? scheduling) + global::Google.Gemini.FunctionResponseScheduling? scheduling, + object? response) { - this.WillContinue = willContinue; - this.Parts = parts; - this.Response = response; this.Id = id; + this.Parts = parts; + this.WillContinue = willContinue; this.Name = name; this.Scheduling = scheduling; + this.Response = response; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponseBlob.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponseBlob.g.cs index d727aa3..68b61c6 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponseBlob.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponseBlob.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class FunctionResponseBlob { - /// - /// Raw bytes for media formats. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("data")] - public byte[]? Data { get; set; } - /// /// The IANA standard MIME type of the source data. Examples: - image/png - image/jpeg If an unsupported MIME type is provided, an error will be returned. For a complete list of supported types, see [Supported file formats](https://ai.google.dev/gemini-api/docs/prompting_with_media#supported_file_formats). /// [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] public string? MimeType { get; set; } + /// + /// Raw bytes for media formats. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("data")] + public byte[]? Data { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class FunctionResponseBlob /// /// Initializes a new instance of the class. /// - /// - /// Raw bytes for media formats. - /// /// /// The IANA standard MIME type of the source data. Examples: - image/png - image/jpeg If an unsupported MIME type is provided, an error will be returned. For a complete list of supported types, see [Supported file formats](https://ai.google.dev/gemini-api/docs/prompting_with_media#supported_file_formats). /// + /// + /// Raw bytes for media formats. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionResponseBlob( - byte[]? data, - string? mimeType) + string? mimeType, + byte[]? data) { - this.Data = data; this.MimeType = mimeType; + this.Data = data; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatch.g.cs index 4fbeb48..412b432 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatch.g.cs @@ -15,38 +15,42 @@ public sealed partial class GenerateContentBatch public string? DisplayName { get; set; } /// - /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
- /// Included only in responses + /// Configures the input to the batch request. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("inputConfig")] + public global::Google.Gemini.InputConfig? InputConfig { get; set; } /// - /// Output only. The time at which the batch was created.
- /// Included only in responses + /// Stats about the batch. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("batchStats")] + public global::Google.Gemini.BatchStats? BatchStats { get; set; } /// - /// Output only. The time at which the batch was last updated.
+ /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("model")] + public string? Model { get; set; } + + /// + /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// - /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// - [global::System.Text.Json.Serialization.JsonPropertyName("output")] - public global::Google.Gemini.GenerateContentBatchOutput? Output { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("priority")] + public string? Priority { get; set; } /// - /// Output only. The time at which the batch processing completed.
+ /// Output only. The time at which the batch was created.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] - public string? EndTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } /// /// Output only. The state of the batch.
@@ -57,28 +61,24 @@ public sealed partial class GenerateContentBatch public global::Google.Gemini.GenerateContentBatchState? State { get; set; } /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("model")] - public string? Model { get; set; } - - /// - /// Configures the input to the batch request. + /// Output only. The time at which the batch was last updated.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("inputConfig")] - public global::Google.Gemini.InputConfig? InputConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } /// - /// Stats about the batch. + /// Output only. The time at which the batch processing completed.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("batchStats")] - public global::Google.Gemini.BatchStats? BatchStats { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] + public string? EndTime { get; set; } /// - /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. + /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. /// - [global::System.Text.Json.Serialization.JsonPropertyName("priority")] - public string? Priority { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("output")] + public global::Google.Gemini.GenerateContentBatchOutput? Output { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -92,68 +92,68 @@ public sealed partial class GenerateContentBatch /// /// Required. The user-defined name of this batch. /// + /// + /// Configures the input to the batch request. + /// + /// + /// Stats about the batch. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// /// /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
/// Included only in responses /// + /// + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. + /// /// /// Output only. The time at which the batch was created.
/// Included only in responses /// + /// + /// Output only. The state of the batch.
+ /// Included only in responses + /// /// /// Output only. The time at which the batch was last updated.
/// Included only in responses /// - /// - /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. - /// /// /// Output only. The time at which the batch processing completed.
/// Included only in responses /// - /// - /// Output only. The state of the batch.
- /// Included only in responses - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Configures the input to the batch request. - /// - /// - /// Stats about the batch. - /// - /// - /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. + /// + /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerateContentBatch( string? displayName, + global::Google.Gemini.InputConfig? inputConfig, + global::Google.Gemini.BatchStats? batchStats, + string? model, string? name, + string? priority, string? createTime, + global::Google.Gemini.GenerateContentBatchState? state, string? updateTime, - global::Google.Gemini.GenerateContentBatchOutput? output, string? endTime, - global::Google.Gemini.GenerateContentBatchState? state, - string? model, - global::Google.Gemini.InputConfig? inputConfig, - global::Google.Gemini.BatchStats? batchStats, - string? priority) + global::Google.Gemini.GenerateContentBatchOutput? output) { this.DisplayName = displayName; + this.InputConfig = inputConfig; + this.BatchStats = batchStats; + this.Model = model; this.Name = name; + this.Priority = priority; this.CreateTime = createTime; + this.State = state; this.UpdateTime = updateTime; - this.Output = output; this.EndTime = endTime; - this.State = state; - this.Model = model; - this.InputConfig = inputConfig; - this.BatchStats = batchStats; - this.Priority = priority; + this.Output = output; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentRequest.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentRequest.g.cs index d390c63..7b6a116 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentRequest.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentRequest.g.cs @@ -8,24 +8,6 @@ namespace Google.Gemini /// public sealed partial class GenerateContentRequest { - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("store")] - public bool? Store { get; set; } - - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("systemInstruction")] - public global::Google.Gemini.Content? SystemInstruction { get; set; } - - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("contents")] - public global::System.Collections.Generic.IList? Contents { get; set; } - /// /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// @@ -33,16 +15,22 @@ public sealed partial class GenerateContentRequest public string? CachedContent { get; set; } /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - [global::System.Text.Json.Serialization.JsonPropertyName("model")] - public string? Model { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("toolConfig")] + public global::Google.Gemini.ToolConfig? ToolConfig { get; set; } /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// - [global::System.Text.Json.Serialization.JsonPropertyName("tools")] - public global::System.Collections.Generic.IList? Tools { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("systemInstruction")] + public global::Google.Gemini.Content? SystemInstruction { get; set; } + + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("store")] + public bool? Store { get; set; } /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. @@ -58,10 +46,22 @@ public sealed partial class GenerateContentRequest public global::Google.Gemini.GenerateContentRequestServiceTier? ServiceTier { get; set; } /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. /// - [global::System.Text.Json.Serialization.JsonPropertyName("toolConfig")] - public global::Google.Gemini.ToolConfig? ToolConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("contents")] + public global::System.Collections.Generic.IList? Contents { get; set; } + + /// + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("tools")] + public global::System.Collections.Generic.IList? Tools { get; set; } + + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("model")] + public string? Model { get; set; } /// /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. @@ -78,23 +78,17 @@ public sealed partial class GenerateContentRequest /// /// Initializes a new instance of the class. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. - /// /// /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. @@ -102,8 +96,14 @@ public sealed partial class GenerateContentRequest /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. @@ -112,26 +112,26 @@ public sealed partial class GenerateContentRequest [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerateContentRequest( - bool? store, - global::Google.Gemini.Content? systemInstruction, - global::System.Collections.Generic.IList? contents, string? cachedContent, - string? model, - global::System.Collections.Generic.IList? tools, + global::Google.Gemini.ToolConfig? toolConfig, + global::Google.Gemini.Content? systemInstruction, + bool? store, global::Google.Gemini.GenerationConfig? generationConfig, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier, - global::Google.Gemini.ToolConfig? toolConfig, + global::System.Collections.Generic.IList? contents, + global::System.Collections.Generic.IList? tools, + string? model, global::System.Collections.Generic.IList? safetySettings) { - this.Store = store; - this.SystemInstruction = systemInstruction; - this.Contents = contents; this.CachedContent = cachedContent; - this.Model = model; - this.Tools = tools; + this.ToolConfig = toolConfig; + this.SystemInstruction = systemInstruction; + this.Store = store; this.GenerationConfig = generationConfig; this.ServiceTier = serviceTier; - this.ToolConfig = toolConfig; + this.Contents = contents; + this.Tools = tools; + this.Model = model; this.SafetySettings = safetySettings; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentResponse.g.cs index 65b37e4..7a6b88e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentResponse.g.cs @@ -15,10 +15,11 @@ public sealed partial class GenerateContentResponse public global::Google.Gemini.UsageMetadata? UsageMetadata { get; set; } /// - /// The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable. + /// Output only. response_id is used to identify each response.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("modelStatus")] - public global::Google.Gemini.ModelStatus? ModelStatus { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseId")] + public string? ResponseId { get; set; } /// /// Output only. The model version used to generate the response.
@@ -27,12 +28,6 @@ public sealed partial class GenerateContentResponse [global::System.Text.Json.Serialization.JsonPropertyName("modelVersion")] public string? ModelVersion { get; set; } - /// - /// Candidate responses from the model. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("candidates")] - public global::System.Collections.Generic.IList? Candidates { get; set; } - /// /// A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`. /// @@ -40,11 +35,16 @@ public sealed partial class GenerateContentResponse public global::Google.Gemini.PromptFeedback? PromptFeedback { get; set; } /// - /// Output only. response_id is used to identify each response.
- /// Included only in responses + /// Candidate responses from the model. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("responseId")] - public string? ResponseId { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("candidates")] + public global::System.Collections.Generic.IList? Candidates { get; set; } + + /// + /// The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("modelStatus")] + public global::Google.Gemini.ModelStatus? ModelStatus { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -58,40 +58,40 @@ public sealed partial class GenerateContentResponse /// /// Metadata on the generation request's token usage. /// - /// - /// The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable. + /// + /// Output only. response_id is used to identify each response.
+ /// Included only in responses /// /// /// Output only. The model version used to generate the response.
/// Included only in responses /// - /// - /// Candidate responses from the model. - /// /// /// A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`. /// - /// - /// Output only. response_id is used to identify each response.
- /// Included only in responses + /// + /// Candidate responses from the model. + /// + /// + /// The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerateContentResponse( global::Google.Gemini.UsageMetadata? usageMetadata, - global::Google.Gemini.ModelStatus? modelStatus, + string? responseId, string? modelVersion, - global::System.Collections.Generic.IList? candidates, global::Google.Gemini.PromptFeedback? promptFeedback, - string? responseId) + global::System.Collections.Generic.IList? candidates, + global::Google.Gemini.ModelStatus? modelStatus) { this.UsageMetadata = usageMetadata; - this.ModelStatus = modelStatus; + this.ResponseId = responseId; this.ModelVersion = modelVersion; - this.Candidates = candidates; this.PromptFeedback = promptFeedback; - this.ResponseId = responseId; + this.Candidates = candidates; + this.ModelStatus = modelStatus; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GeneratedFile.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GeneratedFile.g.cs index 57e471a..f6b2502 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GeneratedFile.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GeneratedFile.g.cs @@ -8,18 +8,6 @@ namespace Google.Gemini /// public sealed partial class GeneratedFile { - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("error")] - public global::Google.Gemini.Status? Error { get; set; } - - /// - /// MIME type of the generatedFile. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] - public string? MimeType { get; set; } - /// /// Output only. The state of the GeneratedFile.
/// Included only in responses @@ -34,6 +22,18 @@ public sealed partial class GeneratedFile [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } + /// + /// MIME type of the generatedFile. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] + public string? MimeType { get; set; } + + /// + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("error")] + public global::Google.Gemini.Status? Error { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -43,12 +43,6 @@ public sealed partial class GeneratedFile /// /// Initializes a new instance of the class. /// - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). - /// - /// - /// MIME type of the generatedFile. - /// /// /// Output only. The state of the GeneratedFile.
/// Included only in responses @@ -56,19 +50,25 @@ public sealed partial class GeneratedFile /// /// Identifier. The name of the generated file. Example: `generatedFiles/abc-123` /// + /// + /// MIME type of the generatedFile. + /// + /// + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GeneratedFile( - global::Google.Gemini.Status? error, - string? mimeType, global::Google.Gemini.GeneratedFileState? state, - string? name) + string? name, + string? mimeType, + global::Google.Gemini.Status? error) { - this.Error = error; - this.MimeType = mimeType; this.State = state; this.Name = name; + this.MimeType = mimeType; + this.Error = error; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerationConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerationConfig.g.cs index 9095741..53e62cc 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerationConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerationConfig.g.cs @@ -8,25 +8,6 @@ namespace Google.Gemini /// public sealed partial class GenerationConfig { - /// - /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseSchema")] - public global::Google.Gemini.Schema? ResponseSchema { get; set; } - - /// - /// Optional. If specified, the media resolution specified will be used. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("mediaResolution")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionJsonConverter))] - public global::Google.Gemini.GenerationConfigMediaResolution? MediaResolution { get; set; } - - /// - /// Optional. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("frequencyPenalty")] - public float? FrequencyPenalty { get; set; } - /// /// Optional. If true, export the logprobs results in response. /// @@ -40,22 +21,16 @@ public sealed partial class GenerationConfig public global::System.Collections.Generic.IList? ResponseModalities { get; set; } /// - /// Optional. MIME type of the generated candidate text. Supported MIME types are: `text/plain`: (default) Text output. `application/json`: JSON response in the response candidates. `text/x.enum`: ENUM as a string response in the response candidates. Refer to the [docs](https://ai.google.dev/gemini-api/docs/prompting_with_media#plain_text_formats) for a list of all supported text MIME types. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseMimeType")] - public string? ResponseMimeType { get; set; } - - /// - /// Optional. Presence penalty applied to the next token's logprobs if the token has already been seen in the response. This penalty is binary on/off and not dependant on the number of times the token is used (after the first). Use frequency_penalty for a penalty that increases with each use. A positive penalty will discourage the use of tokens that have already been used in the response, increasing the vocabulary. A negative penalty will encourage the use of tokens that have already been used in the response, decreasing the vocabulary. + /// Config for thinking features. /// - [global::System.Text.Json.Serialization.JsonPropertyName("presencePenalty")] - public float? PresencePenalty { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("thinkingConfig")] + public global::Google.Gemini.ThinkingConfig? ThinkingConfig { get; set; } /// - /// Optional. The set of character sequences (up to 5) that will stop output generation. If specified, the API will stop at the first appearance of a `stop_sequence`. The stop sequence will not be included as part of the response. + /// Optional. Controls the randomness of the output. Note: The default value varies by model, see the `Model.temperature` attribute of the `Model` returned from the `getModel` function. Values can range from [0.0, 2.0]. /// - [global::System.Text.Json.Serialization.JsonPropertyName("stopSequences")] - public global::System.Collections.Generic.IList? StopSequences { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] + public float? Temperature { get; set; } /// /// Optional. Seed used in decoding. If not set, the request uses a randomly generated seed. @@ -70,16 +45,22 @@ public sealed partial class GenerationConfig public bool? EnableEnhancedCivicAnswers { get; set; } /// - /// Optional. Controls the randomness of the output. Note: The default value varies by model, see the `Model.temperature` attribute of the `Model` returned from the `getModel` function. Values can range from [0.0, 2.0]. + /// Optional. The maximum number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests. /// - [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] - public float? Temperature { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topK")] + public int? TopK { get; set; } /// - /// Config for speech generation and transcription. + /// Optional. An internal detail. Use `responseJsonSchema` rather than this field. /// - [global::System.Text.Json.Serialization.JsonPropertyName("speechConfig")] - public global::Google.Gemini.SpeechConfig? SpeechConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseJsonSchema")] + public object? ResponseJsonSchema { get; set; } + + /// + /// Optional. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("frequencyPenalty")] + public float? FrequencyPenalty { get; set; } /// /// Optional. The maximum cumulative probability of tokens to consider when sampling. The model uses combined Top-k and Top-p (nucleus) sampling. Tokens are sorted based on their assigned probabilities so that only the most likely tokens are considered. Top-k sampling directly limits the maximum number of tokens to consider, while Nucleus sampling limits the number of tokens based on the cumulative probability. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests. @@ -87,6 +68,31 @@ public sealed partial class GenerationConfig [global::System.Text.Json.Serialization.JsonPropertyName("topP")] public float? TopP { get; set; } + /// + /// Optional. If specified, the media resolution specified will be used. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("mediaResolution")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionJsonConverter))] + public global::Google.Gemini.GenerationConfigMediaResolution? MediaResolution { get; set; } + + /// + /// Config for speech generation and transcription. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("speechConfig")] + public global::Google.Gemini.SpeechConfig? SpeechConfig { get; set; } + + /// + /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("responseSchema")] + public global::Google.Gemini.Schema? ResponseSchema { get; set; } + + /// + /// Optional. Presence penalty applied to the next token's logprobs if the token has already been seen in the response. This penalty is binary on/off and not dependant on the number of times the token is used (after the first). Use frequency_penalty for a penalty that increases with each use. A positive penalty will discourage the use of tokens that have already been used in the response, increasing the vocabulary. A negative penalty will encourage the use of tokens that have already been used in the response, decreasing the vocabulary. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("presencePenalty")] + public float? PresencePenalty { get; set; } + /// /// Optional. Number of generated responses to return. If unset, this will default to 1. Please note that this doesn't work for previous generation models (Gemini 1.0 family) /// @@ -94,10 +100,10 @@ public sealed partial class GenerationConfig public int? CandidateCount { get; set; } /// - /// Optional. An internal detail. Use `responseJsonSchema` rather than this field. + /// Optional. MIME type of the generated candidate text. Supported MIME types are: `text/plain`: (default) Text output. `application/json`: JSON response in the response candidates. `text/x.enum`: ENUM as a string response in the response candidates. Refer to the [docs](https://ai.google.dev/gemini-api/docs/prompting_with_media#plain_text_formats) for a list of all supported text MIME types. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseJsonSchema")] - public object? ResponseJsonSchema { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseMimeType")] + public string? ResponseMimeType { get; set; } /// /// Config for image generation features. @@ -106,16 +112,16 @@ public sealed partial class GenerationConfig public global::Google.Gemini.ImageConfig? ImageConfig { get; set; } /// - /// Optional. Only valid if response_logprobs=True. This sets the number of top logprobs, including the chosen candidate, to return at each decoding step in the Candidate.logprobs_result. The number must be in the range of [0, 20]. + /// Optional. The set of character sequences (up to 5) that will stop output generation. If specified, the API will stop at the first appearance of a `stop_sequence`. The stop sequence will not be included as part of the response. /// - [global::System.Text.Json.Serialization.JsonPropertyName("logprobs")] - public int? Logprobs { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("stopSequences")] + public global::System.Collections.Generic.IList? StopSequences { get; set; } /// - /// Optional. The maximum number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests. + /// Optional. Only valid if response_logprobs=True. This sets the number of top logprobs, including the chosen candidate, to return at each decoding step in the Candidate.logprobs_result. The number must be in the range of [0, 20]. /// - [global::System.Text.Json.Serialization.JsonPropertyName("topK")] - public int? TopK { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("logprobs")] + public int? Logprobs { get; set; } /// /// Optional. The maximum number of tokens to include in a response candidate. Note: The default value varies by model, see the `Model.output_token_limit` attribute of the `Model` returned from the `getModel` function. @@ -123,12 +129,6 @@ public sealed partial class GenerationConfig [global::System.Text.Json.Serialization.JsonPropertyName("maxOutputTokens")] public int? MaxOutputTokens { get; set; } - /// - /// Config for thinking features. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("thinkingConfig")] - public global::Google.Gemini.ThinkingConfig? ThinkingConfig { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -138,29 +138,17 @@ public sealed partial class GenerationConfig /// /// Initializes a new instance of the class. /// - /// - /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). - /// - /// - /// Optional. If specified, the media resolution specified will be used. - /// - /// - /// Optional. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit. - /// /// /// Optional. If true, export the logprobs results in response. /// /// /// Optional. The requested modalities of the response. Represents the set of modalities that the model can return, and should be expected in the response. This is an exact match to the modalities of the response. A model may have multiple combinations of supported modalities. If the requested modalities do not match any of the supported combinations, an error will be returned. An empty list is equivalent to requesting only text. /// - /// - /// Optional. MIME type of the generated candidate text. Supported MIME types are: `text/plain`: (default) Text output. `application/json`: JSON response in the response candidates. `text/x.enum`: ENUM as a string response in the response candidates. Refer to the [docs](https://ai.google.dev/gemini-api/docs/prompting_with_media#plain_text_formats) for a list of all supported text MIME types. - /// - /// - /// Optional. Presence penalty applied to the next token's logprobs if the token has already been seen in the response. This penalty is binary on/off and not dependant on the number of times the token is used (after the first). Use frequency_penalty for a penalty that increases with each use. A positive penalty will discourage the use of tokens that have already been used in the response, increasing the vocabulary. A negative penalty will encourage the use of tokens that have already been used in the response, decreasing the vocabulary. + /// + /// Config for thinking features. /// - /// - /// Optional. The set of character sequences (up to 5) that will stop output generation. If specified, the API will stop at the first appearance of a `stop_sequence`. The stop sequence will not be included as part of the response. + /// + /// Optional. Controls the randomness of the output. Note: The default value varies by model, see the `Model.temperature` attribute of the `Model` returned from the `getModel` function. Values can range from [0.0, 2.0]. /// /// /// Optional. Seed used in decoding. If not set, the request uses a randomly generated seed. @@ -168,81 +156,93 @@ public sealed partial class GenerationConfig /// /// Optional. Enables enhanced civic answers. It may not be available for all models. /// - /// - /// Optional. Controls the randomness of the output. Note: The default value varies by model, see the `Model.temperature` attribute of the `Model` returned from the `getModel` function. Values can range from [0.0, 2.0]. + /// + /// Optional. The maximum number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests. /// - /// - /// Config for speech generation and transcription. + /// + /// Optional. An internal detail. Use `responseJsonSchema` rather than this field. + /// + /// + /// Optional. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit. /// /// /// Optional. The maximum cumulative probability of tokens to consider when sampling. The model uses combined Top-k and Top-p (nucleus) sampling. Tokens are sorted based on their assigned probabilities so that only the most likely tokens are considered. Top-k sampling directly limits the maximum number of tokens to consider, while Nucleus sampling limits the number of tokens based on the cumulative probability. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests. /// + /// + /// Optional. If specified, the media resolution specified will be used. + /// + /// + /// Config for speech generation and transcription. + /// + /// + /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). + /// + /// + /// Optional. Presence penalty applied to the next token's logprobs if the token has already been seen in the response. This penalty is binary on/off and not dependant on the number of times the token is used (after the first). Use frequency_penalty for a penalty that increases with each use. A positive penalty will discourage the use of tokens that have already been used in the response, increasing the vocabulary. A negative penalty will encourage the use of tokens that have already been used in the response, decreasing the vocabulary. + /// /// /// Optional. Number of generated responses to return. If unset, this will default to 1. Please note that this doesn't work for previous generation models (Gemini 1.0 family) /// - /// - /// Optional. An internal detail. Use `responseJsonSchema` rather than this field. + /// + /// Optional. MIME type of the generated candidate text. Supported MIME types are: `text/plain`: (default) Text output. `application/json`: JSON response in the response candidates. `text/x.enum`: ENUM as a string response in the response candidates. Refer to the [docs](https://ai.google.dev/gemini-api/docs/prompting_with_media#plain_text_formats) for a list of all supported text MIME types. /// /// /// Config for image generation features. /// + /// + /// Optional. The set of character sequences (up to 5) that will stop output generation. If specified, the API will stop at the first appearance of a `stop_sequence`. The stop sequence will not be included as part of the response. + /// /// /// Optional. Only valid if response_logprobs=True. This sets the number of top logprobs, including the chosen candidate, to return at each decoding step in the Candidate.logprobs_result. The number must be in the range of [0, 20]. /// - /// - /// Optional. The maximum number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests. - /// /// /// Optional. The maximum number of tokens to include in a response candidate. Note: The default value varies by model, see the `Model.output_token_limit` attribute of the `Model` returned from the `getModel` function. /// - /// - /// Config for thinking features. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerationConfig( - global::Google.Gemini.Schema? responseSchema, - global::Google.Gemini.GenerationConfigMediaResolution? mediaResolution, - float? frequencyPenalty, bool? responseLogprobs, global::System.Collections.Generic.IList? responseModalities, - string? responseMimeType, - float? presencePenalty, - global::System.Collections.Generic.IList? stopSequences, + global::Google.Gemini.ThinkingConfig? thinkingConfig, + float? temperature, int? seed, bool? enableEnhancedCivicAnswers, - float? temperature, - global::Google.Gemini.SpeechConfig? speechConfig, + int? topK, + object? responseJsonSchema, + float? frequencyPenalty, float? topP, + global::Google.Gemini.GenerationConfigMediaResolution? mediaResolution, + global::Google.Gemini.SpeechConfig? speechConfig, + global::Google.Gemini.Schema? responseSchema, + float? presencePenalty, int? candidateCount, - object? responseJsonSchema, + string? responseMimeType, global::Google.Gemini.ImageConfig? imageConfig, + global::System.Collections.Generic.IList? stopSequences, int? logprobs, - int? topK, - int? maxOutputTokens, - global::Google.Gemini.ThinkingConfig? thinkingConfig) + int? maxOutputTokens) { - this.ResponseSchema = responseSchema; - this.MediaResolution = mediaResolution; - this.FrequencyPenalty = frequencyPenalty; this.ResponseLogprobs = responseLogprobs; this.ResponseModalities = responseModalities; - this.ResponseMimeType = responseMimeType; - this.PresencePenalty = presencePenalty; - this.StopSequences = stopSequences; + this.ThinkingConfig = thinkingConfig; + this.Temperature = temperature; this.Seed = seed; this.EnableEnhancedCivicAnswers = enableEnhancedCivicAnswers; - this.Temperature = temperature; - this.SpeechConfig = speechConfig; + this.TopK = topK; + this.ResponseJsonSchema = responseJsonSchema; + this.FrequencyPenalty = frequencyPenalty; this.TopP = topP; + this.MediaResolution = mediaResolution; + this.SpeechConfig = speechConfig; + this.ResponseSchema = responseSchema; + this.PresencePenalty = presencePenalty; this.CandidateCount = candidateCount; - this.ResponseJsonSchema = responseJsonSchema; + this.ResponseMimeType = responseMimeType; this.ImageConfig = imageConfig; + this.StopSequences = stopSequences; this.Logprobs = logprobs; - this.TopK = topK; this.MaxOutputTokens = maxOutputTokens; - this.ThinkingConfig = thinkingConfig; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaGroundingSupport.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaGroundingSupport.g.cs index 1c1b71b..708441a 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaGroundingSupport.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaGroundingSupport.g.cs @@ -9,16 +9,17 @@ namespace Google.Gemini public sealed partial class GoogleAiGenerativelanguageV1betaGroundingSupport { /// - /// Optional. A list of indices (into 'grounding_chunk' in `response.candidate.grounding_metadata`) specifying the citations associated with the claim. For instance [1,3,4] means that grounding_chunk[1], grounding_chunk[3], grounding_chunk[4] are the retrieved content attributed to the claim. If the response is streaming, the grounding_chunk_indices refer to the indices across all responses. It is the client's responsibility to accumulate the grounding chunks from all responses (while maintaining the same order). + /// Output only. Indices into the `parts` field of the candidate's content. These indices specify which rendered parts are associated with this support source.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("groundingChunkIndices")] - public global::System.Collections.Generic.IList? GroundingChunkIndices { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("renderedParts")] + public global::System.Collections.Generic.IList? RenderedParts { get; set; } /// - /// Optional. Confidence score of the support references. Ranges from 0 to 1. 1 is the most confident. This list must have the same size as the grounding_chunk_indices. + /// Optional. A list of indices (into 'grounding_chunk' in `response.candidate.grounding_metadata`) specifying the citations associated with the claim. For instance [1,3,4] means that grounding_chunk[1], grounding_chunk[3], grounding_chunk[4] are the retrieved content attributed to the claim. If the response is streaming, the grounding_chunk_indices refer to the indices across all responses. It is the client's responsibility to accumulate the grounding chunks from all responses (while maintaining the same order). /// - [global::System.Text.Json.Serialization.JsonPropertyName("confidenceScores")] - public global::System.Collections.Generic.IList? ConfidenceScores { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("groundingChunkIndices")] + public global::System.Collections.Generic.IList? GroundingChunkIndices { get; set; } /// /// Segment of the content. @@ -27,11 +28,10 @@ public sealed partial class GoogleAiGenerativelanguageV1betaGroundingSupport public global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? Segment { get; set; } /// - /// Output only. Indices into the `parts` field of the candidate's content. These indices specify which rendered parts are associated with this support source.
- /// Included only in responses + /// Optional. Confidence score of the support references. Ranges from 0 to 1. 1 is the most confident. This list must have the same size as the grounding_chunk_indices. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("renderedParts")] - public global::System.Collections.Generic.IList? RenderedParts { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("confidenceScores")] + public global::System.Collections.Generic.IList? ConfidenceScores { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -42,32 +42,32 @@ public sealed partial class GoogleAiGenerativelanguageV1betaGroundingSupport /// /// Initializes a new instance of the class. /// + /// + /// Output only. Indices into the `parts` field of the candidate's content. These indices specify which rendered parts are associated with this support source.
+ /// Included only in responses + /// /// /// Optional. A list of indices (into 'grounding_chunk' in `response.candidate.grounding_metadata`) specifying the citations associated with the claim. For instance [1,3,4] means that grounding_chunk[1], grounding_chunk[3], grounding_chunk[4] are the retrieved content attributed to the claim. If the response is streaming, the grounding_chunk_indices refer to the indices across all responses. It is the client's responsibility to accumulate the grounding chunks from all responses (while maintaining the same order). /// - /// - /// Optional. Confidence score of the support references. Ranges from 0 to 1. 1 is the most confident. This list must have the same size as the grounding_chunk_indices. - /// /// /// Segment of the content. /// - /// - /// Output only. Indices into the `parts` field of the candidate's content. These indices specify which rendered parts are associated with this support source.
- /// Included only in responses + /// + /// Optional. Confidence score of the support references. Ranges from 0 to 1. 1 is the most confident. This list must have the same size as the grounding_chunk_indices. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GoogleAiGenerativelanguageV1betaGroundingSupport( + global::System.Collections.Generic.IList? renderedParts, global::System.Collections.Generic.IList? groundingChunkIndices, - global::System.Collections.Generic.IList? confidenceScores, global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? segment, - global::System.Collections.Generic.IList? renderedParts) + global::System.Collections.Generic.IList? confidenceScores) { + this.RenderedParts = renderedParts; this.GroundingChunkIndices = groundingChunkIndices; - this.ConfidenceScores = confidenceScores; this.Segment = segment; - this.RenderedParts = renderedParts; + this.ConfidenceScores = confidenceScores; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaSegment.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaSegment.g.cs index 1983af1..06a377f 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaSegment.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaSegment.g.cs @@ -14,12 +14,6 @@ public sealed partial class GoogleAiGenerativelanguageV1betaSegment [global::System.Text.Json.Serialization.JsonPropertyName("partIndex")] public int? PartIndex { get; set; } - /// - /// The text corresponding to the segment from the response. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("text")] - public string? Text { get; set; } - /// /// Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero. /// @@ -32,6 +26,12 @@ public sealed partial class GoogleAiGenerativelanguageV1betaSegment [global::System.Text.Json.Serialization.JsonPropertyName("endIndex")] public int? EndIndex { get; set; } + /// + /// The text corresponding to the segment from the response. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("text")] + public string? Text { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -44,28 +44,28 @@ public sealed partial class GoogleAiGenerativelanguageV1betaSegment /// /// The index of a Part object within its parent Content object. /// - /// - /// The text corresponding to the segment from the response. - /// /// /// Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero. /// /// /// End index in the given Part, measured in bytes. Offset from the start of the Part, exclusive, starting at zero. /// + /// + /// The text corresponding to the segment from the response. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GoogleAiGenerativelanguageV1betaSegment( int? partIndex, - string? text, int? startIndex, - int? endIndex) + int? endIndex, + string? text) { this.PartIndex = partIndex; - this.Text = text; this.StartIndex = startIndex; this.EndIndex = endIndex; + this.Text = text; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunk.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunk.g.cs index 780096d..ca73d30 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunk.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunk.g.cs @@ -8,18 +8,6 @@ namespace Google.Gemini /// public sealed partial class GroundingChunk { - /// - /// A grounding chunk from Google Maps. A Maps chunk corresponds to a single place. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("maps")] - public global::Google.Gemini.Maps? Maps { get; set; } - - /// - /// Chunk from image search. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("image")] - public global::Google.Gemini.Image? Image { get; set; } - /// /// Chunk from the web. /// @@ -32,6 +20,18 @@ public sealed partial class GroundingChunk [global::System.Text.Json.Serialization.JsonPropertyName("retrievedContext")] public global::Google.Gemini.RetrievedContext? RetrievedContext { get; set; } + /// + /// A grounding chunk from Google Maps. A Maps chunk corresponds to a single place. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("maps")] + public global::Google.Gemini.Maps? Maps { get; set; } + + /// + /// Chunk from image search. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("image")] + public global::Google.Gemini.Image? Image { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -41,31 +41,31 @@ public sealed partial class GroundingChunk /// /// Initializes a new instance of the class. /// - /// - /// A grounding chunk from Google Maps. A Maps chunk corresponds to a single place. - /// - /// - /// Chunk from image search. - /// /// /// Chunk from the web. /// /// /// Chunk from context retrieved by the file search tool. /// + /// + /// A grounding chunk from Google Maps. A Maps chunk corresponds to a single place. + /// + /// + /// Chunk from image search. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingChunk( - global::Google.Gemini.Maps? maps, - global::Google.Gemini.Image? image, global::Google.Gemini.Web? web, - global::Google.Gemini.RetrievedContext? retrievedContext) + global::Google.Gemini.RetrievedContext? retrievedContext, + global::Google.Gemini.Maps? maps, + global::Google.Gemini.Image? image) { - this.Maps = maps; - this.Image = image; this.Web = web; this.RetrievedContext = retrievedContext; + this.Maps = maps; + this.Image = image; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunkCustomMetadata.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunkCustomMetadata.g.cs index 52714bd..825b243 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunkCustomMetadata.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunkCustomMetadata.g.cs @@ -14,6 +14,12 @@ public sealed partial class GroundingChunkCustomMetadata [global::System.Text.Json.Serialization.JsonPropertyName("stringListValue")] public global::Google.Gemini.GroundingChunkStringList? StringListValue { get; set; } + /// + /// Optional. The string value of the metadata. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("stringValue")] + public string? StringValue { get; set; } + /// /// Optional. The numeric value of the metadata. The expected range for this value depends on the specific `key` used. /// @@ -26,12 +32,6 @@ public sealed partial class GroundingChunkCustomMetadata [global::System.Text.Json.Serialization.JsonPropertyName("key")] public string? Key { get; set; } - /// - /// Optional. The string value of the metadata. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("stringValue")] - public string? StringValue { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -44,28 +44,28 @@ public sealed partial class GroundingChunkCustomMetadata /// /// A list of string values. /// + /// + /// Optional. The string value of the metadata. + /// /// /// Optional. The numeric value of the metadata. The expected range for this value depends on the specific `key` used. /// /// /// The key of the metadata. /// - /// - /// Optional. The string value of the metadata. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingChunkCustomMetadata( global::Google.Gemini.GroundingChunkStringList? stringListValue, + string? stringValue, float? numericValue, - string? key, - string? stringValue) + string? key) { this.StringListValue = stringListValue; + this.StringValue = stringValue; this.NumericValue = numericValue; this.Key = key; - this.StringValue = stringValue; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingMetadata.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingMetadata.g.cs index 24f6c96..b4dee36 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingMetadata.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingMetadata.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class GroundingMetadata { - /// - /// Web search queries for the following-up web search. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("webSearchQueries")] - public global::System.Collections.Generic.IList? WebSearchQueries { get; set; } - /// /// Google search entry point. /// @@ -21,10 +15,16 @@ public sealed partial class GroundingMetadata public global::Google.Gemini.SearchEntryPoint? SearchEntryPoint { get; set; } /// - /// List of grounding support. + /// Metadata related to retrieval in the grounding flow. /// - [global::System.Text.Json.Serialization.JsonPropertyName("groundingSupports")] - public global::System.Collections.Generic.IList? GroundingSupports { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("retrievalMetadata")] + public global::Google.Gemini.RetrievalMetadata? RetrievalMetadata { get; set; } + + /// + /// Image search queries used for grounding. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("imageSearchQueries")] + public global::System.Collections.Generic.IList? ImageSearchQueries { get; set; } /// /// List of supporting references retrieved from specified grounding source. When streaming, this only contains the grounding chunks that have not been included in the grounding metadata of previous responses. @@ -33,22 +33,22 @@ public sealed partial class GroundingMetadata public global::System.Collections.Generic.IList? GroundingChunks { get; set; } /// - /// Image search queries used for grounding. + /// List of grounding support. /// - [global::System.Text.Json.Serialization.JsonPropertyName("imageSearchQueries")] - public global::System.Collections.Generic.IList? ImageSearchQueries { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("groundingSupports")] + public global::System.Collections.Generic.IList? GroundingSupports { get; set; } /// - /// Optional. Resource name of the Google Maps widget context token that can be used with the PlacesContextElement widget in order to render contextual data. Only populated in the case that grounding with Google Maps is enabled. + /// Web search queries for the following-up web search. /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleMapsWidgetContextToken")] - public string? GoogleMapsWidgetContextToken { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("webSearchQueries")] + public global::System.Collections.Generic.IList? WebSearchQueries { get; set; } /// - /// Metadata related to retrieval in the grounding flow. + /// Optional. Resource name of the Google Maps widget context token that can be used with the PlacesContextElement widget in order to render contextual data. Only populated in the case that grounding with Google Maps is enabled. /// - [global::System.Text.Json.Serialization.JsonPropertyName("retrievalMetadata")] - public global::Google.Gemini.RetrievalMetadata? RetrievalMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("googleMapsWidgetContextToken")] + public string? GoogleMapsWidgetContextToken { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -59,46 +59,46 @@ public sealed partial class GroundingMetadata /// /// Initializes a new instance of the class. /// - /// - /// Web search queries for the following-up web search. - /// /// /// Google search entry point. /// - /// - /// List of grounding support. + /// + /// Metadata related to retrieval in the grounding flow. + /// + /// + /// Image search queries used for grounding. /// /// /// List of supporting references retrieved from specified grounding source. When streaming, this only contains the grounding chunks that have not been included in the grounding metadata of previous responses. /// - /// - /// Image search queries used for grounding. + /// + /// List of grounding support. + /// + /// + /// Web search queries for the following-up web search. /// /// /// Optional. Resource name of the Google Maps widget context token that can be used with the PlacesContextElement widget in order to render contextual data. Only populated in the case that grounding with Google Maps is enabled. /// - /// - /// Metadata related to retrieval in the grounding flow. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingMetadata( - global::System.Collections.Generic.IList? webSearchQueries, global::Google.Gemini.SearchEntryPoint? searchEntryPoint, - global::System.Collections.Generic.IList? groundingSupports, - global::System.Collections.Generic.IList? groundingChunks, + global::Google.Gemini.RetrievalMetadata? retrievalMetadata, global::System.Collections.Generic.IList? imageSearchQueries, - string? googleMapsWidgetContextToken, - global::Google.Gemini.RetrievalMetadata? retrievalMetadata) + global::System.Collections.Generic.IList? groundingChunks, + global::System.Collections.Generic.IList? groundingSupports, + global::System.Collections.Generic.IList? webSearchQueries, + string? googleMapsWidgetContextToken) { - this.WebSearchQueries = webSearchQueries; this.SearchEntryPoint = searchEntryPoint; - this.GroundingSupports = groundingSupports; - this.GroundingChunks = groundingChunks; + this.RetrievalMetadata = retrievalMetadata; this.ImageSearchQueries = imageSearchQueries; + this.GroundingChunks = groundingChunks; + this.GroundingSupports = groundingSupports; + this.WebSearchQueries = webSearchQueries; this.GoogleMapsWidgetContextToken = googleMapsWidgetContextToken; - this.RetrievalMetadata = retrievalMetadata; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingPassageId.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingPassageId.g.cs index 6d7ea67..29ecf6d 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingPassageId.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingPassageId.g.cs @@ -9,18 +9,18 @@ namespace Google.Gemini public sealed partial class GroundingPassageId { /// - /// Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`.
+ /// Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("partIndex")] - public int? PartIndex { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("passageId")] + public string? PassageId { get; set; } /// - /// Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`.
+ /// Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("passageId")] - public string? PassageId { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("partIndex")] + public int? PartIndex { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -31,23 +31,23 @@ public sealed partial class GroundingPassageId /// /// Initializes a new instance of the class. /// - /// - /// Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`.
- /// Included only in responses - /// /// /// Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`.
/// Included only in responses /// + /// + /// Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`.
+ /// Included only in responses + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingPassageId( - int? partIndex, - string? passageId) + string? passageId, + int? partIndex) { - this.PartIndex = partIndex; this.PassageId = passageId; + this.PartIndex = partIndex; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Hyperparameters.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Hyperparameters.g.cs index 9bc3820..d7b344e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Hyperparameters.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Hyperparameters.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class Hyperparameters { + /// + /// Immutable. The batch size hyperparameter for tuning. If not set, a default of 4 or 16 will be used based on the number of training examples. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("batchSize")] + public int? BatchSize { get; set; } + /// /// Optional. Immutable. The learning rate hyperparameter for tuning. If not set, a default of 0.001 or 0.0002 will be calculated based on the number of training examples. /// @@ -26,12 +32,6 @@ public sealed partial class Hyperparameters [global::System.Text.Json.Serialization.JsonPropertyName("epochCount")] public int? EpochCount { get; set; } - /// - /// Immutable. The batch size hyperparameter for tuning. If not set, a default of 4 or 16 will be used based on the number of training examples. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("batchSize")] - public int? BatchSize { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -41,6 +41,9 @@ public sealed partial class Hyperparameters /// /// Initializes a new instance of the class. /// + /// + /// Immutable. The batch size hyperparameter for tuning. If not set, a default of 4 or 16 will be used based on the number of training examples. + /// /// /// Optional. Immutable. The learning rate hyperparameter for tuning. If not set, a default of 0.001 or 0.0002 will be calculated based on the number of training examples. /// @@ -50,22 +53,19 @@ public sealed partial class Hyperparameters /// /// Immutable. The number of training epochs. An epoch is one pass through the training data. If not set, a default of 5 will be used. /// - /// - /// Immutable. The batch size hyperparameter for tuning. If not set, a default of 4 or 16 will be used based on the number of training examples. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Hyperparameters( + int? batchSize, float? learningRate, float? learningRateMultiplier, - int? epochCount, - int? batchSize) + int? epochCount) { + this.BatchSize = batchSize; this.LearningRate = learningRate; this.LearningRateMultiplier = learningRateMultiplier; this.EpochCount = epochCount; - this.BatchSize = batchSize; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Image.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Image.g.cs index 36f43be..c483dab 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Image.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Image.g.cs @@ -8,18 +8,6 @@ namespace Google.Gemini /// public sealed partial class Image { - /// - /// The title of the web page that the image is from. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - public string? Title { get; set; } - - /// - /// The web page URI for attribution. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("sourceUri")] - public string? SourceUri { get; set; } - /// /// The image asset URL. /// @@ -32,6 +20,18 @@ public sealed partial class Image [global::System.Text.Json.Serialization.JsonPropertyName("domain")] public string? Domain { get; set; } + /// + /// The web page URI for attribution. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("sourceUri")] + public string? SourceUri { get; set; } + + /// + /// The title of the web page that the image is from. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("title")] + public string? Title { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -41,31 +41,31 @@ public sealed partial class Image /// /// Initializes a new instance of the class. /// - /// - /// The title of the web page that the image is from. - /// - /// - /// The web page URI for attribution. - /// /// /// The image asset URL. /// /// /// The root domain of the web page that the image is from, e.g. "example.com". /// + /// + /// The web page URI for attribution. + /// + /// + /// The title of the web page that the image is from. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Image( - string? title, - string? sourceUri, string? imageUri, - string? domain) + string? domain, + string? sourceUri, + string? title) { - this.Title = title; - this.SourceUri = sourceUri; this.ImageUri = imageUri; this.Domain = domain; + this.SourceUri = sourceUri; + this.Title = title; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImageConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImageConfig.g.cs index 84e2562..5ed82a6 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImageConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImageConfig.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ImageConfig { - /// - /// Optional. The aspect ratio of the image to generate. Supported aspect ratios: `1:1`, `1:4`, `4:1`, `1:8`, `8:1`, `2:3`, `3:2`, `3:4`, `4:3`, `4:5`, `5:4`, `9:16`, `16:9`, or `21:9`. If not specified, the model will choose a default aspect ratio based on any reference images provided. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("aspectRatio")] - public string? AspectRatio { get; set; } - /// /// Optional. Specifies the size of generated images. Supported values are `512`, `1K`, `2K`, `4K`. If not specified, the model will use default value `1K`. /// [global::System.Text.Json.Serialization.JsonPropertyName("imageSize")] public string? ImageSize { get; set; } + /// + /// Optional. The aspect ratio of the image to generate. Supported aspect ratios: `1:1`, `1:4`, `4:1`, `1:8`, `8:1`, `2:3`, `3:2`, `3:4`, `4:3`, `4:5`, `5:4`, `9:16`, `16:9`, or `21:9`. If not specified, the model will choose a default aspect ratio based on any reference images provided. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("aspectRatio")] + public string? AspectRatio { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class ImageConfig /// /// Initializes a new instance of the class. /// - /// - /// Optional. The aspect ratio of the image to generate. Supported aspect ratios: `1:1`, `1:4`, `4:1`, `1:8`, `8:1`, `2:3`, `3:2`, `3:4`, `4:3`, `4:5`, `5:4`, `9:16`, `16:9`, or `21:9`. If not specified, the model will choose a default aspect ratio based on any reference images provided. - /// /// /// Optional. Specifies the size of generated images. Supported values are `512`, `1K`, `2K`, `4K`. If not specified, the model will use default value `1K`. /// + /// + /// Optional. The aspect ratio of the image to generate. Supported aspect ratios: `1:1`, `1:4`, `4:1`, `1:8`, `8:1`, `2:3`, `3:2`, `3:4`, `4:3`, `4:5`, `5:4`, `9:16`, `16:9`, or `21:9`. If not specified, the model will choose a default aspect ratio based on any reference images provided. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ImageConfig( - string? aspectRatio, - string? imageSize) + string? imageSize, + string? aspectRatio) { - this.AspectRatio = aspectRatio; this.ImageSize = imageSize; + this.AspectRatio = aspectRatio; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImportFileRequest.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImportFileRequest.g.cs index 0c6351f..2f4a44c 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImportFileRequest.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImportFileRequest.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class ImportFileRequest { - /// - /// Custom metadata to be associated with the file. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] - public global::System.Collections.Generic.IList? CustomMetadata { get; set; } - /// /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto /// @@ -26,6 +20,12 @@ public sealed partial class ImportFileRequest [global::System.Text.Json.Serialization.JsonPropertyName("fileName")] public string? FileName { get; set; } + /// + /// Custom metadata to be associated with the file. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] + public global::System.Collections.Generic.IList? CustomMetadata { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class ImportFileRequest /// /// Initializes a new instance of the class. /// - /// - /// Custom metadata to be associated with the file. - /// /// /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto /// /// /// Required. The name of the `File` to import. Example: `files/abc-123` /// + /// + /// Custom metadata to be associated with the file. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ImportFileRequest( - global::System.Collections.Generic.IList? customMetadata, global::Google.Gemini.ChunkingConfig? chunkingConfig, - string? fileName) + string? fileName, + global::System.Collections.Generic.IList? customMetadata) { - this.CustomMetadata = customMetadata; this.ChunkingConfig = chunkingConfig; this.FileName = fileName; + this.CustomMetadata = customMetadata; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentResponse.g.cs index d705a97..ca0840b 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentResponse.g.cs @@ -8,6 +8,13 @@ namespace Google.Gemini /// public sealed partial class InlinedEmbedContentResponse { + /// + /// Output only. The metadata associated with the request.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] + public object? Metadata { get; set; } + /// /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// @@ -20,13 +27,6 @@ public sealed partial class InlinedEmbedContentResponse [global::System.Text.Json.Serialization.JsonPropertyName("response")] public global::Google.Gemini.EmbedContentResponse? Response { get; set; } - /// - /// Output only. The metadata associated with the request.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] - public object? Metadata { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -36,27 +36,27 @@ public sealed partial class InlinedEmbedContentResponse /// /// Initializes a new instance of the class. /// + /// + /// Output only. The metadata associated with the request.
+ /// Included only in responses + /// /// /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// /// /// The response to an `EmbedContentRequest`. /// - /// - /// Output only. The metadata associated with the request.
- /// Included only in responses - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public InlinedEmbedContentResponse( + object? metadata, global::Google.Gemini.Status? error, - global::Google.Gemini.EmbedContentResponse? response, - object? metadata) + global::Google.Gemini.EmbedContentResponse? response) { + this.Metadata = metadata; this.Error = error; this.Response = response; - this.Metadata = metadata; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InputConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InputConfig.g.cs index c37f215..01a06fc 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InputConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InputConfig.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class InputConfig { - /// - /// The requests to be processed in the batch if provided as part of the batch creation request. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("requests")] - public global::Google.Gemini.InlinedRequests? Requests { get; set; } - /// /// The name of the `File` containing the input requests. /// [global::System.Text.Json.Serialization.JsonPropertyName("fileName")] public string? FileName { get; set; } + /// + /// The requests to be processed in the batch if provided as part of the batch creation request. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("requests")] + public global::Google.Gemini.InlinedRequests? Requests { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class InputConfig /// /// Initializes a new instance of the class. /// - /// - /// The requests to be processed in the batch if provided as part of the batch creation request. - /// /// /// The name of the `File` containing the input requests. /// + /// + /// The requests to be processed in the batch if provided as part of the batch creation request. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public InputConfig( - global::Google.Gemini.InlinedRequests? requests, - string? fileName) + string? fileName, + global::Google.Gemini.InlinedRequests? requests) { - this.Requests = requests; this.FileName = fileName; + this.Requests = requests; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InputEmbedContentConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InputEmbedContentConfig.g.cs index acc98cf..d91125c 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InputEmbedContentConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InputEmbedContentConfig.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class InputEmbedContentConfig { - /// - /// The requests to be processed in the batch if provided as part of the batch creation request. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("requests")] - public global::Google.Gemini.InlinedEmbedContentRequests? Requests { get; set; } - /// /// The name of the `File` containing the input requests. /// [global::System.Text.Json.Serialization.JsonPropertyName("fileName")] public string? FileName { get; set; } + /// + /// The requests to be processed in the batch if provided as part of the batch creation request. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("requests")] + public global::Google.Gemini.InlinedEmbedContentRequests? Requests { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class InputEmbedContentConfig /// /// Initializes a new instance of the class. /// - /// - /// The requests to be processed in the batch if provided as part of the batch creation request. - /// /// /// The name of the `File` containing the input requests. /// + /// + /// The requests to be processed in the batch if provided as part of the batch creation request. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public InputEmbedContentConfig( - global::Google.Gemini.InlinedEmbedContentRequests? requests, - string? fileName) + string? fileName, + global::Google.Gemini.InlinedEmbedContentRequests? requests) { - this.Requests = requests; this.FileName = fileName; + this.Requests = requests; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LatLng.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LatLng.g.cs index 8f9cc3b..d540847 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LatLng.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LatLng.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class LatLng { - /// - /// The longitude in degrees. It must be in the range [-180.0, +180.0]. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("longitude")] - public double? Longitude { get; set; } - /// /// The latitude in degrees. It must be in the range [-90.0, +90.0]. /// [global::System.Text.Json.Serialization.JsonPropertyName("latitude")] public double? Latitude { get; set; } + /// + /// The longitude in degrees. It must be in the range [-180.0, +180.0]. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("longitude")] + public double? Longitude { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class LatLng /// /// Initializes a new instance of the class. /// - /// - /// The longitude in degrees. It must be in the range [-180.0, +180.0]. - /// /// /// The latitude in degrees. It must be in the range [-90.0, +90.0]. /// + /// + /// The longitude in degrees. It must be in the range [-180.0, +180.0]. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public LatLng( - double? longitude, - double? latitude) + double? latitude, + double? longitude) { - this.Longitude = longitude; this.Latitude = latitude; + this.Longitude = longitude; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCachedContentsResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCachedContentsResponse.g.cs index 6b112b8..d8960e0 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCachedContentsResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCachedContentsResponse.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ListCachedContentsResponse { - /// - /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] - public string? NextPageToken { get; set; } - /// /// List of cached contents. /// [global::System.Text.Json.Serialization.JsonPropertyName("cachedContents")] public global::System.Collections.Generic.IList? CachedContents { get; set; } + /// + /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] + public string? NextPageToken { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class ListCachedContentsResponse /// /// Initializes a new instance of the class. /// - /// - /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages. - /// /// /// List of cached contents. /// + /// + /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListCachedContentsResponse( - string? nextPageToken, - global::System.Collections.Generic.IList? cachedContents) + global::System.Collections.Generic.IList? cachedContents, + string? nextPageToken) { - this.NextPageToken = nextPageToken; this.CachedContents = cachedContents; + this.NextPageToken = nextPageToken; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCorporaResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCorporaResponse.g.cs index f5cb758..53b78dd 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCorporaResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCorporaResponse.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ListCorporaResponse { - /// - /// The returned corpora. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("corpora")] - public global::System.Collections.Generic.IList? Corpora { get; set; } - /// /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. /// [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] public string? NextPageToken { get; set; } + /// + /// The returned corpora. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("corpora")] + public global::System.Collections.Generic.IList? Corpora { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class ListCorporaResponse /// /// Initializes a new instance of the class. /// - /// - /// The returned corpora. - /// /// /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. /// + /// + /// The returned corpora. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListCorporaResponse( - global::System.Collections.Generic.IList? corpora, - string? nextPageToken) + string? nextPageToken, + global::System.Collections.Generic.IList? corpora) { - this.Corpora = corpora; this.NextPageToken = nextPageToken; + this.Corpora = corpora; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFileSearchStoresResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFileSearchStoresResponse.g.cs index b64b02e..841ed88 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFileSearchStoresResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFileSearchStoresResponse.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ListFileSearchStoresResponse { - /// - /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] - public string? NextPageToken { get; set; } - /// /// The returned rag_stores. /// [global::System.Text.Json.Serialization.JsonPropertyName("fileSearchStores")] public global::System.Collections.Generic.IList? FileSearchStores { get; set; } + /// + /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] + public string? NextPageToken { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class ListFileSearchStoresResponse /// /// Initializes a new instance of the class. /// - /// - /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. - /// /// /// The returned rag_stores. /// + /// + /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListFileSearchStoresResponse( - string? nextPageToken, - global::System.Collections.Generic.IList? fileSearchStores) + global::System.Collections.Generic.IList? fileSearchStores, + string? nextPageToken) { - this.NextPageToken = nextPageToken; this.FileSearchStores = fileSearchStores; + this.NextPageToken = nextPageToken; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFilesResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFilesResponse.g.cs index 7b51e54..00f5c2a 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFilesResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFilesResponse.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ListFilesResponse { - /// - /// The list of `File`s. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("files")] - public global::System.Collections.Generic.IList? Files { get; set; } - /// /// A token that can be sent as a `page_token` into a subsequent `ListFiles` call. /// [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] public string? NextPageToken { get; set; } + /// + /// The list of `File`s. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("files")] + public global::System.Collections.Generic.IList? Files { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class ListFilesResponse /// /// Initializes a new instance of the class. /// - /// - /// The list of `File`s. - /// /// /// A token that can be sent as a `page_token` into a subsequent `ListFiles` call. /// + /// + /// The list of `File`s. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListFilesResponse( - global::System.Collections.Generic.IList? files, - string? nextPageToken) + string? nextPageToken, + global::System.Collections.Generic.IList? files) { - this.Files = files; this.NextPageToken = nextPageToken; + this.Files = files; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListModelsResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListModelsResponse.g.cs index 040a93d..1c37480 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListModelsResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListModelsResponse.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ListModelsResponse { - /// - /// The returned Models. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("models")] - public global::System.Collections.Generic.IList? Models { get; set; } - /// /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. /// [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] public string? NextPageToken { get; set; } + /// + /// The returned Models. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("models")] + public global::System.Collections.Generic.IList? Models { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class ListModelsResponse /// /// Initializes a new instance of the class. /// - /// - /// The returned Models. - /// /// /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. /// + /// + /// The returned Models. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListModelsResponse( - global::System.Collections.Generic.IList? models, - string? nextPageToken) + string? nextPageToken, + global::System.Collections.Generic.IList? models) { - this.Models = models; this.NextPageToken = nextPageToken; + this.Models = models; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListOperationsResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListOperationsResponse.g.cs index ade5a8e..ba86db6 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListOperationsResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListOperationsResponse.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class ListOperationsResponse { - /// - /// The standard List next-page token. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] - public string? NextPageToken { get; set; } - /// /// A list of operations that matches the specified filter in the request. /// @@ -26,6 +20,12 @@ public sealed partial class ListOperationsResponse [global::System.Text.Json.Serialization.JsonPropertyName("unreachable")] public global::System.Collections.Generic.IList? Unreachable { get; set; } + /// + /// The standard List next-page token. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] + public string? NextPageToken { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class ListOperationsResponse /// /// Initializes a new instance of the class. /// - /// - /// The standard List next-page token. - /// /// /// A list of operations that matches the specified filter in the request. /// /// /// Unordered list. Unreachable resources. Populated when the request sets `ListOperationsRequest.return_partial_success` and reads across collections. For example, when attempting to list all resources across all supported locations. /// + /// + /// The standard List next-page token. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListOperationsResponse( - string? nextPageToken, global::System.Collections.Generic.IList? operations, - global::System.Collections.Generic.IList? unreachable) + global::System.Collections.Generic.IList? unreachable, + string? nextPageToken) { - this.NextPageToken = nextPageToken; this.Operations = operations; this.Unreachable = unreachable; + this.NextPageToken = nextPageToken; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResultCandidate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResultCandidate.g.cs index 1c4558c..d773b7f 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResultCandidate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResultCandidate.g.cs @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class LogprobsResultCandidate { /// - /// The candidate’s token string value. + /// The candidate's log probability. /// - [global::System.Text.Json.Serialization.JsonPropertyName("token")] - public string? Token { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("logProbability")] + public float? LogProbability { get; set; } /// /// The candidate’s token id value. @@ -21,10 +21,10 @@ public sealed partial class LogprobsResultCandidate public int? TokenId { get; set; } /// - /// The candidate's log probability. + /// The candidate’s token string value. /// - [global::System.Text.Json.Serialization.JsonPropertyName("logProbability")] - public float? LogProbability { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("token")] + public string? Token { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -35,26 +35,26 @@ public sealed partial class LogprobsResultCandidate /// /// Initializes a new instance of the class. /// - /// - /// The candidate’s token string value. + /// + /// The candidate's log probability. /// /// /// The candidate’s token id value. /// - /// - /// The candidate's log probability. + /// + /// The candidate’s token string value. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public LogprobsResultCandidate( - string? token, + float? logProbability, int? tokenId, - float? logProbability) + string? token) { - this.Token = token; - this.TokenId = tokenId; this.LogProbability = logProbability; + this.TokenId = tokenId; + this.Token = token; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Maps.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Maps.g.cs index dc3d063..cd66688 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Maps.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Maps.g.cs @@ -9,16 +9,10 @@ namespace Google.Gemini public sealed partial class Maps { /// - /// The ID of the place, in `places/{place_id}` format. A user can use this ID to look up that place. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("placeId")] - public string? PlaceId { get; set; } - - /// - /// Title of the place. + /// URI reference of the place. /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - public string? Title { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("uri")] + public string? Uri { get; set; } /// /// Text description of the place answer. @@ -27,10 +21,16 @@ public sealed partial class Maps public string? Text { get; set; } /// - /// URI reference of the place. + /// The ID of the place, in `places/{place_id}` format. A user can use this ID to look up that place. /// - [global::System.Text.Json.Serialization.JsonPropertyName("uri")] - public string? Uri { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("placeId")] + public string? PlaceId { get; set; } + + /// + /// Title of the place. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("title")] + public string? Title { get; set; } /// /// Collection of sources that provide answers about the features of a given place in Google Maps. Each PlaceAnswerSources message corresponds to a specific place in Google Maps. The Google Maps tool used these sources in order to answer questions about features of the place (e.g: "does Bar Foo have Wifi" or "is Foo Bar wheelchair accessible?"). Currently we only support review snippets as sources. @@ -47,18 +47,18 @@ public sealed partial class Maps /// /// Initializes a new instance of the class. /// + /// + /// URI reference of the place. + /// + /// + /// Text description of the place answer. + /// /// /// The ID of the place, in `places/{place_id}` format. A user can use this ID to look up that place. /// /// /// Title of the place. /// - /// - /// Text description of the place answer. - /// - /// - /// URI reference of the place. - /// /// /// Collection of sources that provide answers about the features of a given place in Google Maps. Each PlaceAnswerSources message corresponds to a specific place in Google Maps. The Google Maps tool used these sources in order to answer questions about features of the place (e.g: "does Bar Foo have Wifi" or "is Foo Bar wheelchair accessible?"). Currently we only support review snippets as sources. /// @@ -66,16 +66,16 @@ public sealed partial class Maps [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Maps( + string? uri, + string? text, string? placeId, string? title, - string? text, - string? uri, global::Google.Gemini.PlaceAnswerSources? placeAnswerSources) { + this.Uri = uri; + this.Text = text; this.PlaceId = placeId; this.Title = title; - this.Text = text; - this.Uri = uri; this.PlaceAnswerSources = placeAnswerSources; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Model.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Model.g.cs index 80a42b5..5a76806 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Model.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Model.g.cs @@ -9,40 +9,28 @@ namespace Google.Gemini public sealed partial class Model { /// - /// Maximum number of output tokens available for this model. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("outputTokenLimit")] - public int? OutputTokenLimit { get; set; } - - /// - /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) - /// - [global::System.Text.Json.Serialization.JsonPropertyName("version")] - public string? Version { get; set; } - - /// - /// For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. If empty, indicates the model doesn't use top-k sampling, and `top_k` isn't allowed as a generation parameter. + /// Controls the randomness of the output. Values can range over `[0.0,max_temperature]`, inclusive. A higher value will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be used by the backend while making the call to the model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("topK")] - public int? TopK { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] + public float? Temperature { get; set; } /// - /// Maximum number of input tokens allowed for this model. + /// Required. The resource name of the `Model`. Refer to [Model variants](https://ai.google.dev/gemini-api/docs/models/gemini#model-variations) for all allowed values. Format: `models/{model}` with a `{model}` naming convention of: * "{base_model_id}-{version}" Examples: * `models/gemini-1.5-flash-001` /// - [global::System.Text.Json.Serialization.JsonPropertyName("inputTokenLimit")] - public int? InputTokenLimit { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// - /// Whether the model supports thinking. + /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) /// - [global::System.Text.Json.Serialization.JsonPropertyName("thinking")] - public bool? Thinking { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("version")] + public string? Version { get; set; } /// - /// Required. The resource name of the `Model`. Refer to [Model variants](https://ai.google.dev/gemini-api/docs/models/gemini#model-variations) for all allowed values. Format: `models/{model}` with a `{model}` naming convention of: * "{base_model_id}-{version}" Examples: * `models/gemini-1.5-flash-001` + /// For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topP")] + public float? TopP { get; set; } /// /// The human-readable name of the model. E.g. "Gemini 1.5 Flash". The name can be up to 128 characters long and can consist of any UTF-8 characters. @@ -51,16 +39,22 @@ public sealed partial class Model public string? DisplayName { get; set; } /// - /// Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` + /// For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. If empty, indicates the model doesn't use top-k sampling, and `top_k` isn't allowed as a generation parameter. /// - [global::System.Text.Json.Serialization.JsonPropertyName("baseModelId")] - public string? BaseModelId { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topK")] + public int? TopK { get; set; } /// - /// For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model. + /// The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("topP")] - public float? TopP { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("supportedGenerationMethods")] + public global::System.Collections.Generic.IList? SupportedGenerationMethods { get; set; } + + /// + /// Whether the model supports thinking. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("thinking")] + public bool? Thinking { get; set; } /// /// A short description of the model. @@ -69,22 +63,28 @@ public sealed partial class Model public string? Description { get; set; } /// - /// Controls the randomness of the output. Values can range over `[0.0,max_temperature]`, inclusive. A higher value will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be used by the backend while making the call to the model. + /// The maximum temperature this model can use. /// - [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] - public float? Temperature { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxTemperature")] + public float? MaxTemperature { get; set; } /// - /// The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`. + /// Maximum number of output tokens available for this model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("supportedGenerationMethods")] - public global::System.Collections.Generic.IList? SupportedGenerationMethods { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("outputTokenLimit")] + public int? OutputTokenLimit { get; set; } /// - /// The maximum temperature this model can use. + /// Maximum number of input tokens allowed for this model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxTemperature")] - public float? MaxTemperature { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("inputTokenLimit")] + public int? InputTokenLimit { get; set; } + + /// + /// Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` + /// + [global::System.Text.Json.Serialization.JsonPropertyName("baseModelId")] + public string? BaseModelId { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -95,76 +95,76 @@ public sealed partial class Model /// /// Initializes a new instance of the class. /// - /// - /// Maximum number of output tokens available for this model. + /// + /// Controls the randomness of the output. Values can range over `[0.0,max_temperature]`, inclusive. A higher value will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be used by the backend while making the call to the model. + /// + /// + /// Required. The resource name of the `Model`. Refer to [Model variants](https://ai.google.dev/gemini-api/docs/models/gemini#model-variations) for all allowed values. Format: `models/{model}` with a `{model}` naming convention of: * "{base_model_id}-{version}" Examples: * `models/gemini-1.5-flash-001` /// /// /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) /// + /// + /// For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model. + /// + /// + /// The human-readable name of the model. E.g. "Gemini 1.5 Flash". The name can be up to 128 characters long and can consist of any UTF-8 characters. + /// /// /// For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. If empty, indicates the model doesn't use top-k sampling, and `top_k` isn't allowed as a generation parameter. /// - /// - /// Maximum number of input tokens allowed for this model. + /// + /// The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`. /// /// /// Whether the model supports thinking. /// - /// - /// Required. The resource name of the `Model`. Refer to [Model variants](https://ai.google.dev/gemini-api/docs/models/gemini#model-variations) for all allowed values. Format: `models/{model}` with a `{model}` naming convention of: * "{base_model_id}-{version}" Examples: * `models/gemini-1.5-flash-001` - /// - /// - /// The human-readable name of the model. E.g. "Gemini 1.5 Flash". The name can be up to 128 characters long and can consist of any UTF-8 characters. - /// - /// - /// Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` - /// - /// - /// For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model. - /// /// /// A short description of the model. /// - /// - /// Controls the randomness of the output. Values can range over `[0.0,max_temperature]`, inclusive. A higher value will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be used by the backend while making the call to the model. - /// - /// - /// The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`. - /// /// /// The maximum temperature this model can use. /// + /// + /// Maximum number of output tokens available for this model. + /// + /// + /// Maximum number of input tokens allowed for this model. + /// + /// + /// Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Model( - int? outputTokenLimit, + float? temperature, + string? name, string? version, + float? topP, + string? displayName, int? topK, - int? inputTokenLimit, + global::System.Collections.Generic.IList? supportedGenerationMethods, bool? thinking, - string? name, - string? displayName, - string? baseModelId, - float? topP, string? description, - float? temperature, - global::System.Collections.Generic.IList? supportedGenerationMethods, - float? maxTemperature) + float? maxTemperature, + int? outputTokenLimit, + int? inputTokenLimit, + string? baseModelId) { - this.OutputTokenLimit = outputTokenLimit; + this.Temperature = temperature; + this.Name = name; this.Version = version; + this.TopP = topP; + this.DisplayName = displayName; this.TopK = topK; - this.InputTokenLimit = inputTokenLimit; + this.SupportedGenerationMethods = supportedGenerationMethods; this.Thinking = thinking; - this.Name = name; - this.DisplayName = displayName; - this.BaseModelId = baseModelId; - this.TopP = topP; this.Description = description; - this.Temperature = temperature; - this.SupportedGenerationMethods = supportedGenerationMethods; this.MaxTemperature = maxTemperature; + this.OutputTokenLimit = outputTokenLimit; + this.InputTokenLimit = inputTokenLimit; + this.BaseModelId = baseModelId; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ModelStatus.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ModelStatus.g.cs index bb3395c..ad41b18 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ModelStatus.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ModelStatus.g.cs @@ -15,18 +15,18 @@ public sealed partial class ModelStatus [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageJsonConverter))] public global::Google.Gemini.ModelStatusModelStage? ModelStage { get; set; } - /// - /// The time at which the model will be retired. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("retirementTime")] - public string? RetirementTime { get; set; } - /// /// A message explaining the model status. /// [global::System.Text.Json.Serialization.JsonPropertyName("message")] public string? Message { get; set; } + /// + /// The time at which the model will be retired. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("retirementTime")] + public string? RetirementTime { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -39,23 +39,23 @@ public sealed partial class ModelStatus /// /// The stage of the underlying model. /// - /// - /// The time at which the model will be retired. - /// /// /// A message explaining the model status. /// + /// + /// The time at which the model will be retired. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ModelStatus( global::Google.Gemini.ModelStatusModelStage? modelStage, - string? retirementTime, - string? message) + string? message, + string? retirementTime) { this.ModelStage = modelStage; - this.RetirementTime = retirementTime; this.Message = message; + this.RetirementTime = retirementTime; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Operation.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Operation.g.cs index 1d0f9ea..a763fe7 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Operation.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Operation.g.cs @@ -14,12 +14,6 @@ public sealed partial class Operation [global::System.Text.Json.Serialization.JsonPropertyName("done")] public bool? Done { get; set; } - /// - /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } - /// /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// @@ -32,6 +26,12 @@ public sealed partial class Operation [global::System.Text.Json.Serialization.JsonPropertyName("response")] public object? Response { get; set; } + /// + /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } + /// /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. /// @@ -50,15 +50,15 @@ public sealed partial class Operation /// /// If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available. /// - /// - /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. - /// /// /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// /// /// The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. /// + /// + /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. + /// /// /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. /// @@ -67,15 +67,15 @@ public sealed partial class Operation #endif public Operation( bool? done, - string? name, global::Google.Gemini.Status? error, object? response, + string? name, object? metadata) { this.Done = done; - this.Name = name; this.Error = error; this.Response = response; + this.Name = name; this.Metadata = metadata; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Part.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Part.g.cs index d54aea6..0ade8cc 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Part.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Part.g.cs @@ -16,18 +16,6 @@ public sealed partial class Part [global::System.Text.Json.Serialization.JsonPropertyName("inlineData")] public global::Google.Gemini.Blob? InlineData { get; set; } - /// - /// A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("toolCall")] - public global::Google.Gemini.ToolCall? ToolCall { get; set; } - - /// - /// Optional. An opaque signature for the thought so it can be reused in subsequent requests. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("thoughtSignature")] - public byte[]? ThoughtSignature { get; set; } - /// /// Inline text. /// @@ -35,10 +23,16 @@ public sealed partial class Part public string? Text { get; set; } /// - /// URI based data. + /// Custom metadata associated with the Part. Agents using genai.Part as content representation may need to keep track of the additional information. For example it can be name of a file/source from which the Part originates or a way to multiplex multiple Part streams. /// - [global::System.Text.Json.Serialization.JsonPropertyName("fileData")] - public global::Google.Gemini.FileData? FileData { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("partMetadata")] + public object? PartMetadata { get; set; } + + /// + /// A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("functionCall")] + public global::Google.Gemini.FunctionCall? FunctionCall { get; set; } /// /// Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content. @@ -48,16 +42,22 @@ public sealed partial class Part public global::Google.Gemini.VideoMetadata? VideoMetadata { get; set; } /// - /// The output from a server-side `ToolCall` execution. This message contains the results of a tool invocation that was initiated by a `ToolCall` from the model. The client should pass this `ToolResponse` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolCall`. + /// Optional. Indicates if the part is thought from the model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("toolResponse")] - public global::Google.Gemini.ToolResponse? ToolResponse { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("thought")] + public bool? Thought { get; set; } /// - /// The result output from a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model. This should contain the result of a`FunctionCall` made based on model prediction. + /// A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("functionResponse")] - public global::Google.Gemini.FunctionResponse? FunctionResponse { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("toolCall")] + public global::Google.Gemini.ToolCall? ToolCall { get; set; } + + /// + /// URI based data. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("fileData")] + public global::Google.Gemini.FileData? FileData { get; set; } /// /// Code generated by the model that is meant to be executed, and the result returned to the model. Only generated when using the `CodeExecution` tool, in which the code will be automatically executed, and a corresponding `CodeExecutionResult` will also be generated. @@ -66,28 +66,28 @@ public sealed partial class Part public global::Google.Gemini.ExecutableCode? ExecutableCode { get; set; } /// - /// Custom metadata associated with the Part. Agents using genai.Part as content representation may need to keep track of the additional information. For example it can be name of a file/source from which the Part originates or a way to multiplex multiple Part streams. + /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. /// - [global::System.Text.Json.Serialization.JsonPropertyName("partMetadata")] - public object? PartMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("codeExecutionResult")] + public global::Google.Gemini.CodeExecutionResult? CodeExecutionResult { get; set; } /// - /// A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values. + /// The output from a server-side `ToolCall` execution. This message contains the results of a tool invocation that was initiated by a `ToolCall` from the model. The client should pass this `ToolResponse` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolCall`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("functionCall")] - public global::Google.Gemini.FunctionCall? FunctionCall { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("toolResponse")] + public global::Google.Gemini.ToolResponse? ToolResponse { get; set; } /// - /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. + /// The result output from a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model. This should contain the result of a`FunctionCall` made based on model prediction. /// - [global::System.Text.Json.Serialization.JsonPropertyName("codeExecutionResult")] - public global::Google.Gemini.CodeExecutionResult? CodeExecutionResult { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("functionResponse")] + public global::Google.Gemini.FunctionResponse? FunctionResponse { get; set; } /// - /// Optional. Indicates if the part is thought from the model. + /// Optional. An opaque signature for the thought so it can be reused in subsequent requests. /// - [global::System.Text.Json.Serialization.JsonPropertyName("thought")] - public bool? Thought { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("thoughtSignature")] + public byte[]? ThoughtSignature { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -101,68 +101,68 @@ public sealed partial class Part /// /// Raw media bytes. Text should not be sent as raw bytes, use the 'text' field. /// - /// - /// A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`. - /// - /// - /// Optional. An opaque signature for the thought so it can be reused in subsequent requests. - /// /// /// Inline text. /// - /// - /// URI based data. - /// - /// - /// The output from a server-side `ToolCall` execution. This message contains the results of a tool invocation that was initiated by a `ToolCall` from the model. The client should pass this `ToolResponse` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolCall`. - /// - /// - /// The result output from a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model. This should contain the result of a`FunctionCall` made based on model prediction. - /// - /// - /// Code generated by the model that is meant to be executed, and the result returned to the model. Only generated when using the `CodeExecution` tool, in which the code will be automatically executed, and a corresponding `CodeExecutionResult` will also be generated. - /// /// /// Custom metadata associated with the Part. Agents using genai.Part as content representation may need to keep track of the additional information. For example it can be name of a file/source from which the Part originates or a way to multiplex multiple Part streams. /// /// /// A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values. /// + /// + /// Optional. Indicates if the part is thought from the model. + /// + /// + /// A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`. + /// + /// + /// URI based data. + /// + /// + /// Code generated by the model that is meant to be executed, and the result returned to the model. Only generated when using the `CodeExecution` tool, in which the code will be automatically executed, and a corresponding `CodeExecutionResult` will also be generated. + /// /// /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. /// - /// - /// Optional. Indicates if the part is thought from the model. + /// + /// The output from a server-side `ToolCall` execution. This message contains the results of a tool invocation that was initiated by a `ToolCall` from the model. The client should pass this `ToolResponse` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolCall`. + /// + /// + /// The result output from a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model. This should contain the result of a`FunctionCall` made based on model prediction. + /// + /// + /// Optional. An opaque signature for the thought so it can be reused in subsequent requests. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Part( global::Google.Gemini.Blob? inlineData, - global::Google.Gemini.ToolCall? toolCall, - byte[]? thoughtSignature, string? text, - global::Google.Gemini.FileData? fileData, - global::Google.Gemini.ToolResponse? toolResponse, - global::Google.Gemini.FunctionResponse? functionResponse, - global::Google.Gemini.ExecutableCode? executableCode, object? partMetadata, global::Google.Gemini.FunctionCall? functionCall, + bool? thought, + global::Google.Gemini.ToolCall? toolCall, + global::Google.Gemini.FileData? fileData, + global::Google.Gemini.ExecutableCode? executableCode, global::Google.Gemini.CodeExecutionResult? codeExecutionResult, - bool? thought) + global::Google.Gemini.ToolResponse? toolResponse, + global::Google.Gemini.FunctionResponse? functionResponse, + byte[]? thoughtSignature) { this.InlineData = inlineData; - this.ToolCall = toolCall; - this.ThoughtSignature = thoughtSignature; this.Text = text; - this.FileData = fileData; - this.ToolResponse = toolResponse; - this.FunctionResponse = functionResponse; - this.ExecutableCode = executableCode; this.PartMetadata = partMetadata; this.FunctionCall = functionCall; - this.CodeExecutionResult = codeExecutionResult; this.Thought = thought; + this.ToolCall = toolCall; + this.FileData = fileData; + this.ExecutableCode = executableCode; + this.CodeExecutionResult = codeExecutionResult; + this.ToolResponse = toolResponse; + this.FunctionResponse = functionResponse; + this.ThoughtSignature = thoughtSignature; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Permission.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Permission.g.cs index 95e9315..2d00f94 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Permission.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Permission.g.cs @@ -15,6 +15,12 @@ public sealed partial class Permission [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeJsonConverter))] public global::Google.Gemini.PermissionGranteeType? GranteeType { get; set; } + /// + /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("emailAddress")] + public string? EmailAddress { get; set; } + /// /// Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.
/// Included only in responses @@ -22,12 +28,6 @@ public sealed partial class Permission [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } - /// - /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("emailAddress")] - public string? EmailAddress { get; set; } - /// /// Required. The role granted by this permission. /// @@ -47,13 +47,13 @@ public sealed partial class Permission /// /// Optional. Immutable. The type of the grantee. /// + /// + /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. + /// /// /// Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.
/// Included only in responses /// - /// - /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. - /// /// /// Required. The role granted by this permission. /// @@ -62,13 +62,13 @@ public sealed partial class Permission #endif public Permission( global::Google.Gemini.PermissionGranteeType? granteeType, - string? name, string? emailAddress, + string? name, global::Google.Gemini.PermissionRole? role) { this.GranteeType = granteeType; - this.Name = name; this.EmailAddress = emailAddress; + this.Name = name; this.Role = role; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.PromptFeedback.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.PromptFeedback.g.cs index f7e526d..458cc7a 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.PromptFeedback.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.PromptFeedback.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini ///
public sealed partial class PromptFeedback { - /// - /// Ratings for safety of the prompt. There is at most one rating per category. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("safetyRatings")] - public global::System.Collections.Generic.IList? SafetyRatings { get; set; } - /// /// Optional. If set, the prompt was blocked and no candidates are returned. Rephrase the prompt. /// @@ -21,6 +15,12 @@ public sealed partial class PromptFeedback [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonJsonConverter))] public global::Google.Gemini.PromptFeedbackBlockReason? BlockReason { get; set; } + /// + /// Ratings for safety of the prompt. There is at most one rating per category. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("safetyRatings")] + public global::System.Collections.Generic.IList? SafetyRatings { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,21 +30,21 @@ public sealed partial class PromptFeedback /// /// Initializes a new instance of the class. /// - /// - /// Ratings for safety of the prompt. There is at most one rating per category. - /// /// /// Optional. If set, the prompt was blocked and no candidates are returned. Rephrase the prompt. /// + /// + /// Ratings for safety of the prompt. There is at most one rating per category. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public PromptFeedback( - global::System.Collections.Generic.IList? safetyRatings, - global::Google.Gemini.PromptFeedbackBlockReason? blockReason) + global::Google.Gemini.PromptFeedbackBlockReason? blockReason, + global::System.Collections.Generic.IList? safetyRatings) { - this.SafetyRatings = safetyRatings; this.BlockReason = blockReason; + this.SafetyRatings = safetyRatings; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.RetrievedContext.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.RetrievedContext.g.cs index f8fc67e..5dd4bba 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.RetrievedContext.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.RetrievedContext.g.cs @@ -14,12 +14,6 @@ public sealed partial class RetrievedContext [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] public global::System.Collections.Generic.IList? CustomMetadata { get; set; } - /// - /// Optional. URI reference of the semantic retrieval document. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("uri")] - public string? Uri { get; set; } - /// /// Optional. Title of the document. /// @@ -38,6 +32,12 @@ public sealed partial class RetrievedContext [global::System.Text.Json.Serialization.JsonPropertyName("fileSearchStore")] public string? FileSearchStore { get; set; } + /// + /// Optional. URI reference of the semantic retrieval document. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("uri")] + public string? Uri { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -50,9 +50,6 @@ public sealed partial class RetrievedContext /// /// Optional. User-provided metadata about the retrieved context. /// - /// - /// Optional. URI reference of the semantic retrieval document. - /// /// /// Optional. Title of the document. /// @@ -62,21 +59,24 @@ public sealed partial class RetrievedContext /// /// Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123` /// + /// + /// Optional. URI reference of the semantic retrieval document. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public RetrievedContext( global::System.Collections.Generic.IList? customMetadata, - string? uri, string? title, string? text, - string? fileSearchStore) + string? fileSearchStore, + string? uri) { this.CustomMetadata = customMetadata; - this.Uri = uri; this.Title = title; this.Text = text; this.FileSearchStore = fileSearchStore; + this.Uri = uri; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ReviewSnippet.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ReviewSnippet.g.cs index dcbe94b..7faf206 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ReviewSnippet.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ReviewSnippet.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class ReviewSnippet { - /// - /// The ID of the review snippet. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("reviewId")] - public string? ReviewId { get; set; } - /// /// Title of the review. /// @@ -26,6 +20,12 @@ public sealed partial class ReviewSnippet [global::System.Text.Json.Serialization.JsonPropertyName("googleMapsUri")] public string? GoogleMapsUri { get; set; } + /// + /// The ID of the review snippet. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("reviewId")] + public string? ReviewId { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class ReviewSnippet /// /// Initializes a new instance of the class. /// - /// - /// The ID of the review snippet. - /// /// /// Title of the review. /// /// /// A link that corresponds to the user review on Google Maps. /// + /// + /// The ID of the review snippet. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ReviewSnippet( - string? reviewId, string? title, - string? googleMapsUri) + string? googleMapsUri, + string? reviewId) { - this.ReviewId = reviewId; this.Title = title; this.GoogleMapsUri = googleMapsUri; + this.ReviewId = reviewId; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SafetyRating.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SafetyRating.g.cs index 92d47ab..4d10712 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SafetyRating.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SafetyRating.g.cs @@ -15,6 +15,12 @@ public sealed partial class SafetyRating [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityJsonConverter))] public global::Google.Gemini.SafetyRatingProbability? Probability { get; set; } + /// + /// Was this content blocked because of this rating? + /// + [global::System.Text.Json.Serialization.JsonPropertyName("blocked")] + public bool? Blocked { get; set; } + /// /// Required. The category for this rating. /// @@ -22,12 +28,6 @@ public sealed partial class SafetyRating [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryJsonConverter))] public global::Google.Gemini.SafetyRatingCategory? Category { get; set; } - /// - /// Was this content blocked because of this rating? - /// - [global::System.Text.Json.Serialization.JsonPropertyName("blocked")] - public bool? Blocked { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -40,23 +40,23 @@ public sealed partial class SafetyRating /// /// Required. The probability of harm for this content. /// - /// - /// Required. The category for this rating. - /// /// /// Was this content blocked because of this rating? /// + /// + /// Required. The category for this rating. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public SafetyRating( global::Google.Gemini.SafetyRatingProbability? probability, - global::Google.Gemini.SafetyRatingCategory? category, - bool? blocked) + bool? blocked, + global::Google.Gemini.SafetyRatingCategory? category) { this.Probability = probability; - this.Category = category; this.Blocked = blocked; + this.Category = category; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Schema.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Schema.g.cs index faddd41..41ff7cb 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Schema.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Schema.g.cs @@ -9,22 +9,22 @@ namespace Google.Gemini public sealed partial class Schema { /// - /// Optional. Indicates if the value may be null. + /// Optional. The order of the properties. Not a standard field in open api spec. Used to determine the order of the properties in the response. /// - [global::System.Text.Json.Serialization.JsonPropertyName("nullable")] - public bool? Nullable { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("propertyOrdering")] + public global::System.Collections.Generic.IList? PropertyOrdering { get; set; } /// - /// Optional. Maximum value of the Type.INTEGER and Type.NUMBER + /// Optional. Pattern of the Type.STRING to restrict a string to a regular expression. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maximum")] - public double? Maximum { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("pattern")] + public string? Pattern { get; set; } /// - /// Optional. Minimum number of the elements for Type.ARRAY. + /// Optional. Possible values of the element of Type.STRING with enum format. For example we can define an Enum Direction as : {type:STRING, format:enum, enum:["EAST", NORTH", "SOUTH", "WEST"]} /// - [global::System.Text.Json.Serialization.JsonPropertyName("minItems")] - public string? MinItems { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("enum")] + public global::System.Collections.Generic.IList? Enum { get; set; } /// /// Optional. Minimum number of the properties for Type.OBJECT. @@ -33,29 +33,22 @@ public sealed partial class Schema public string? MinProperties { get; set; } /// - /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING - /// - [global::System.Text.Json.Serialization.JsonPropertyName("minLength")] - public string? MinLength { get; set; } - - /// - /// Optional. Maximum number of the properties for Type.OBJECT. + /// Optional. Maximum length of the Type.STRING /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxProperties")] - public string? MaxProperties { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxLength")] + public string? MaxLength { get; set; } /// - /// Optional. The value should be validated against any (one or more) of the subschemas in the list. + /// Optional. Example of the object. Will only populated when the object is the root. /// - [global::System.Text.Json.Serialization.JsonPropertyName("anyOf")] - public global::System.Collections.Generic.IList? AnyOf { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("example")] + public object? Example { get; set; } /// - /// Required. Data type. + /// Optional. Minimum number of the elements for Type.ARRAY. /// - [global::System.Text.Json.Serialization.JsonPropertyName("type")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.SchemaTypeJsonConverter))] - public global::Google.Gemini.SchemaType? Type { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minItems")] + public string? MinItems { get; set; } /// /// Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER @@ -64,58 +57,58 @@ public sealed partial class Schema public double? Minimum { get; set; } /// - /// Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality. + /// Optional. The value should be validated against any (one or more) of the subschemas in the list. /// - [global::System.Text.Json.Serialization.JsonPropertyName("format")] - public string? Format { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("anyOf")] + public global::System.Collections.Generic.IList? AnyOf { get; set; } /// - /// Optional. Possible values of the element of Type.STRING with enum format. For example we can define an Enum Direction as : {type:STRING, format:enum, enum:["EAST", NORTH", "SOUTH", "WEST"]} + /// Optional. The title of the schema. /// - [global::System.Text.Json.Serialization.JsonPropertyName("enum")] - public global::System.Collections.Generic.IList? Enum { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("title")] + public string? Title { get; set; } /// - /// Optional. Pattern of the Type.STRING to restrict a string to a regular expression. + /// Optional. Maximum value of the Type.INTEGER and Type.NUMBER /// - [global::System.Text.Json.Serialization.JsonPropertyName("pattern")] - public string? Pattern { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maximum")] + public double? Maximum { get; set; } /// - /// Optional. Required properties of Type.OBJECT. + /// Optional. Maximum number of the elements for Type.ARRAY. /// - [global::System.Text.Json.Serialization.JsonPropertyName("required")] - public global::System.Collections.Generic.IList? Required { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxItems")] + public string? MaxItems { get; set; } /// - /// Optional. Default value of the field. Per JSON Schema, this field is intended for documentation generators and doesn't affect validation. Thus it's included here and ignored so that developers who send schemas with a `default` field don't get unknown-field errors. + /// Optional. Properties of Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("default")] - public object? Default { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("properties")] + public global::System.Collections.Generic.Dictionary? Properties { get; set; } /// - /// Optional. Example of the object. Will only populated when the object is the root. + /// Optional. Indicates if the value may be null. /// - [global::System.Text.Json.Serialization.JsonPropertyName("example")] - public object? Example { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("nullable")] + public bool? Nullable { get; set; } /// - /// Optional. Maximum length of the Type.STRING + /// Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxLength")] - public string? MaxLength { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("description")] + public string? Description { get; set; } /// - /// Optional. Maximum number of the elements for Type.ARRAY. + /// Optional. Maximum number of the properties for Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxItems")] - public string? MaxItems { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxProperties")] + public string? MaxProperties { get; set; } /// - /// Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown. + /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING /// - [global::System.Text.Json.Serialization.JsonPropertyName("description")] - public string? Description { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minLength")] + public string? MinLength { get; set; } /// /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). @@ -124,22 +117,29 @@ public sealed partial class Schema public global::Google.Gemini.Schema? Items { get; set; } /// - /// Optional. The title of the schema. + /// Optional. Required properties of Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - public string? Title { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("required")] + public global::System.Collections.Generic.IList? Required { get; set; } /// - /// Optional. The order of the properties. Not a standard field in open api spec. Used to determine the order of the properties in the response. + /// Optional. Default value of the field. Per JSON Schema, this field is intended for documentation generators and doesn't affect validation. Thus it's included here and ignored so that developers who send schemas with a `default` field don't get unknown-field errors. /// - [global::System.Text.Json.Serialization.JsonPropertyName("propertyOrdering")] - public global::System.Collections.Generic.IList? PropertyOrdering { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("default")] + public object? Default { get; set; } /// - /// Optional. Properties of Type.OBJECT. + /// Required. Data type. /// - [global::System.Text.Json.Serialization.JsonPropertyName("properties")] - public global::System.Collections.Generic.Dictionary? Properties { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("type")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.SchemaTypeJsonConverter))] + public global::Google.Gemini.SchemaType? Type { get; set; } + + /// + /// Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("format")] + public string? Format { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -150,121 +150,121 @@ public sealed partial class Schema /// /// Initializes a new instance of the class. /// - /// - /// Optional. Indicates if the value may be null. + /// + /// Optional. The order of the properties. Not a standard field in open api spec. Used to determine the order of the properties in the response. /// - /// - /// Optional. Maximum value of the Type.INTEGER and Type.NUMBER + /// + /// Optional. Pattern of the Type.STRING to restrict a string to a regular expression. /// - /// - /// Optional. Minimum number of the elements for Type.ARRAY. + /// + /// Optional. Possible values of the element of Type.STRING with enum format. For example we can define an Enum Direction as : {type:STRING, format:enum, enum:["EAST", NORTH", "SOUTH", "WEST"]} /// /// /// Optional. Minimum number of the properties for Type.OBJECT. /// - /// - /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING - /// - /// - /// Optional. Maximum number of the properties for Type.OBJECT. + /// + /// Optional. Maximum length of the Type.STRING /// - /// - /// Optional. The value should be validated against any (one or more) of the subschemas in the list. + /// + /// Optional. Example of the object. Will only populated when the object is the root. /// - /// - /// Required. Data type. + /// + /// Optional. Minimum number of the elements for Type.ARRAY. /// /// /// Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER /// - /// - /// Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality. - /// - /// - /// Optional. Possible values of the element of Type.STRING with enum format. For example we can define an Enum Direction as : {type:STRING, format:enum, enum:["EAST", NORTH", "SOUTH", "WEST"]} - /// - /// - /// Optional. Pattern of the Type.STRING to restrict a string to a regular expression. - /// - /// - /// Optional. Required properties of Type.OBJECT. - /// - /// - /// Optional. Default value of the field. Per JSON Schema, this field is intended for documentation generators and doesn't affect validation. Thus it's included here and ignored so that developers who send schemas with a `default` field don't get unknown-field errors. + /// + /// Optional. The value should be validated against any (one or more) of the subschemas in the list. /// - /// - /// Optional. Example of the object. Will only populated when the object is the root. + /// + /// Optional. The title of the schema. /// - /// - /// Optional. Maximum length of the Type.STRING + /// + /// Optional. Maximum value of the Type.INTEGER and Type.NUMBER /// /// /// Optional. Maximum number of the elements for Type.ARRAY. /// + /// + /// Optional. Properties of Type.OBJECT. + /// + /// + /// Optional. Indicates if the value may be null. + /// /// /// Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown. /// + /// + /// Optional. Maximum number of the properties for Type.OBJECT. + /// + /// + /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING + /// /// /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). /// - /// - /// Optional. The title of the schema. + /// + /// Optional. Required properties of Type.OBJECT. /// - /// - /// Optional. The order of the properties. Not a standard field in open api spec. Used to determine the order of the properties in the response. + /// + /// Optional. Default value of the field. Per JSON Schema, this field is intended for documentation generators and doesn't affect validation. Thus it's included here and ignored so that developers who send schemas with a `default` field don't get unknown-field errors. /// - /// - /// Optional. Properties of Type.OBJECT. + /// + /// Required. Data type. + /// + /// + /// Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Schema( - bool? nullable, - double? maximum, - string? minItems, - string? minProperties, - string? minLength, - string? maxProperties, - global::System.Collections.Generic.IList? anyOf, - global::Google.Gemini.SchemaType? type, - double? minimum, - string? format, - global::System.Collections.Generic.IList? @enum, + global::System.Collections.Generic.IList? propertyOrdering, string? pattern, - global::System.Collections.Generic.IList? required, - object? @default, - object? example, + global::System.Collections.Generic.IList? @enum, + string? minProperties, string? maxLength, + object? example, + string? minItems, + double? minimum, + global::System.Collections.Generic.IList? anyOf, + string? title, + double? maximum, string? maxItems, + global::System.Collections.Generic.Dictionary? properties, + bool? nullable, string? description, + string? maxProperties, + string? minLength, global::Google.Gemini.Schema? items, - string? title, - global::System.Collections.Generic.IList? propertyOrdering, - global::System.Collections.Generic.Dictionary? properties) + global::System.Collections.Generic.IList? required, + object? @default, + global::Google.Gemini.SchemaType? type, + string? format) { - this.Nullable = nullable; - this.Maximum = maximum; - this.MinItems = minItems; - this.MinProperties = minProperties; - this.MinLength = minLength; - this.MaxProperties = maxProperties; - this.AnyOf = anyOf; - this.Type = type; - this.Minimum = minimum; - this.Format = format; - this.Enum = @enum; + this.PropertyOrdering = propertyOrdering; this.Pattern = pattern; - this.Required = required; - this.Default = @default; - this.Example = example; + this.Enum = @enum; + this.MinProperties = minProperties; this.MaxLength = maxLength; + this.Example = example; + this.MinItems = minItems; + this.Minimum = minimum; + this.AnyOf = anyOf; + this.Title = title; + this.Maximum = maximum; this.MaxItems = maxItems; + this.Properties = properties; + this.Nullable = nullable; this.Description = description; + this.MaxProperties = maxProperties; + this.MinLength = minLength; this.Items = items; - this.Title = title; - this.PropertyOrdering = propertyOrdering; - this.Properties = properties; + this.Required = required; + this.Default = @default; + this.Type = type; + this.Format = format; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeakerVoiceConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeakerVoiceConfig.g.cs index 370880f..f1ef065 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeakerVoiceConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeakerVoiceConfig.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class SpeakerVoiceConfig { - /// - /// The configuration for the voice to use. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("voiceConfig")] - public global::Google.Gemini.VoiceConfig? VoiceConfig { get; set; } - /// /// Required. The name of the speaker to use. Should be the same as in the prompt. /// [global::System.Text.Json.Serialization.JsonPropertyName("speaker")] public string? Speaker { get; set; } + /// + /// The configuration for the voice to use. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("voiceConfig")] + public global::Google.Gemini.VoiceConfig? VoiceConfig { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class SpeakerVoiceConfig /// /// Initializes a new instance of the class. /// - /// - /// The configuration for the voice to use. - /// /// /// Required. The name of the speaker to use. Should be the same as in the prompt. /// + /// + /// The configuration for the voice to use. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public SpeakerVoiceConfig( - global::Google.Gemini.VoiceConfig? voiceConfig, - string? speaker) + string? speaker, + global::Google.Gemini.VoiceConfig? voiceConfig) { - this.VoiceConfig = voiceConfig; this.Speaker = speaker; + this.VoiceConfig = voiceConfig; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Status.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Status.g.cs index fcc62f1..7afcb10 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Status.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Status.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class Status { - /// - /// A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("message")] - public string? Message { get; set; } - /// /// A list of messages that carry the error details. There is a common set of message types for APIs to use. /// @@ -26,6 +20,12 @@ public sealed partial class Status [global::System.Text.Json.Serialization.JsonPropertyName("code")] public int? Code { get; set; } + /// + /// A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("message")] + public string? Message { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class Status /// /// Initializes a new instance of the class. /// - /// - /// A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client. - /// /// /// A list of messages that carry the error details. There is a common set of message types for APIs to use. /// /// /// The status code, which should be an enum value of google.rpc.Code. /// + /// + /// A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Status( - string? message, global::System.Collections.Generic.IList? details, - int? code) + int? code, + string? message) { - this.Message = message; this.Details = details; this.Code = code; + this.Message = message; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.StreamableHttpTransport.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.StreamableHttpTransport.g.cs index 2f622ce..eba829d 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.StreamableHttpTransport.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.StreamableHttpTransport.g.cs @@ -21,10 +21,10 @@ public sealed partial class StreamableHttpTransport public bool? TerminateOnClose { get; set; } /// - /// HTTP timeout for regular operations. + /// Timeout for SSE read operations. /// - [global::System.Text.Json.Serialization.JsonPropertyName("timeout")] - public string? Timeout { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sseReadTimeout")] + public string? SseReadTimeout { get; set; } /// /// Optional: Fields for authentication headers, timeouts, etc., if needed. @@ -33,10 +33,10 @@ public sealed partial class StreamableHttpTransport public global::System.Collections.Generic.Dictionary? Headers { get; set; } /// - /// Timeout for SSE read operations. + /// HTTP timeout for regular operations. /// - [global::System.Text.Json.Serialization.JsonPropertyName("sseReadTimeout")] - public string? SseReadTimeout { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("timeout")] + public string? Timeout { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -53,14 +53,14 @@ public sealed partial class StreamableHttpTransport /// /// Whether to close the client session when the transport closes. /// - /// - /// HTTP timeout for regular operations. + /// + /// Timeout for SSE read operations. /// /// /// Optional: Fields for authentication headers, timeouts, etc., if needed. /// - /// - /// Timeout for SSE read operations. + /// + /// HTTP timeout for regular operations. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] @@ -68,15 +68,15 @@ public sealed partial class StreamableHttpTransport public StreamableHttpTransport( string? url, bool? terminateOnClose, - string? timeout, + string? sseReadTimeout, global::System.Collections.Generic.Dictionary? headers, - string? sseReadTimeout) + string? timeout) { this.Url = url; this.TerminateOnClose = terminateOnClose; - this.Timeout = timeout; - this.Headers = headers; this.SseReadTimeout = sseReadTimeout; + this.Headers = headers; + this.Timeout = timeout; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ThinkingConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ThinkingConfig.g.cs index b3cdd8f..5e903db 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ThinkingConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ThinkingConfig.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ThinkingConfig { - /// - /// The number of thoughts tokens that the model should generate. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("thinkingBudget")] - public int? ThinkingBudget { get; set; } - /// /// Indicates whether to include thoughts in the response. If true, thoughts are returned only when available. /// [global::System.Text.Json.Serialization.JsonPropertyName("includeThoughts")] public bool? IncludeThoughts { get; set; } + /// + /// The number of thoughts tokens that the model should generate. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("thinkingBudget")] + public int? ThinkingBudget { get; set; } + /// /// Optional. Controls the maximum depth of the model's internal reasoning process before it produces a response. If not specified, the default is HIGH. Recommended for Gemini 3 or later models. Use with earlier models results in an error. /// @@ -36,12 +36,12 @@ public sealed partial class ThinkingConfig /// /// Initializes a new instance of the class. /// - /// - /// The number of thoughts tokens that the model should generate. - /// /// /// Indicates whether to include thoughts in the response. If true, thoughts are returned only when available. /// + /// + /// The number of thoughts tokens that the model should generate. + /// /// /// Optional. Controls the maximum depth of the model's internal reasoning process before it produces a response. If not specified, the default is HIGH. Recommended for Gemini 3 or later models. Use with earlier models results in an error. /// @@ -49,12 +49,12 @@ public sealed partial class ThinkingConfig [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ThinkingConfig( - int? thinkingBudget, bool? includeThoughts, + int? thinkingBudget, global::Google.Gemini.ThinkingConfigThinkingLevel? thinkingLevel) { - this.ThinkingBudget = thinkingBudget; this.IncludeThoughts = includeThoughts; + this.ThinkingBudget = thinkingBudget; this.ThinkingLevel = thinkingLevel; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Tool.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Tool.g.cs index a4c830d..469928b 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Tool.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Tool.g.cs @@ -9,22 +9,16 @@ namespace Google.Gemini public sealed partial class Tool { /// - /// Tool that executes code generated by the model, and automatically returns the result to the model. See also `ExecutableCode` and `CodeExecutionResult` which are only generated when using this tool. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("codeExecution")] - public global::Google.Gemini.CodeExecution? CodeExecution { get; set; } - - /// - /// Tool to support URL context retrieval. + /// Optional. A list of `FunctionDeclarations` available to the model that can be used for function calling. The model or system does not execute the function. Instead the defined function may be returned as a FunctionCall with arguments to the client side for execution. The model may decide to call a subset of these functions by populating FunctionCall in the response. The next conversation turn may contain a FunctionResponse with the Content.role "function" generation context for the next model turn. /// - [global::System.Text.Json.Serialization.JsonPropertyName("urlContext")] - public global::Google.Gemini.UrlContext? UrlContext { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("functionDeclarations")] + public global::System.Collections.Generic.IList? FunctionDeclarations { get; set; } /// - /// The GoogleMaps Tool that provides geospatial context for the user's query. + /// Tool that executes code generated by the model, and automatically returns the result to the model. See also `ExecutableCode` and `CodeExecutionResult` which are only generated when using this tool. /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleMaps")] - public global::Google.Gemini.GoogleMaps? GoogleMaps { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("codeExecution")] + public global::Google.Gemini.CodeExecution? CodeExecution { get; set; } /// /// Computer Use tool type. @@ -33,22 +27,22 @@ public sealed partial class Tool public global::Google.Gemini.ComputerUse? ComputerUse { get; set; } /// - /// The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API. + /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. /// - [global::System.Text.Json.Serialization.JsonPropertyName("fileSearch")] - public global::Google.Gemini.FileSearch? FileSearch { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("googleSearch")] + public global::Google.Gemini.GoogleSearch? GoogleSearch { get; set; } /// - /// Optional. A list of `FunctionDeclarations` available to the model that can be used for function calling. The model or system does not execute the function. Instead the defined function may be returned as a FunctionCall with arguments to the client side for execution. The model may decide to call a subset of these functions by populating FunctionCall in the response. The next conversation turn may contain a FunctionResponse with the Content.role "function" generation context for the next model turn. + /// Tool to support URL context retrieval. /// - [global::System.Text.Json.Serialization.JsonPropertyName("functionDeclarations")] - public global::System.Collections.Generic.IList? FunctionDeclarations { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("urlContext")] + public global::Google.Gemini.UrlContext? UrlContext { get; set; } /// - /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. + /// The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API. /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleSearch")] - public global::Google.Gemini.GoogleSearch? GoogleSearch { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("fileSearch")] + public global::Google.Gemini.FileSearch? FileSearch { get; set; } /// /// Optional. MCP Servers to connect to. @@ -62,6 +56,12 @@ public sealed partial class Tool [global::System.Text.Json.Serialization.JsonPropertyName("googleSearchRetrieval")] public global::Google.Gemini.GoogleSearchRetrieval? GoogleSearchRetrieval { get; set; } + /// + /// The GoogleMaps Tool that provides geospatial context for the user's query. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("googleMaps")] + public global::Google.Gemini.GoogleMaps? GoogleMaps { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -71,56 +71,56 @@ public sealed partial class Tool /// /// Initializes a new instance of the class. /// + /// + /// Optional. A list of `FunctionDeclarations` available to the model that can be used for function calling. The model or system does not execute the function. Instead the defined function may be returned as a FunctionCall with arguments to the client side for execution. The model may decide to call a subset of these functions by populating FunctionCall in the response. The next conversation turn may contain a FunctionResponse with the Content.role "function" generation context for the next model turn. + /// /// /// Tool that executes code generated by the model, and automatically returns the result to the model. See also `ExecutableCode` and `CodeExecutionResult` which are only generated when using this tool. /// - /// - /// Tool to support URL context retrieval. - /// - /// - /// The GoogleMaps Tool that provides geospatial context for the user's query. - /// /// /// Computer Use tool type. /// - /// - /// The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API. - /// - /// - /// Optional. A list of `FunctionDeclarations` available to the model that can be used for function calling. The model or system does not execute the function. Instead the defined function may be returned as a FunctionCall with arguments to the client side for execution. The model may decide to call a subset of these functions by populating FunctionCall in the response. The next conversation turn may contain a FunctionResponse with the Content.role "function" generation context for the next model turn. - /// /// /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. /// + /// + /// Tool to support URL context retrieval. + /// + /// + /// The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API. + /// /// /// Optional. MCP Servers to connect to. /// /// /// Tool to retrieve public web data for grounding, powered by Google. /// + /// + /// The GoogleMaps Tool that provides geospatial context for the user's query. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Tool( + global::System.Collections.Generic.IList? functionDeclarations, global::Google.Gemini.CodeExecution? codeExecution, - global::Google.Gemini.UrlContext? urlContext, - global::Google.Gemini.GoogleMaps? googleMaps, global::Google.Gemini.ComputerUse? computerUse, - global::Google.Gemini.FileSearch? fileSearch, - global::System.Collections.Generic.IList? functionDeclarations, global::Google.Gemini.GoogleSearch? googleSearch, + global::Google.Gemini.UrlContext? urlContext, + global::Google.Gemini.FileSearch? fileSearch, global::System.Collections.Generic.IList? mcpServers, - global::Google.Gemini.GoogleSearchRetrieval? googleSearchRetrieval) + global::Google.Gemini.GoogleSearchRetrieval? googleSearchRetrieval, + global::Google.Gemini.GoogleMaps? googleMaps) { + this.FunctionDeclarations = functionDeclarations; this.CodeExecution = codeExecution; - this.UrlContext = urlContext; - this.GoogleMaps = googleMaps; this.ComputerUse = computerUse; - this.FileSearch = fileSearch; - this.FunctionDeclarations = functionDeclarations; this.GoogleSearch = googleSearch; + this.UrlContext = urlContext; + this.FileSearch = fileSearch; this.McpServers = mcpServers; this.GoogleSearchRetrieval = googleSearchRetrieval; + this.GoogleMaps = googleMaps; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolCall.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolCall.g.cs index 74dded9..dfede8e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolCall.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolCall.g.cs @@ -8,6 +8,13 @@ namespace Google.Gemini /// public sealed partial class ToolCall { + /// + /// Required. The type of tool that was called. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("toolType")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeJsonConverter))] + public global::Google.Gemini.ToolCallToolType? ToolType { get; set; } + /// /// Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`. /// @@ -20,13 +27,6 @@ public sealed partial class ToolCall [global::System.Text.Json.Serialization.JsonPropertyName("args")] public object? Args { get; set; } - /// - /// Required. The type of tool that was called. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("toolType")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeJsonConverter))] - public global::Google.Gemini.ToolCallToolType? ToolType { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -36,26 +36,26 @@ public sealed partial class ToolCall /// /// Initializes a new instance of the class. /// + /// + /// Required. The type of tool that was called. + /// /// /// Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`. /// /// /// Optional. The tool call arguments. Example: {"arg1" : "value1", "arg2" : "value2" , ...} /// - /// - /// Required. The type of tool that was called. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ToolCall( + global::Google.Gemini.ToolCallToolType? toolType, string? id, - object? args, - global::Google.Gemini.ToolCallToolType? toolType) + object? args) { + this.ToolType = toolType; this.Id = id; this.Args = args; - this.ToolType = toolType; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolConfig.g.cs index 3a67d3c..78771bb 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolConfig.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class ToolConfig { - /// - /// Optional. If true, the API response will include the server-side tool calls and responses within the `Content` message. This allows clients to observe the server's tool interactions. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("includeServerSideToolInvocations")] - public bool? IncludeServerSideToolInvocations { get; set; } - /// /// Configuration for specifying function calling behavior. /// @@ -26,6 +20,12 @@ public sealed partial class ToolConfig [global::System.Text.Json.Serialization.JsonPropertyName("retrievalConfig")] public global::Google.Gemini.RetrievalConfig? RetrievalConfig { get; set; } + /// + /// Optional. If true, the API response will include the server-side tool calls and responses within the `Content` message. This allows clients to observe the server's tool interactions. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("includeServerSideToolInvocations")] + public bool? IncludeServerSideToolInvocations { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class ToolConfig /// /// Initializes a new instance of the class. /// - /// - /// Optional. If true, the API response will include the server-side tool calls and responses within the `Content` message. This allows clients to observe the server's tool interactions. - /// /// /// Configuration for specifying function calling behavior. /// /// /// Retrieval config. /// + /// + /// Optional. If true, the API response will include the server-side tool calls and responses within the `Content` message. This allows clients to observe the server's tool interactions. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ToolConfig( - bool? includeServerSideToolInvocations, global::Google.Gemini.FunctionCallingConfig? functionCallingConfig, - global::Google.Gemini.RetrievalConfig? retrievalConfig) + global::Google.Gemini.RetrievalConfig? retrievalConfig, + bool? includeServerSideToolInvocations) { - this.IncludeServerSideToolInvocations = includeServerSideToolInvocations; this.FunctionCallingConfig = functionCallingConfig; this.RetrievalConfig = retrievalConfig; + this.IncludeServerSideToolInvocations = includeServerSideToolInvocations; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolResponse.g.cs index 21b7c61..8a47cf0 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolResponse.g.cs @@ -14,6 +14,12 @@ public sealed partial class ToolResponse [global::System.Text.Json.Serialization.JsonPropertyName("id")] public string? Id { get; set; } + /// + /// Optional. The tool response. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("response")] + public object? Response { get; set; } + /// /// Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`. /// @@ -21,12 +27,6 @@ public sealed partial class ToolResponse [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeJsonConverter))] public global::Google.Gemini.ToolResponseToolType? ToolType { get; set; } - /// - /// Optional. The tool response. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("response")] - public object? Response { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -39,23 +39,23 @@ public sealed partial class ToolResponse /// /// Optional. The identifier of the tool call this response is for. /// - /// - /// Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`. - /// /// /// Optional. The tool response. /// + /// + /// Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ToolResponse( string? id, - global::Google.Gemini.ToolResponseToolType? toolType, - object? response) + object? response, + global::Google.Gemini.ToolResponseToolType? toolType) { this.Id = id; - this.ToolType = toolType; this.Response = response; + this.ToolType = toolType; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TunedModel.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TunedModel.g.cs index b81651b..29b1589 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TunedModel.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TunedModel.g.cs @@ -8,12 +8,39 @@ namespace Google.Gemini /// public sealed partial class TunedModel { + /// + /// Optional. List of project numbers that have read access to the tuned model. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("readerProjectNumbers")] + public global::System.Collections.Generic.IList? ReaderProjectNumbers { get; set; } + + /// + /// Tuning tasks that create tuned models. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("tuningTask")] + public global::Google.Gemini.TuningTask? TuningTask { get; set; } + + /// + /// Output only. The timestamp when this model was updated.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } + /// /// Tuned model as a source for training a new model. /// [global::System.Text.Json.Serialization.JsonPropertyName("tunedModelSource")] public global::Google.Gemini.TunedModelSource? TunedModelSource { get; set; } + /// + /// Output only. The state of the tuned model.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("state")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.TunedModelStateJsonConverter))] + public global::Google.Gemini.TunedModelState? State { get; set; } + /// /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` /// @@ -27,16 +54,11 @@ public sealed partial class TunedModel public string? Description { get; set; } /// - /// Optional. List of project numbers that have read access to the tuned model. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("readerProjectNumbers")] - public global::System.Collections.Generic.IList? ReaderProjectNumbers { get; set; } - - /// - /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. + /// Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] - public float? Temperature { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. @@ -45,18 +67,10 @@ public sealed partial class TunedModel public float? TopP { get; set; } /// - /// Output only. The state of the tuned model.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("state")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.TunedModelStateJsonConverter))] - public global::Google.Gemini.TunedModelState? State { get; set; } - - /// - /// Tuning tasks that create tuned models. + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// - [global::System.Text.Json.Serialization.JsonPropertyName("tuningTask")] - public global::Google.Gemini.TuningTask? TuningTask { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. @@ -64,13 +78,6 @@ public sealed partial class TunedModel [global::System.Text.Json.Serialization.JsonPropertyName("topK")] public int? TopK { get; set; } - /// - /// Output only. The timestamp when this model was updated.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } - /// /// Output only. The timestamp when this model was created.
/// Included only in responses @@ -79,17 +86,10 @@ public sealed partial class TunedModel public string? CreateTime { get; set; } /// - /// Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } - - /// - /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. + /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] + public float? Temperature { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -100,80 +100,80 @@ public sealed partial class TunedModel /// /// Initializes a new instance of the class. /// + /// + /// Optional. List of project numbers that have read access to the tuned model. + /// + /// + /// Tuning tasks that create tuned models. + /// + /// + /// Output only. The timestamp when this model was updated.
+ /// Included only in responses + /// /// /// Tuned model as a source for training a new model. /// + /// + /// Output only. The state of the tuned model.
+ /// Included only in responses + /// /// /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` /// /// /// Optional. A short description of this model. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. - /// - /// - /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. + /// + /// Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`
+ /// Included only in responses /// /// /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Output only. The state of the tuned model.
- /// Included only in responses - /// - /// - /// Tuning tasks that create tuned models. + /// + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// /// /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Output only. The timestamp when this model was updated.
- /// Included only in responses - /// /// /// Output only. The timestamp when this model was created.
/// Included only in responses /// - /// - /// Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`
- /// Included only in responses - /// - /// - /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. + /// + /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public TunedModel( + global::System.Collections.Generic.IList? readerProjectNumbers, + global::Google.Gemini.TuningTask? tuningTask, + string? updateTime, global::Google.Gemini.TunedModelSource? tunedModelSource, + global::Google.Gemini.TunedModelState? state, string? baseModel, string? description, - global::System.Collections.Generic.IList? readerProjectNumbers, - float? temperature, + string? name, float? topP, - global::Google.Gemini.TunedModelState? state, - global::Google.Gemini.TuningTask? tuningTask, + string? displayName, int? topK, - string? updateTime, string? createTime, - string? name, - string? displayName) + float? temperature) { + this.ReaderProjectNumbers = readerProjectNumbers; + this.TuningTask = tuningTask; + this.UpdateTime = updateTime; this.TunedModelSource = tunedModelSource; + this.State = state; this.BaseModel = baseModel; this.Description = description; - this.ReaderProjectNumbers = readerProjectNumbers; - this.Temperature = temperature; + this.Name = name; this.TopP = topP; - this.State = state; - this.TuningTask = tuningTask; + this.DisplayName = displayName; this.TopK = topK; - this.UpdateTime = updateTime; this.CreateTime = createTime; - this.Name = name; - this.DisplayName = displayName; + this.Temperature = temperature; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TuningSnapshot.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TuningSnapshot.g.cs index 821e303..2f0a634 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TuningSnapshot.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TuningSnapshot.g.cs @@ -23,18 +23,18 @@ public sealed partial class TuningSnapshot public float? MeanLoss { get; set; } /// - /// Output only. The tuning step.
+ /// Output only. The timestamp when this metric was computed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("step")] - public int? Step { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("computeTime")] + public string? ComputeTime { get; set; } /// - /// Output only. The timestamp when this metric was computed.
+ /// Output only. The tuning step.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("computeTime")] - public string? ComputeTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("step")] + public int? Step { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -53,27 +53,27 @@ public sealed partial class TuningSnapshot /// Output only. The mean loss of the training examples for this step.
/// Included only in responses /// - /// - /// Output only. The tuning step.
- /// Included only in responses - /// /// /// Output only. The timestamp when this metric was computed.
/// Included only in responses /// + /// + /// Output only. The tuning step.
+ /// Included only in responses + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public TuningSnapshot( int? epoch, float? meanLoss, - int? step, - string? computeTime) + string? computeTime, + int? step) { this.Epoch = epoch; this.MeanLoss = meanLoss; - this.Step = step; this.ComputeTime = computeTime; + this.Step = step; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TuningTask.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TuningTask.g.cs index 65c2d46..f35cdbc 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TuningTask.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TuningTask.g.cs @@ -9,17 +9,11 @@ namespace Google.Gemini public sealed partial class TuningTask { /// - /// Dataset for training or validation. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("trainingData")] - public global::Google.Gemini.Dataset? TrainingData { get; set; } - - /// - /// Output only. The timestamp when tuning this model completed.
+ /// Output only. The timestamp when tuning this model started.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("completeTime")] - public string? CompleteTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("startTime")] + public string? StartTime { get; set; } /// /// Output only. Metrics collected during tuning.
@@ -29,17 +23,23 @@ public sealed partial class TuningTask public global::System.Collections.Generic.IList? Snapshots { get; set; } /// - /// Output only. The timestamp when tuning this model started.
+ /// Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("hyperparameters")] + public global::Google.Gemini.Hyperparameters? Hyperparameters { get; set; } + + /// + /// Output only. The timestamp when tuning this model completed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("startTime")] - public string? StartTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("completeTime")] + public string? CompleteTime { get; set; } /// - /// Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance + /// Dataset for training or validation. /// - [global::System.Text.Json.Serialization.JsonPropertyName("hyperparameters")] - public global::Google.Gemini.Hyperparameters? Hyperparameters { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("trainingData")] + public global::Google.Gemini.Dataset? TrainingData { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -50,39 +50,39 @@ public sealed partial class TuningTask /// /// Initializes a new instance of the class. /// - /// - /// Dataset for training or validation. - /// - /// - /// Output only. The timestamp when tuning this model completed.
+ /// + /// Output only. The timestamp when tuning this model started.
/// Included only in responses /// /// /// Output only. Metrics collected during tuning.
/// Included only in responses /// - /// - /// Output only. The timestamp when tuning this model started.
- /// Included only in responses - /// /// /// Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance /// + /// + /// Output only. The timestamp when tuning this model completed.
+ /// Included only in responses + /// + /// + /// Dataset for training or validation. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public TuningTask( - global::Google.Gemini.Dataset? trainingData, - string? completeTime, - global::System.Collections.Generic.IList? snapshots, string? startTime, - global::Google.Gemini.Hyperparameters? hyperparameters) + global::System.Collections.Generic.IList? snapshots, + global::Google.Gemini.Hyperparameters? hyperparameters, + string? completeTime, + global::Google.Gemini.Dataset? trainingData) { - this.TrainingData = trainingData; - this.CompleteTime = completeTime; - this.Snapshots = snapshots; this.StartTime = startTime; + this.Snapshots = snapshots; this.Hyperparameters = hyperparameters; + this.CompleteTime = completeTime; + this.TrainingData = trainingData; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UploadToFileSearchStoreRequest.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UploadToFileSearchStoreRequest.g.cs index 2768899..fa4c84a 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UploadToFileSearchStoreRequest.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UploadToFileSearchStoreRequest.g.cs @@ -9,16 +9,16 @@ namespace Google.Gemini public sealed partial class UploadToFileSearchStoreRequest { /// - /// Optional. Display name of the created document. + /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("chunkingConfig")] + public global::Google.Gemini.ChunkingConfig? ChunkingConfig { get; set; } /// - /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. + /// Optional. Display name of the created document. /// - [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] - public string? MimeType { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// /// Custom metadata to be associated with the data. @@ -27,10 +27,10 @@ public sealed partial class UploadToFileSearchStoreRequest public global::System.Collections.Generic.IList? CustomMetadata { get; set; } /// - /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto + /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. /// - [global::System.Text.Json.Serialization.JsonPropertyName("chunkingConfig")] - public global::Google.Gemini.ChunkingConfig? ChunkingConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] + public string? MimeType { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -41,31 +41,31 @@ public sealed partial class UploadToFileSearchStoreRequest /// /// Initializes a new instance of the class. /// + /// + /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto + /// /// /// Optional. Display name of the created document. /// - /// - /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. - /// /// /// Custom metadata to be associated with the data. /// - /// - /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto + /// + /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public UploadToFileSearchStoreRequest( + global::Google.Gemini.ChunkingConfig? chunkingConfig, string? displayName, - string? mimeType, global::System.Collections.Generic.IList? customMetadata, - global::Google.Gemini.ChunkingConfig? chunkingConfig) + string? mimeType) { + this.ChunkingConfig = chunkingConfig; this.DisplayName = displayName; - this.MimeType = mimeType; this.CustomMetadata = customMetadata; - this.ChunkingConfig = chunkingConfig; + this.MimeType = mimeType; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UsageMetadata.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UsageMetadata.g.cs index a9692da..cfa787a 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UsageMetadata.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UsageMetadata.g.cs @@ -9,49 +9,51 @@ namespace Google.Gemini public sealed partial class UsageMetadata { /// - /// Number of tokens in the prompt. When `cached_content` is set, this is still the total effective prompt size meaning this includes the number of tokens in the cached content. + /// Output only. List of modalities of the cached content in the request input.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("promptTokenCount")] - public int? PromptTokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("cacheTokensDetails")] + public global::System.Collections.Generic.IList? CacheTokensDetails { get; set; } /// - /// Number of tokens in the cached part of the prompt (the cached content) + /// Total number of tokens across all the generated response candidates. /// - [global::System.Text.Json.Serialization.JsonPropertyName("cachedContentTokenCount")] - public int? CachedContentTokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokenCount")] + public int? CandidatesTokenCount { get; set; } /// - /// Output only. List of modalities that were processed for tool-use request inputs.
+ /// Output only. Number of tokens present in tool-use prompt(s).
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("toolUsePromptTokensDetails")] - public global::System.Collections.Generic.IList? ToolUsePromptTokensDetails { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("toolUsePromptTokenCount")] + public int? ToolUsePromptTokenCount { get; set; } /// - /// Output only. Number of tokens present in tool-use prompt(s).
+ /// Output only. List of modalities that were returned in the response.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("toolUsePromptTokenCount")] - public int? ToolUsePromptTokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokensDetails")] + public global::System.Collections.Generic.IList? CandidatesTokensDetails { get; set; } /// - /// Total number of tokens across all the generated response candidates. + /// Output only. Number of tokens of thoughts for thinking models.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokenCount")] - public int? CandidatesTokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("thoughtsTokenCount")] + public int? ThoughtsTokenCount { get; set; } /// - /// Total token count for the generation request (prompt + response candidates). + /// Number of tokens in the prompt. When `cached_content` is set, this is still the total effective prompt size meaning this includes the number of tokens in the cached content. /// - [global::System.Text.Json.Serialization.JsonPropertyName("totalTokenCount")] - public int? TotalTokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("promptTokenCount")] + public int? PromptTokenCount { get; set; } /// - /// Output only. List of modalities that were returned in the response.
+ /// Output only. List of modalities that were processed for tool-use request inputs.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokensDetails")] - public global::System.Collections.Generic.IList? CandidatesTokensDetails { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("toolUsePromptTokensDetails")] + public global::System.Collections.Generic.IList? ToolUsePromptTokensDetails { get; set; } /// /// Output only. List of modalities that were processed in the request input.
@@ -61,18 +63,16 @@ public sealed partial class UsageMetadata public global::System.Collections.Generic.IList? PromptTokensDetails { get; set; } /// - /// Output only. List of modalities of the cached content in the request input.
- /// Included only in responses + /// Number of tokens in the cached part of the prompt (the cached content) ///
- [global::System.Text.Json.Serialization.JsonPropertyName("cacheTokensDetails")] - public global::System.Collections.Generic.IList? CacheTokensDetails { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("cachedContentTokenCount")] + public int? CachedContentTokenCount { get; set; } /// - /// Output only. Number of tokens of thoughts for thinking models.
- /// Included only in responses + /// Total token count for the generation request (prompt + response candidates). ///
- [global::System.Text.Json.Serialization.JsonPropertyName("thoughtsTokenCount")] - public int? ThoughtsTokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("totalTokenCount")] + public int? TotalTokenCount { get; set; } /// /// Output only. Number of tokens in the response. Used by Gemini 3.1+ Live API models instead of candidatesTokenCount.
@@ -97,42 +97,42 @@ public sealed partial class UsageMetadata /// /// Initializes a new instance of the class. /// - /// - /// Number of tokens in the prompt. When `cached_content` is set, this is still the total effective prompt size meaning this includes the number of tokens in the cached content. - /// - /// - /// Number of tokens in the cached part of the prompt (the cached content) - /// - /// - /// Output only. List of modalities that were processed for tool-use request inputs.
- /// Included only in responses - /// - /// - /// Output only. Number of tokens present in tool-use prompt(s).
+ /// + /// Output only. List of modalities of the cached content in the request input.
/// Included only in responses /// /// /// Total number of tokens across all the generated response candidates. /// - /// - /// Total token count for the generation request (prompt + response candidates). + /// + /// Output only. Number of tokens present in tool-use prompt(s).
+ /// Included only in responses /// /// /// Output only. List of modalities that were returned in the response.
/// Included only in responses /// - /// - /// Output only. List of modalities that were processed in the request input.
+ /// + /// Output only. Number of tokens of thoughts for thinking models.
/// Included only in responses /// - /// - /// Output only. List of modalities of the cached content in the request input.
+ /// + /// Number of tokens in the prompt. When `cached_content` is set, this is still the total effective prompt size meaning this includes the number of tokens in the cached content. + /// + /// + /// Output only. List of modalities that were processed for tool-use request inputs.
/// Included only in responses /// - /// - /// Output only. Number of tokens of thoughts for thinking models.
+ /// + /// Output only. List of modalities that were processed in the request input.
/// Included only in responses /// + /// + /// Number of tokens in the cached part of the prompt (the cached content) + /// + /// + /// Total token count for the generation request (prompt + response candidates). + /// /// /// Output only. Number of tokens in the response. Used by Gemini 3.1+ Live API models instead of candidatesTokenCount.
/// Included only in responses @@ -145,29 +145,29 @@ public sealed partial class UsageMetadata [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public UsageMetadata( - int? promptTokenCount, - int? cachedContentTokenCount, - global::System.Collections.Generic.IList? toolUsePromptTokensDetails, - int? toolUsePromptTokenCount, + global::System.Collections.Generic.IList? cacheTokensDetails, int? candidatesTokenCount, - int? totalTokenCount, + int? toolUsePromptTokenCount, global::System.Collections.Generic.IList? candidatesTokensDetails, - global::System.Collections.Generic.IList? promptTokensDetails, - global::System.Collections.Generic.IList? cacheTokensDetails, int? thoughtsTokenCount, + int? promptTokenCount, + global::System.Collections.Generic.IList? toolUsePromptTokensDetails, + global::System.Collections.Generic.IList? promptTokensDetails, + int? cachedContentTokenCount, + int? totalTokenCount, int? responseTokenCount, global::System.Collections.Generic.IList? responseTokensDetails) { - this.PromptTokenCount = promptTokenCount; - this.CachedContentTokenCount = cachedContentTokenCount; - this.ToolUsePromptTokensDetails = toolUsePromptTokensDetails; - this.ToolUsePromptTokenCount = toolUsePromptTokenCount; + this.CacheTokensDetails = cacheTokensDetails; this.CandidatesTokenCount = candidatesTokenCount; - this.TotalTokenCount = totalTokenCount; + this.ToolUsePromptTokenCount = toolUsePromptTokenCount; this.CandidatesTokensDetails = candidatesTokensDetails; - this.PromptTokensDetails = promptTokensDetails; - this.CacheTokensDetails = cacheTokensDetails; this.ThoughtsTokenCount = thoughtsTokenCount; + this.PromptTokenCount = promptTokenCount; + this.ToolUsePromptTokensDetails = toolUsePromptTokensDetails; + this.PromptTokensDetails = promptTokensDetails; + this.CachedContentTokenCount = cachedContentTokenCount; + this.TotalTokenCount = totalTokenCount; this.ResponseTokenCount = responseTokenCount; this.ResponseTokensDetails = responseTokensDetails; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.VideoMetadata.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.VideoMetadata.g.cs index 1ade518..3d0c3e5 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.VideoMetadata.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.VideoMetadata.g.cs @@ -10,11 +10,11 @@ namespace Google.Gemini public sealed partial class VideoMetadata { /// - /// Optional. The start offset of the video. + /// Optional. The frame rate of the video sent to the model. If not specified, the default value will be 1.0. The fps range is (0.0, 24.0]. /// - [global::System.Text.Json.Serialization.JsonPropertyName("startOffset")] + [global::System.Text.Json.Serialization.JsonPropertyName("fps")] [global::System.Obsolete("This property marked as deprecated.")] - public string? StartOffset { get; set; } + public double? Fps { get; set; } /// /// Optional. The end offset of the video. @@ -24,11 +24,11 @@ public sealed partial class VideoMetadata public string? EndOffset { get; set; } /// - /// Optional. The frame rate of the video sent to the model. If not specified, the default value will be 1.0. The fps range is (0.0, 24.0]. + /// Optional. The start offset of the video. /// - [global::System.Text.Json.Serialization.JsonPropertyName("fps")] + [global::System.Text.Json.Serialization.JsonPropertyName("startOffset")] [global::System.Obsolete("This property marked as deprecated.")] - public double? Fps { get; set; } + public string? StartOffset { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -39,26 +39,26 @@ public sealed partial class VideoMetadata /// /// Initializes a new instance of the class. /// - /// - /// Optional. The start offset of the video. + /// + /// Optional. The frame rate of the video sent to the model. If not specified, the default value will be 1.0. The fps range is (0.0, 24.0]. /// /// /// Optional. The end offset of the video. /// - /// - /// Optional. The frame rate of the video sent to the model. If not specified, the default value will be 1.0. The fps range is (0.0, 24.0]. + /// + /// Optional. The start offset of the video. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public VideoMetadata( - string? startOffset, + double? fps, string? endOffset, - double? fps) + string? startOffset) { - this.StartOffset = startOffset; - this.EndOffset = endOffset; this.Fps = fps; + this.EndOffset = endOffset; + this.StartOffset = startOffset; } /// diff --git a/src/libs/Google.Gemini/openapi.json b/src/libs/Google.Gemini/openapi.json index 900386f..9133164 100644 --- a/src/libs/Google.Gemini/openapi.json +++ b/src/libs/Google.Gemini/openapi.json @@ -11,63 +11,100 @@ } ], "paths": { - "/models/{modelsId}:streamGenerateContent": { - "post": { - "description": "Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`.", - "operationId": "models.streamGenerateContent", + "/batches": { + "get": { + "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.", + "operationId": "batches.list", "parameters": [ { - "name": "modelsId", - "in": "path", - "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "name": "filter", + "in": "query", + "description": "The standard list filter.", "schema": { - "type": "string", - "pattern": "^models/[^/]+$" + "type": "string" + } + }, + { + "name": "pageSize", + "in": "query", + "description": "The standard list page size.", + "schema": { + "type": "integer", + "format": "int32" + } + }, + { + "name": "pageToken", + "in": "query", + "description": "The standard list page token.", + "schema": { + "type": "string" + } + }, + { + "name": "returnPartialSuccess", + "in": "query", + "description": "When set to `true`, operations that are reachable are returned as normal, and those that are unreachable are returned in the ListOperationsResponse.unreachable field. This can only be `true` when reading across collections. For example, when `parent` is set to `\"projects/example/locations/-\"`. This field is not supported by default and will result in an `UNIMPLEMENTED` error if set unless explicitly documented otherwise in service or product specific documentation.", + "schema": { + "type": "boolean" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/ListOperationsResponse" + } } } } - }, + } + } + }, + "/batches/{batchesId}": { + "delete": { + "description": "Deletes a long-running operation. This method indicates that the client is no longer interested in the operation result. It does not cancel the operation. If the server doesn't support this method, it returns `google.rpc.Code.UNIMPLEMENTED`.", + "operationId": "batches.delete", + "parameters": [ + { + "name": "batchesId", + "in": "path", + "required": true, + "description": "The name of the operation resource to be deleted.", + "schema": { + "type": "string", + "pattern": "^batches/[^/]+$" + } + } + ], "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" - } - }, - "text/event-stream": { - "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/Empty" } } } } } - } - }, - "/models/{modelsId}": { + }, "get": { - "description": "Gets information about a specific `Model` such as its version number, token limits, [parameters](https://ai.google.dev/gemini-api/docs/models/generative-models#model-parameters) and other metadata. Refer to the [Gemini models guide](https://ai.google.dev/gemini-api/docs/models/gemini) for detailed model information.", - "operationId": "models.get", + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "batches.get", "parameters": [ { - "name": "modelsId", + "name": "batchesId", "in": "path", "required": true, - "description": "Required. The resource name of the model. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^batches/[^/]+$" } } ], @@ -77,7 +114,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Model" + "$ref": "#/components/schemas/Operation" } } } @@ -85,38 +122,29 @@ } } }, - "/models/{modelsId}:generateContent": { + "/batches/{batchesId}:cancel": { "post": { - "description": "Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details.", - "operationId": "models.generateContent", + "description": "Starts asynchronous cancellation on a long-running operation. The server makes a best effort to cancel the operation, but success is not guaranteed. If the server doesn't support this method, it returns `google.rpc.Code.UNIMPLEMENTED`. Clients can use Operations.GetOperation or other methods to check whether the cancellation succeeded or whether the operation completed despite cancellation. On successful cancellation, the operation is not deleted; instead, it becomes an operation with an Operation.error value with a google.rpc.Status.code of `1`, corresponding to `Code.CANCELLED`.", + "operationId": "batches.cancel", "parameters": [ { - "name": "modelsId", + "name": "batchesId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "The name of the operation resource to be cancelled.", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^batches/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/Empty" } } } @@ -124,19 +152,28 @@ } } }, - "/models/{modelsId}:asyncBatchEmbedContent": { - "post": { - "description": "Enqueues a batch of `EmbedContent` requests for batch processing. We have a `BatchEmbedContents` handler in `GenerativeService`, but it was synchronized. So we name this one to be `Async` to avoid confusion.", - "operationId": "models.asyncBatchEmbedContent", + "/batches/{batchesId}:updateGenerateContentBatch": { + "patch": { + "description": "Updates a batch of GenerateContent requests for batch processing.", + "operationId": "batches.updateGenerateContentBatch", "parameters": [ { - "name": "modelsId", + "name": "batchesId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^batches/[^/]+$" + } + }, + { + "name": "updateMask", + "in": "query", + "description": "Optional. The list of fields to update.", + "schema": { + "type": "string", + "format": "google-fieldmask" } } ], @@ -144,7 +181,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" + "$ref": "#/components/schemas/GenerateContentBatch" } } } @@ -155,7 +192,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/GenerateContentBatch" } } } @@ -163,19 +200,28 @@ } } }, - "/models/{modelsId}:batchGenerateContent": { - "post": { - "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", - "operationId": "models.batchGenerateContent", + "/batches/{batchesId}:updateEmbedContentBatch": { + "patch": { + "description": "Updates a batch of EmbedContent requests for batch processing.", + "operationId": "batches.updateEmbedContentBatch", "parameters": [ { - "name": "modelsId", + "name": "batchesId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^batches/[^/]+$" + } + }, + { + "name": "updateMask", + "in": "query", + "description": "Optional. The list of fields to update.", + "schema": { + "type": "string", + "format": "google-fieldmask" } } ], @@ -183,7 +229,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/BatchGenerateContentRequest" + "$ref": "#/components/schemas/EmbedContentBatch" } } } @@ -194,7 +240,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/EmbedContentBatch" } } } @@ -202,15 +248,15 @@ } } }, - "/models": { + "/corpora": { "get": { - "description": "Lists the [`Model`s](https://ai.google.dev/gemini-api/docs/models/gemini) available through the Gemini API.", - "operationId": "models.list", + "description": "Lists all `Corpora` owned by the user.", + "operationId": "corpora.list", "parameters": [ { "name": "pageSize", "in": "query", - "description": "The maximum number of `Models` to return (per page). If unspecified, 50 models will be returned per page. This method returns at most 1000 models per page, even if you pass a larger page_size.", + "description": "Optional. The maximum number of `Corpora` to return (per page). The service may return fewer `Corpora`. If unspecified, at most 10 `Corpora` will be returned. The maximum size limit is 20 `Corpora` per page.", "schema": { "type": "integer", "format": "int32" @@ -219,7 +265,7 @@ { "name": "pageToken", "in": "query", - "description": "A page token, received from a previous `ListModels` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListModels` must match the call that provided the page token.", + "description": "Optional. A page token, received from a previous `ListCorpora` call. Provide the `next_page_token` returned in the response as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListCorpora` must match the call that provided the page token.", "schema": { "type": "string" } @@ -231,35 +277,21 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListModelsResponse" + "$ref": "#/components/schemas/ListCorporaResponse" } } } } } - } - }, - "/models/{modelsId}:countTokens": { + }, "post": { - "description": "Runs a model's tokenizer on input `Content` and returns the token count. Refer to the [tokens guide](https://ai.google.dev/gemini-api/docs/tokens) to learn more about tokens.", - "operationId": "models.countTokens", - "parameters": [ - { - "name": "modelsId", - "in": "path", - "required": true, - "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", - "schema": { - "type": "string", - "pattern": "^models/[^/]+$" - } - } - ], + "description": "Creates an empty `Corpus`.", + "operationId": "corpora.create", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CountTokensRequest" + "$ref": "#/components/schemas/Corpus" } } } @@ -270,7 +302,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CountTokensResponse" + "$ref": "#/components/schemas/Corpus" } } } @@ -278,77 +310,65 @@ } } }, - "/models/{modelsId}:batchEmbedContents": { - "post": { - "description": "Generates multiple embedding vectors from the input `Content` which consists of a batch of strings represented as `EmbedContentRequest` objects.", - "operationId": "models.batchEmbedContents", + "/corpora/{corporaId}": { + "get": { + "description": "Gets information about a specific `Corpus`.", + "operationId": "corpora.get", "parameters": [ { - "name": "modelsId", + "name": "corporaId", "in": "path", "required": true, - "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", + "description": "Required. The name of the `Corpus`. Example: `corpora/my-corpus-123`", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^corpora/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/BatchEmbedContentsRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/BatchEmbedContentsResponse" + "$ref": "#/components/schemas/Corpus" } } } } } - } - }, - "/models/{modelsId}:embedContent": { - "post": { - "description": "Generates a text embedding vector from the input `Content` using the specified [Gemini Embedding model](https://ai.google.dev/gemini-api/docs/models/gemini#text-embedding).", - "operationId": "models.embedContent", + }, + "delete": { + "description": "Deletes a `Corpus`.", + "operationId": "corpora.delete", "parameters": [ { - "name": "modelsId", - "in": "path", - "required": true, - "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", + "name": "force", + "in": "query", + "description": "Optional. If set to true, any `Document`s and objects related to this `Corpus` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `Corpus` contains any `Document`s.", "schema": { - "type": "string", - "pattern": "^models/[^/]+$" + "type": "boolean" } - } - ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/EmbedContentRequest" - } + }, + { + "name": "corporaId", + "in": "path", + "required": true, + "description": "Required. The resource name of the `Corpus`. Example: `corpora/my-corpus-123`", + "schema": { + "type": "string", + "pattern": "^corpora/[^/]+$" } } - }, + ], "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/EmbedContentResponse" + "$ref": "#/components/schemas/Empty" } } } @@ -356,33 +376,90 @@ } } }, - "/models/{modelsId}/operations": { + "/corpora/{corporaId}/operations/{operationsId}": { "get": { - "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.", - "operationId": "models.operations.list", + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "corpora.operations.get", "parameters": [ { - "name": "filter", - "in": "query", - "description": "The standard list filter.", + "name": "operationsId", + "in": "path", + "required": true, "schema": { "type": "string" } }, { - "name": "modelsId", + "name": "corporaId", "in": "path", "required": true, - "description": "The name of the operation's parent resource.", + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^corpora/[^/]+/operations/[^/]+$" } - }, + } + ], + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Operation" + } + } + } + } + } + } + }, + "/corpora/{corporaId}/permissions": { + "post": { + "description": "Create a permission to a specific resource.", + "operationId": "corpora.permissions.create", + "parameters": [ + { + "name": "corporaId", + "in": "path", + "required": true, + "description": "Required. The parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", + "schema": { + "type": "string", + "pattern": "^corpora/[^/]+$" + } + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Permission" + } + } + } + }, + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Permission" + } + } + } + } + } + }, + "get": { + "description": "Lists permissions for the specific resource.", + "operationId": "corpora.permissions.list", + "parameters": [ { "name": "pageSize", "in": "query", - "description": "The standard list page size.", + "description": "Optional. The maximum number of `Permission`s to return (per page). The service may return fewer permissions. If unspecified, at most 10 permissions will be returned. This method returns at most 1000 permissions per page, even if you pass larger page_size.", "schema": { "type": "integer", "format": "int32" @@ -391,17 +468,19 @@ { "name": "pageToken", "in": "query", - "description": "The standard list page token.", + "description": "Optional. A page token, received from a previous `ListPermissions` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListPermissions` must match the call that provided the page token.", "schema": { "type": "string" } }, { - "name": "returnPartialSuccess", - "in": "query", - "description": "When set to `true`, operations that are reachable are returned as normal, and those that are unreachable are returned in the ListOperationsResponse.unreachable field. This can only be `true` when reading across collections. For example, when `parent` is set to `\"projects/example/locations/-\"`. This field is not supported by default and will result in an `UNIMPLEMENTED` error if set unless explicitly documented otherwise in service or product specific documentation.", + "name": "corporaId", + "in": "path", + "required": true, + "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", "schema": { - "type": "boolean" + "type": "string", + "pattern": "^corpora/[^/]+$" } } ], @@ -411,7 +490,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListOperationsResponse" + "$ref": "#/components/schemas/ListPermissionsResponse" } } } @@ -419,13 +498,13 @@ } } }, - "/models/{modelsId}/operations/{operationsId}": { - "get": { - "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "models.operations.get", + "/corpora/{corporaId}/permissions/{permissionsId}": { + "patch": { + "description": "Updates the permission.", + "operationId": "corpora.permissions.patch", "parameters": [ { - "name": "operationsId", + "name": "permissionsId", "in": "path", "required": true, "schema": { @@ -433,43 +512,67 @@ } }, { - "name": "modelsId", + "name": "corporaId", "in": "path", "required": true, - "description": "The name of the operation resource.", + "description": "Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.", "schema": { "type": "string", - "pattern": "^models/[^/]+/operations/[^/]+$" + "pattern": "^corpora/[^/]+/permissions/[^/]+$" + } + }, + { + "name": "updateMask", + "in": "query", + "description": "Required. The list of fields to update. Accepted ones: - role (`Permission.role` field)", + "schema": { + "type": "string", + "format": "google-fieldmask" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Permission" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Permission" } } } } } - } - }, - "/tunedModels/{tunedModelsId}": { + }, "get": { - "description": "Gets information about a specific TunedModel.", - "operationId": "tunedModels.get", + "description": "Gets information about a specific Permission.", + "operationId": "corpora.permissions.get", "parameters": [ { - "name": "tunedModelsId", + "name": "permissionsId", "in": "path", "required": true, - "description": "Required. The resource name of the model. Format: `tunedModels/my-model-id`", + "schema": { + "type": "string" + } + }, + { + "name": "corporaId", + "in": "path", + "required": true, + "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^corpora/[^/]+/permissions/[^/]+$" } } ], @@ -479,71 +582,63 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/Permission" } } } } } }, - "patch": { - "description": "Updates a tuned model.", - "operationId": "tunedModels.patch", + "delete": { + "description": "Deletes the permission.", + "operationId": "corpora.permissions.delete", "parameters": [ { - "name": "tunedModelsId", + "name": "permissionsId", "in": "path", "required": true, - "description": "Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`", "schema": { - "type": "string", - "pattern": "^tunedModels/[^/]+$" + "type": "string" } }, { - "name": "updateMask", - "in": "query", - "description": "Optional. The list of fields to update.", + "name": "corporaId", + "in": "path", + "required": true, + "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", "schema": { "type": "string", - "format": "google-fieldmask" + "pattern": "^corpora/[^/]+/permissions/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/TunedModel" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/Empty" } } } } } - }, + } + }, + "/cachedContents/{cachedContentsId}": { "delete": { - "description": "Deletes a tuned model.", - "operationId": "tunedModels.delete", + "description": "Deletes CachedContent resource.", + "operationId": "cachedContents.delete", "parameters": [ { - "name": "tunedModelsId", + "name": "cachedContentsId", "in": "path", "required": true, - "description": "Required. The resource name of the model. Format: `tunedModels/my-model-id`", + "description": "Required. The resource name referring to the content cache entry Format: `cachedContents/{id}`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^cachedContents/[^/]+$" } } ], @@ -559,69 +654,91 @@ } } } - } - }, - "/tunedModels/{tunedModelsId}:streamGenerateContent": { - "post": { - "description": "Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`.", - "operationId": "tunedModels.streamGenerateContent", + }, + "get": { + "description": "Reads CachedContent resource.", + "operationId": "cachedContents.get", "parameters": [ { - "name": "tunedModelsId", + "name": "cachedContentsId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "Required. The resource name referring to the content cache entry. Format: `cachedContents/{id}`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^cachedContents/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" - } - }, - "text/event-stream": { - "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/CachedContent" } } } } } - } - }, - "/tunedModels": { - "get": { - "description": "Lists created tuned models.", - "operationId": "tunedModels.list", + }, + "patch": { + "description": "Updates CachedContent resource (only expiration is updatable).", + "operationId": "cachedContents.patch", "parameters": [ { - "name": "filter", - "in": "query", - "description": "Optional. A filter is a full text search over the tuned model's description and display name. By default, results will not include tuned models shared with everyone. Additional operators: - owner:me - writers:me - readers:me - readers:everyone Examples: \"owner:me\" returns all tuned models to which caller has owner role \"readers:me\" returns all tuned models to which caller has reader role \"readers:everyone\" returns all tuned models that are shared with everyone", + "name": "cachedContentsId", + "in": "path", + "required": true, + "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`", "schema": { - "type": "string" + "type": "string", + "pattern": "^cachedContents/[^/]+$" } }, + { + "name": "updateMask", + "in": "query", + "description": "The list of fields to update.", + "schema": { + "type": "string", + "format": "google-fieldmask" + } + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/CachedContent" + } + } + } + }, + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/CachedContent" + } + } + } + } + } + } + }, + "/cachedContents": { + "get": { + "description": "Lists CachedContents.", + "operationId": "cachedContents.list", + "parameters": [ { "name": "pageSize", "in": "query", - "description": "Optional. The maximum number of `TunedModels` to return (per page). The service may return fewer tuned models. If unspecified, at most 10 tuned models will be returned. This method returns at most 1000 models per page, even if you pass a larger page_size.", + "description": "Optional. The maximum number of cached contents to return. The service may return fewer than this value. If unspecified, some default (under maximum) number of items will be returned. The maximum value is 1000; values above 1000 will be coerced to 1000.", "schema": { "type": "integer", "format": "int32" @@ -630,7 +747,7 @@ { "name": "pageToken", "in": "query", - "description": "Optional. A page token, received from a previous `ListTunedModels` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListTunedModels` must match the call that provided the page token.", + "description": "Optional. A page token, received from a previous `ListCachedContents` call. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `ListCachedContents` must match the call that provided the page token.", "schema": { "type": "string" } @@ -642,7 +759,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListTunedModelsResponse" + "$ref": "#/components/schemas/ListCachedContentsResponse" } } } @@ -650,23 +767,13 @@ } }, "post": { - "description": "Creates a tuned model. Check intermediate tuning progress (if any) through the [google.longrunning.Operations] service. Access status and results through the Operations service. Example: GET /v1/tunedModels/az2mb0bpw6i/operations/000-111-222", - "operationId": "tunedModels.create", - "parameters": [ - { - "name": "tunedModelId", - "in": "query", - "description": "Optional. The unique id for the tuned model if specified. This value should be up to 40 characters, the first character must be a letter, the last could be a letter or a number. The id must match the regular expression: `[a-z]([a-z0-9-]{0,38}[a-z0-9])?`.", - "schema": { - "type": "string" - } - } - ], + "description": "Creates CachedContent resource.", + "operationId": "cachedContents.create", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/CachedContent" } } } @@ -677,7 +784,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/CachedContent" } } } @@ -685,27 +792,50 @@ } } }, - "/tunedModels/{tunedModelsId}:generateContent": { - "post": { - "description": "Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details.", - "operationId": "tunedModels.generateContent", + "/files": { + "get": { + "description": "Lists the metadata for `File`s owned by the requesting project.", + "operationId": "files.list", "parameters": [ { - "name": "tunedModelsId", - "in": "path", - "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "name": "pageSize", + "in": "query", + "description": "Optional. Maximum number of `File`s to return per page. If unspecified, defaults to 10. Maximum `page_size` is 100.", "schema": { - "type": "string", - "pattern": "^tunedModels/[^/]+$" + "type": "integer", + "format": "int32" + } + }, + { + "name": "pageToken", + "in": "query", + "description": "Optional. A page token from a previous `ListFiles` call.", + "schema": { + "type": "string" } } ], + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/ListFilesResponse" + } + } + } + } + } + }, + "post": { + "description": "Creates a `File`.", + "operationId": "media.upload", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "$ref": "#/components/schemas/CreateFileRequest" } } } @@ -716,7 +846,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/CreateFileResponse" } } } @@ -724,27 +854,15 @@ } } }, - "/tunedModels/{tunedModelsId}:asyncBatchEmbedContent": { + "/files:register": { "post": { - "description": "Enqueues a batch of `EmbedContent` requests for batch processing. We have a `BatchEmbedContents` handler in `GenerativeService`, but it was synchronized. So we name this one to be `Async` to avoid confusion.", - "operationId": "tunedModels.asyncBatchEmbedContent", - "parameters": [ - { - "name": "tunedModelsId", - "in": "path", - "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", - "schema": { - "type": "string", - "pattern": "^tunedModels/[^/]+$" - } - } - ], + "description": "Registers a Google Cloud Storage files with FileService. The user is expected to provide Google Cloud Storage URIs and will receive a File resource for each URI in return. Note that the files are not copied, just registered with File API. If one file fails to register, the whole request fails.", + "operationId": "files.register", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" + "$ref": "#/components/schemas/RegisterFilesRequest" } } } @@ -755,7 +873,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/RegisterFilesResponse" } } } @@ -763,77 +881,57 @@ } } }, - "/tunedModels/{tunedModelsId}:transferOwnership": { - "post": { - "description": "Transfers ownership of the tuned model. This is the only way to change ownership of the tuned model. The current owner will be downgraded to writer role.", - "operationId": "tunedModels.transferOwnership", + "/files/{filesId}": { + "delete": { + "description": "Deletes the `File`.", + "operationId": "files.delete", "parameters": [ { - "name": "tunedModelsId", + "name": "filesId", "in": "path", "required": true, - "description": "Required. The resource name of the tuned model to transfer ownership. Format: `tunedModels/my-model-id`", + "description": "Required. The name of the `File` to delete. Example: `files/abc-123`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^files/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/TransferOwnershipRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TransferOwnershipResponse" + "$ref": "#/components/schemas/Empty" } } } } } - } - }, - "/tunedModels/{tunedModelsId}:batchGenerateContent": { - "post": { - "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", - "operationId": "tunedModels.batchGenerateContent", + }, + "get": { + "description": "Gets the metadata for the given `File`.", + "operationId": "files.get", "parameters": [ { - "name": "tunedModelsId", + "name": "filesId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "Required. The name of the `File` to get. Example: `files/abc-123`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^files/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/BatchGenerateContentRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/File" } } } @@ -841,52 +939,19 @@ } } }, - "/tunedModels/{tunedModelsId}/operations": { + "/fileSearchStores/{fileSearchStoresId}": { "get": { - "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.", - "operationId": "tunedModels.operations.list", + "description": "Gets information about a specific `FileSearchStore`.", + "operationId": "fileSearchStores.get", "parameters": [ { - "name": "filter", - "in": "query", - "description": "The standard list filter.", - "schema": { - "type": "string" - } - }, - { - "name": "tunedModelsId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "The name of the operation's parent resource.", + "description": "Required. The name of the `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" - } - }, - { - "name": "pageSize", - "in": "query", - "description": "The standard list page size.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "The standard list page token.", - "schema": { - "type": "string" - } - }, - { - "name": "returnPartialSuccess", - "in": "query", - "description": "When set to `true`, operations that are reachable are returned as normal, and those that are unreachable are returned in the ListOperationsResponse.unreachable field. This can only be `true` when reading across collections. For example, when `parent` is set to `\"projects/example/locations/-\"`. This field is not supported by default and will result in an `UNIMPLEMENTED` error if set unless explicitly documented otherwise in service or product specific documentation.", - "schema": { - "type": "boolean" + "pattern": "^fileSearchStores/[^/]+$" } } ], @@ -896,35 +961,33 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListOperationsResponse" + "$ref": "#/components/schemas/FileSearchStore" } } } } } - } - }, - "/tunedModels/{tunedModelsId}/operations/{operationsId}": { - "get": { - "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "tunedModels.operations.get", - "parameters": [ - { - "name": "tunedModelsId", - "in": "path", - "required": true, + }, + "delete": { + "description": "Deletes a `FileSearchStore`.", + "operationId": "fileSearchStores.delete", + "parameters": [ + { + "name": "force", + "in": "query", + "description": "Optional. If set to true, any `Document`s and objects related to this `FileSearchStore` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `FileSearchStore` contains any `Document`s.", "schema": { - "type": "string" + "type": "boolean" } }, { - "name": "operationsId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "The name of the operation resource.", + "description": "Required. The resource name of the `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+/operations/[^/]+$" + "pattern": "^fileSearchStores/[^/]+$" } } ], @@ -934,7 +997,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Empty" } } } @@ -942,15 +1005,40 @@ } } }, - "/tunedModels/{tunedModelsId}/permissions": { + "/fileSearchStores": { + "post": { + "description": "Creates an empty `FileSearchStore`.", + "operationId": "fileSearchStores.create", + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/FileSearchStore" + } + } + } + }, + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/FileSearchStore" + } + } + } + } + } + }, "get": { - "description": "Lists permissions for the specific resource.", - "operationId": "tunedModels.permissions.list", + "description": "Lists all `FileSearchStores` owned by the user.", + "operationId": "fileSearchStores.list", "parameters": [ { "name": "pageSize", "in": "query", - "description": "Optional. The maximum number of `Permission`s to return (per page). The service may return fewer permissions. If unspecified, at most 10 permissions will be returned. This method returns at most 1000 permissions per page, even if you pass larger page_size.", + "description": "Optional. The maximum number of `FileSearchStores` to return (per page). The service may return fewer `FileSearchStores`. If unspecified, at most 10 `FileSearchStores` will be returned. The maximum size limit is 20 `FileSearchStores` per page.", "schema": { "type": "integer", "format": "int32" @@ -959,20 +1047,10 @@ { "name": "pageToken", "in": "query", - "description": "Optional. A page token, received from a previous `ListPermissions` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListPermissions` must match the call that provided the page token.", + "description": "Optional. A page token, received from a previous `ListFileSearchStores` call. Provide the `next_page_token` returned in the response as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListFileSearchStores` must match the call that provided the page token.", "schema": { "type": "string" } - }, - { - "name": "tunedModelsId", - "in": "path", - "required": true, - "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", - "schema": { - "type": "string", - "pattern": "^tunedModels/[^/]+$" - } } ], "responses": { @@ -981,25 +1059,27 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListPermissionsResponse" + "$ref": "#/components/schemas/ListFileSearchStoresResponse" } } } } } - }, + } + }, + "/fileSearchStores/{fileSearchStoresId}:importFile": { "post": { - "description": "Create a permission to a specific resource.", - "operationId": "tunedModels.permissions.create", + "description": "Imports a `File` from File Service to a `FileSearchStore`.", + "operationId": "fileSearchStores.importFile", "parameters": [ { - "name": "tunedModelsId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Required. The parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", + "description": "Required. Immutable. The name of the `FileSearchStore` to import the file into. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^fileSearchStores/[^/]+$" } } ], @@ -1007,7 +1087,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/ImportFileRequest" } } } @@ -1018,7 +1098,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/Operation" } } } @@ -1026,13 +1106,13 @@ } } }, - "/tunedModels/{tunedModelsId}/permissions/{permissionsId}": { + "/fileSearchStores/{fileSearchStoresId}/upload/operations/{operationsId}": { "get": { - "description": "Gets information about a specific Permission.", - "operationId": "tunedModels.permissions.get", + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "fileSearchStores.upload.operations.get", "parameters": [ { - "name": "tunedModelsId", + "name": "operationsId", "in": "path", "required": true, "schema": { @@ -1040,13 +1120,13 @@ } }, { - "name": "permissionsId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" + "pattern": "^fileSearchStores/[^/]+/upload/operations/[^/]+$" } } ], @@ -1056,19 +1136,21 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/Operation" } } } } } - }, - "patch": { - "description": "Updates the permission.", - "operationId": "tunedModels.permissions.patch", + } + }, + "/fileSearchStores/{fileSearchStoresId}/operations/{operationsId}": { + "get": { + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "fileSearchStores.operations.get", "parameters": [ { - "name": "tunedModelsId", + "name": "operationsId", "in": "path", "required": true, "schema": { @@ -1076,41 +1158,61 @@ } }, { - "name": "permissionsId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.", + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" + "pattern": "^fileSearchStores/[^/]+/operations/[^/]+$" + } + } + ], + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Operation" + } + } + } + } + } + } + }, + "/fileSearchStores/{fileSearchStoresId}/documents/{documentsId}": { + "get": { + "description": "Gets information about a specific `Document`.", + "operationId": "fileSearchStores.documents.get", + "parameters": [ + { + "name": "fileSearchStoresId", + "in": "path", + "required": true, + "schema": { + "type": "string" } }, { - "name": "updateMask", - "in": "query", - "description": "Required. The list of fields to update. Accepted ones: - role (`Permission.role` field)", + "name": "documentsId", + "in": "path", + "required": true, + "description": "Required. The name of the `Document` to retrieve. Example: `fileSearchStores/my-file-search-store-123/documents/the-doc-abc`", "schema": { "type": "string", - "format": "google-fieldmask" + "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Permission" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/Document" } } } @@ -1118,11 +1220,11 @@ } }, "delete": { - "description": "Deletes the permission.", - "operationId": "tunedModels.permissions.delete", + "description": "Deletes a `Document`.", + "operationId": "fileSearchStores.documents.delete", "parameters": [ { - "name": "tunedModelsId", + "name": "fileSearchStoresId", "in": "path", "required": true, "schema": { @@ -1130,13 +1232,21 @@ } }, { - "name": "permissionsId", + "name": "force", + "in": "query", + "description": "Optional. If set to true, any `Chunk`s and objects related to this `Document` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `Document` contains any `Chunk`s.", + "schema": { + "type": "boolean" + } + }, + { + "name": "documentsId", "in": "path", "required": true, - "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", + "description": "Required. The resource name of the `Document` to delete. Example: `fileSearchStores/my-file-search-store-123/documents/the-doc-abc`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" + "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" } } ], @@ -1154,19 +1264,36 @@ } } }, - "/cachedContents/{cachedContentsId}": { + "/fileSearchStores/{fileSearchStoresId}/documents": { "get": { - "description": "Reads CachedContent resource.", - "operationId": "cachedContents.get", + "description": "Lists all `Document`s in a `Corpus`.", + "operationId": "fileSearchStores.documents.list", "parameters": [ { - "name": "cachedContentsId", + "name": "pageSize", + "in": "query", + "description": "Optional. The maximum number of `Document`s to return (per page). The service may return fewer `Document`s. If unspecified, at most 10 `Document`s will be returned. The maximum size limit is 20 `Document`s per page.", + "schema": { + "type": "integer", + "format": "int32" + } + }, + { + "name": "pageToken", + "in": "query", + "description": "Optional. A page token, received from a previous `ListDocuments` call. Provide the `next_page_token` returned in the response as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListDocuments` must match the call that provided the page token.", + "schema": { + "type": "string" + } + }, + { + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Required. The resource name referring to the content cache entry. Format: `cachedContents/{id}`", + "description": "Required. The name of the `FileSearchStore` containing `Document`s. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "pattern": "^cachedContents/[^/]+$" + "pattern": "^fileSearchStores/[^/]+$" } } ], @@ -1176,34 +1303,27 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/ListDocumentsResponse" } } } } } - }, - "patch": { - "description": "Updates CachedContent resource (only expiration is updatable).", - "operationId": "cachedContents.patch", + } + }, + "/models/{modelsId}:batchEmbedContents": { + "post": { + "description": "Generates multiple embedding vectors from the input `Content` which consists of a batch of strings represented as `EmbedContentRequest` objects.", + "operationId": "models.batchEmbedContents", "parameters": [ { - "name": "cachedContentsId", + "name": "modelsId", "in": "path", "required": true, - "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`", - "schema": { - "type": "string", - "pattern": "^cachedContents/[^/]+$" - } - }, - { - "name": "updateMask", - "in": "query", - "description": "The list of fields to update.", + "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", "schema": { "type": "string", - "format": "google-fieldmask" + "pattern": "^models/[^/]+$" } } ], @@ -1211,7 +1331,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/BatchEmbedContentsRequest" } } } @@ -1222,35 +1342,46 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/BatchEmbedContentsResponse" } } } } } - }, - "delete": { - "description": "Deletes CachedContent resource.", - "operationId": "cachedContents.delete", - "parameters": [ - { - "name": "cachedContentsId", - "in": "path", + } + }, + "/models/{modelsId}:batchGenerateContent": { + "post": { + "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", + "operationId": "models.batchGenerateContent", + "parameters": [ + { + "name": "modelsId", + "in": "path", "required": true, - "description": "Required. The resource name referring to the content cache entry Format: `cachedContents/{id}`", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^cachedContents/[^/]+$" + "pattern": "^models/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/BatchGenerateContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/Operation" } } } @@ -1258,50 +1389,27 @@ } } }, - "/cachedContents": { - "get": { - "description": "Lists CachedContents.", - "operationId": "cachedContents.list", + "/models/{modelsId}:generateContent": { + "post": { + "description": "Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details.", + "operationId": "models.generateContent", "parameters": [ { - "name": "pageSize", - "in": "query", - "description": "Optional. The maximum number of cached contents to return. The service may return fewer than this value. If unspecified, some default (under maximum) number of items will be returned. The maximum value is 1000; values above 1000 will be coerced to 1000.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "Optional. A page token, received from a previous `ListCachedContents` call. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `ListCachedContents` must match the call that provided the page token.", + "name": "modelsId", + "in": "path", + "required": true, + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { - "type": "string" + "type": "string", + "pattern": "^models/[^/]+$" } } ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/ListCachedContentsResponse" - } - } - } - } - } - }, - "post": { - "description": "Creates CachedContent resource.", - "operationId": "cachedContents.create", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/GenerateContentRequest" } } } @@ -1312,7 +1420,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/GenerateContentResponse" } } } @@ -1320,50 +1428,27 @@ } } }, - "/fileSearchStores": { - "get": { - "description": "Lists all `FileSearchStores` owned by the user.", - "operationId": "fileSearchStores.list", + "/models/{modelsId}:countTokens": { + "post": { + "description": "Runs a model's tokenizer on input `Content` and returns the token count. Refer to the [tokens guide](https://ai.google.dev/gemini-api/docs/tokens) to learn more about tokens.", + "operationId": "models.countTokens", "parameters": [ { - "name": "pageSize", - "in": "query", - "description": "Optional. The maximum number of `FileSearchStores` to return (per page). The service may return fewer `FileSearchStores`. If unspecified, at most 10 `FileSearchStores` will be returned. The maximum size limit is 20 `FileSearchStores` per page.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "Optional. A page token, received from a previous `ListFileSearchStores` call. Provide the `next_page_token` returned in the response as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListFileSearchStores` must match the call that provided the page token.", + "name": "modelsId", + "in": "path", + "required": true, + "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", "schema": { - "type": "string" + "type": "string", + "pattern": "^models/[^/]+$" } } ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/ListFileSearchStoresResponse" - } - } - } - } - } - }, - "post": { - "description": "Creates an empty `FileSearchStore`.", - "operationId": "fileSearchStores.create", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/FileSearchStore" + "$ref": "#/components/schemas/CountTokensRequest" } } } @@ -1374,7 +1459,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/FileSearchStore" + "$ref": "#/components/schemas/CountTokensResponse" } } } @@ -1382,19 +1467,19 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}": { + "/models/{modelsId}": { "get": { - "description": "Gets information about a specific `FileSearchStore`.", - "operationId": "fileSearchStores.get", + "description": "Gets information about a specific `Model` such as its version number, token limits, [parameters](https://ai.google.dev/gemini-api/docs/models/generative-models#model-parameters) and other metadata. Refer to the [Gemini models guide](https://ai.google.dev/gemini-api/docs/models/gemini) for detailed model information.", + "operationId": "models.get", "parameters": [ { - "name": "fileSearchStoresId", + "name": "modelsId", "in": "path", "required": true, - "description": "Required. The name of the `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", + "description": "Required. The resource name of the model. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+$" + "pattern": "^models/[^/]+$" } } ], @@ -1404,33 +1489,34 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/FileSearchStore" + "$ref": "#/components/schemas/Model" } } } } } - }, - "delete": { - "description": "Deletes a `FileSearchStore`.", - "operationId": "fileSearchStores.delete", + } + }, + "/models": { + "get": { + "description": "Lists the [`Model`s](https://ai.google.dev/gemini-api/docs/models/gemini) available through the Gemini API.", + "operationId": "models.list", "parameters": [ { - "name": "force", + "name": "pageSize", "in": "query", - "description": "Optional. If set to true, any `Document`s and objects related to this `FileSearchStore` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `FileSearchStore` contains any `Document`s.", + "description": "The maximum number of `Models` to return (per page). If unspecified, 50 models will be returned per page. This method returns at most 1000 models per page, even if you pass a larger page_size.", "schema": { - "type": "boolean" + "type": "integer", + "format": "int32" } }, { - "name": "fileSearchStoresId", - "in": "path", - "required": true, - "description": "Required. The resource name of the `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", + "name": "pageToken", + "in": "query", + "description": "A page token, received from a previous `ListModels` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListModels` must match the call that provided the page token.", "schema": { - "type": "string", - "pattern": "^fileSearchStores/[^/]+$" + "type": "string" } } ], @@ -1440,7 +1526,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/ListModelsResponse" } } } @@ -1448,19 +1534,19 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}:importFile": { + "/models/{modelsId}:streamGenerateContent": { "post": { - "description": "Imports a `File` from File Service to a `FileSearchStore`.", - "operationId": "fileSearchStores.importFile", + "description": "Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`.", + "operationId": "models.streamGenerateContent", "parameters": [ { - "name": "fileSearchStoresId", + "name": "modelsId", "in": "path", "required": true, - "description": "Required. Immutable. The name of the `FileSearchStore` to import the file into. Example: `fileSearchStores/my-file-search-store-123`", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+$" + "pattern": "^models/[^/]+$" } } ], @@ -1468,7 +1554,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ImportFileRequest" + "$ref": "#/components/schemas/GenerateContentRequest" } } } @@ -1479,7 +1565,12 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/GenerateContentResponse" + } + }, + "text/event-stream": { + "schema": { + "$ref": "#/components/schemas/GenerateContentResponse" } } } @@ -1487,37 +1578,38 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}/operations/{operationsId}": { - "get": { - "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "fileSearchStores.operations.get", + "/models/{modelsId}:embedContent": { + "post": { + "description": "Generates a text embedding vector from the input `Content` using the specified [Gemini Embedding model](https://ai.google.dev/gemini-api/docs/models/gemini#text-embedding).", + "operationId": "models.embedContent", "parameters": [ { - "name": "operationsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "fileSearchStoresId", + "name": "modelsId", "in": "path", "required": true, - "description": "The name of the operation resource.", + "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/operations/[^/]+$" + "pattern": "^models/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/EmbedContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/EmbedContentResponse" } } } @@ -1525,30 +1617,31 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}/upload/operations/{operationsId}": { - "get": { - "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "fileSearchStores.upload.operations.get", + "/models/{modelsId}:asyncBatchEmbedContent": { + "post": { + "description": "Enqueues a batch of `EmbedContent` requests for batch processing. We have a `BatchEmbedContents` handler in `GenerativeService`, but it was synchronized. So we name this one to be `Async` to avoid confusion.", + "operationId": "models.asyncBatchEmbedContent", "parameters": [ { - "name": "operationsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "fileSearchStoresId", + "name": "modelsId", "in": "path", "required": true, - "description": "The name of the operation resource.", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/upload/operations/[^/]+$" + "pattern": "^models/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", @@ -1563,27 +1656,52 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}/documents/{documentsId}": { + "/models/{modelsId}/operations": { "get": { - "description": "Gets information about a specific `Document`.", - "operationId": "fileSearchStores.documents.get", + "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.", + "operationId": "models.operations.list", "parameters": [ { - "name": "fileSearchStoresId", - "in": "path", - "required": true, + "name": "filter", + "in": "query", + "description": "The standard list filter.", "schema": { "type": "string" } }, { - "name": "documentsId", + "name": "modelsId", "in": "path", "required": true, - "description": "Required. The name of the `Document` to retrieve. Example: `fileSearchStores/my-file-search-store-123/documents/the-doc-abc`", + "description": "The name of the operation's parent resource.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" + "pattern": "^models/[^/]+$" + } + }, + { + "name": "pageSize", + "in": "query", + "description": "The standard list page size.", + "schema": { + "type": "integer", + "format": "int32" + } + }, + { + "name": "pageToken", + "in": "query", + "description": "The standard list page token.", + "schema": { + "type": "string" + } + }, + { + "name": "returnPartialSuccess", + "in": "query", + "description": "When set to `true`, operations that are reachable are returned as normal, and those that are unreachable are returned in the ListOperationsResponse.unreachable field. This can only be `true` when reading across collections. For example, when `parent` is set to `\"projects/example/locations/-\"`. This field is not supported by default and will result in an `UNIMPLEMENTED` error if set unless explicitly documented otherwise in service or product specific documentation.", + "schema": { + "type": "boolean" } } ], @@ -1593,19 +1711,21 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Document" + "$ref": "#/components/schemas/ListOperationsResponse" } } } } } - }, - "delete": { - "description": "Deletes a `Document`.", - "operationId": "fileSearchStores.documents.delete", + } + }, + "/models/{modelsId}/operations/{operationsId}": { + "get": { + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "models.operations.get", "parameters": [ { - "name": "fileSearchStoresId", + "name": "operationsId", "in": "path", "required": true, "schema": { @@ -1613,21 +1733,13 @@ } }, { - "name": "force", - "in": "query", - "description": "Optional. If set to true, any `Chunk`s and objects related to this `Document` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `Document` contains any `Chunk`s.", - "schema": { - "type": "boolean" - } - }, - { - "name": "documentsId", + "name": "modelsId", "in": "path", "required": true, - "description": "Required. The resource name of the `Document` to delete. Example: `fileSearchStores/my-file-search-store-123/documents/the-doc-abc`", + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" + "pattern": "^models/[^/]+/operations/[^/]+$" } } ], @@ -1637,7 +1749,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/Operation" } } } @@ -1645,46 +1757,38 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}/documents": { - "get": { - "description": "Lists all `Document`s in a `Corpus`.", - "operationId": "fileSearchStores.documents.list", + "/dynamic/{dynamicId}:generateContent": { + "post": { + "description": "Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details.", + "operationId": "dynamic.generateContent", "parameters": [ { - "name": "pageSize", - "in": "query", - "description": "Optional. The maximum number of `Document`s to return (per page). The service may return fewer `Document`s. If unspecified, at most 10 `Document`s will be returned. The maximum size limit is 20 `Document`s per page.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "Optional. A page token, received from a previous `ListDocuments` call. Provide the `next_page_token` returned in the response as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListDocuments` must match the call that provided the page token.", - "schema": { - "type": "string" - } - }, - { - "name": "fileSearchStoresId", + "name": "dynamicId", "in": "path", "required": true, - "description": "Required. The name of the `FileSearchStore` containing `Document`s. Example: `fileSearchStores/my-file-search-store-123`", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+$" + "pattern": "^dynamic/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/GenerateContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListDocumentsResponse" + "$ref": "#/components/schemas/GenerateContentResponse" } } } @@ -1692,57 +1796,87 @@ } } }, - "/batches/{batchesId}": { - "get": { - "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "batches.get", + "/dynamic/{dynamicId}:streamGenerateContent": { + "post": { + "description": "Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`.", + "operationId": "dynamic.streamGenerateContent", "parameters": [ { - "name": "batchesId", + "name": "dynamicId", "in": "path", "required": true, - "description": "The name of the operation resource.", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^batches/[^/]+$" + "pattern": "^dynamic/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/GenerateContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/GenerateContentResponse" + } + }, + "text/event-stream": { + "schema": { + "$ref": "#/components/schemas/GenerateContentResponse" } } } } } - }, - "delete": { - "description": "Deletes a long-running operation. This method indicates that the client is no longer interested in the operation result. It does not cancel the operation. If the server doesn't support this method, it returns `google.rpc.Code.UNIMPLEMENTED`.", - "operationId": "batches.delete", + } + }, + "/tunedModels/{tunedModelsId}:streamGenerateContent": { + "post": { + "description": "Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`.", + "operationId": "tunedModels.streamGenerateContent", "parameters": [ { - "name": "batchesId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "The name of the operation resource to be deleted.", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^batches/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/GenerateContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/GenerateContentResponse" + } + }, + "text/event-stream": { + "schema": { + "$ref": "#/components/schemas/GenerateContentResponse" } } } @@ -1750,15 +1884,15 @@ } } }, - "/batches": { + "/tunedModels": { "get": { - "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.", - "operationId": "batches.list", + "description": "Lists created tuned models.", + "operationId": "tunedModels.list", "parameters": [ { "name": "filter", "in": "query", - "description": "The standard list filter.", + "description": "Optional. A filter is a full text search over the tuned model's description and display name. By default, results will not include tuned models shared with everyone. Additional operators: - owner:me - writers:me - readers:me - readers:everyone Examples: \"owner:me\" returns all tuned models to which caller has owner role \"readers:me\" returns all tuned models to which caller has reader role \"readers:everyone\" returns all tuned models that are shared with everyone", "schema": { "type": "string" } @@ -1766,7 +1900,7 @@ { "name": "pageSize", "in": "query", - "description": "The standard list page size.", + "description": "Optional. The maximum number of `TunedModels` to return (per page). The service may return fewer tuned models. If unspecified, at most 10 tuned models will be returned. This method returns at most 1000 models per page, even if you pass a larger page_size.", "schema": { "type": "integer", "format": "int32" @@ -1775,18 +1909,10 @@ { "name": "pageToken", "in": "query", - "description": "The standard list page token.", + "description": "Optional. A page token, received from a previous `ListTunedModels` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListTunedModels` must match the call that provided the page token.", "schema": { "type": "string" } - }, - { - "name": "returnPartialSuccess", - "in": "query", - "description": "When set to `true`, operations that are reachable are returned as normal, and those that are unreachable are returned in the ListOperationsResponse.unreachable field. This can only be `true` when reading across collections. For example, when `parent` is set to `\"projects/example/locations/-\"`. This field is not supported by default and will result in an `UNIMPLEMENTED` error if set unless explicitly documented otherwise in service or product specific documentation.", - "schema": { - "type": "boolean" - } } ], "responses": { @@ -1795,36 +1921,23 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListOperationsResponse" + "$ref": "#/components/schemas/ListTunedModelsResponse" } } } } } - } - }, - "/batches/{batchesId}:updateGenerateContentBatch": { - "patch": { - "description": "Updates a batch of GenerateContent requests for batch processing.", - "operationId": "batches.updateGenerateContentBatch", + }, + "post": { + "description": "Creates a tuned model. Check intermediate tuning progress (if any) through the [google.longrunning.Operations] service. Access status and results through the Operations service. Example: GET /v1/tunedModels/az2mb0bpw6i/operations/000-111-222", + "operationId": "tunedModels.create", "parameters": [ { - "name": "batchesId", - "in": "path", - "required": true, - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", - "schema": { - "type": "string", - "pattern": "^batches/[^/]+$" - } - }, - { - "name": "updateMask", + "name": "tunedModelId", "in": "query", - "description": "Optional. The list of fields to update.", + "description": "Optional. The unique id for the tuned model if specified. This value should be up to 40 characters, the first character must be a letter, the last could be a letter or a number. The id must match the regular expression: `[a-z]([a-z0-9-]{0,38}[a-z0-9])?`.", "schema": { - "type": "string", - "format": "google-fieldmask" + "type": "string" } } ], @@ -1832,7 +1945,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentBatch" + "$ref": "#/components/schemas/TunedModel" } } } @@ -1843,7 +1956,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentBatch" + "$ref": "#/components/schemas/Operation" } } } @@ -1851,28 +1964,19 @@ } } }, - "/batches/{batchesId}:updateEmbedContentBatch": { - "patch": { - "description": "Updates a batch of EmbedContent requests for batch processing.", - "operationId": "batches.updateEmbedContentBatch", + "/tunedModels/{tunedModelsId}:batchGenerateContent": { + "post": { + "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", + "operationId": "tunedModels.batchGenerateContent", "parameters": [ { - "name": "batchesId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", - "schema": { - "type": "string", - "pattern": "^batches/[^/]+$" - } - }, - { - "name": "updateMask", - "in": "query", - "description": "Optional. The list of fields to update.", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "format": "google-fieldmask" + "pattern": "^tunedModels/[^/]+$" } } ], @@ -1880,7 +1984,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/EmbedContentBatch" + "$ref": "#/components/schemas/BatchGenerateContentRequest" } } } @@ -1891,7 +1995,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/EmbedContentBatch" + "$ref": "#/components/schemas/Operation" } } } @@ -1899,29 +2003,38 @@ } } }, - "/batches/{batchesId}:cancel": { + "/tunedModels/{tunedModelsId}:transferOwnership": { "post": { - "description": "Starts asynchronous cancellation on a long-running operation. The server makes a best effort to cancel the operation, but success is not guaranteed. If the server doesn't support this method, it returns `google.rpc.Code.UNIMPLEMENTED`. Clients can use Operations.GetOperation or other methods to check whether the cancellation succeeded or whether the operation completed despite cancellation. On successful cancellation, the operation is not deleted; instead, it becomes an operation with an Operation.error value with a google.rpc.Status.code of `1`, corresponding to `Code.CANCELLED`.", - "operationId": "batches.cancel", + "description": "Transfers ownership of the tuned model. This is the only way to change ownership of the tuned model. The current owner will be downgraded to writer role.", + "operationId": "tunedModels.transferOwnership", "parameters": [ { - "name": "batchesId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "The name of the operation resource to be cancelled.", + "description": "Required. The resource name of the tuned model to transfer ownership. Format: `tunedModels/my-model-id`", "schema": { "type": "string", - "pattern": "^batches/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/TransferOwnershipRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/TransferOwnershipResponse" } } } @@ -1929,19 +2042,19 @@ } } }, - "/dynamic/{dynamicId}:generateContent": { + "/tunedModels/{tunedModelsId}:asyncBatchEmbedContent": { "post": { - "description": "Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details.", - "operationId": "dynamic.generateContent", + "description": "Enqueues a batch of `EmbedContent` requests for batch processing. We have a `BatchEmbedContents` handler in `GenerativeService`, but it was synchronized. So we name this one to be `Async` to avoid confusion.", + "operationId": "tunedModels.asyncBatchEmbedContent", "parameters": [ { - "name": "dynamicId", + "name": "tunedModelsId", "in": "path", "required": true, "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^dynamic/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], @@ -1949,7 +2062,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" } } } @@ -1960,7 +2073,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/Operation" } } } @@ -1968,19 +2081,28 @@ } } }, - "/dynamic/{dynamicId}:streamGenerateContent": { - "post": { - "description": "Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`.", - "operationId": "dynamic.streamGenerateContent", + "/tunedModels/{tunedModelsId}": { + "patch": { + "description": "Updates a tuned model.", + "operationId": "tunedModels.patch", "parameters": [ { - "name": "dynamicId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`", "schema": { "type": "string", - "pattern": "^dynamic/[^/]+$" + "pattern": "^tunedModels/[^/]+$" + } + }, + { + "name": "updateMask", + "in": "query", + "description": "Optional. The list of fields to update.", + "schema": { + "type": "string", + "format": "google-fieldmask" } } ], @@ -1988,7 +2110,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "$ref": "#/components/schemas/TunedModel" } } } @@ -1999,66 +2121,53 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" - } - }, - "text/event-stream": { - "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/TunedModel" } } } } } - } - }, - "/files:register": { - "post": { - "description": "Registers a Google Cloud Storage files with FileService. The user is expected to provide Google Cloud Storage URIs and will receive a File resource for each URI in return. Note that the files are not copied, just registered with File API. If one file fails to register, the whole request fails.", - "operationId": "files.register", - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/RegisterFilesRequest" - } + }, + "delete": { + "description": "Deletes a tuned model.", + "operationId": "tunedModels.delete", + "parameters": [ + { + "name": "tunedModelsId", + "in": "path", + "required": true, + "description": "Required. The resource name of the model. Format: `tunedModels/my-model-id`", + "schema": { + "type": "string", + "pattern": "^tunedModels/[^/]+$" } } - }, + ], "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/RegisterFilesResponse" + "$ref": "#/components/schemas/Empty" } } } } } - } - }, - "/files": { + }, "get": { - "description": "Lists the metadata for `File`s owned by the requesting project.", - "operationId": "files.list", + "description": "Gets information about a specific TunedModel.", + "operationId": "tunedModels.get", "parameters": [ { - "name": "pageSize", - "in": "query", - "description": "Optional. Maximum number of `File`s to return per page. If unspecified, defaults to 10. Maximum `page_size` is 100.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "Optional. A page token from a previous `ListFiles` call.", + "name": "tunedModelsId", + "in": "path", + "required": true, + "description": "Required. The resource name of the model. Format: `tunedModels/my-model-id`", "schema": { - "type": "string" + "type": "string", + "pattern": "^tunedModels/[^/]+$" } } ], @@ -2068,21 +2177,35 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListFilesResponse" + "$ref": "#/components/schemas/TunedModel" } } } } } - }, + } + }, + "/tunedModels/{tunedModelsId}:generateContent": { "post": { - "description": "Creates a `File`.", - "operationId": "media.upload", + "description": "Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details.", + "operationId": "tunedModels.generateContent", + "parameters": [ + { + "name": "tunedModelsId", + "in": "path", + "required": true, + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "schema": { + "type": "string", + "pattern": "^tunedModels/[^/]+$" + } + } + ], "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CreateFileRequest" + "$ref": "#/components/schemas/GenerateContentRequest" } } } @@ -2093,7 +2216,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CreateFileResponse" + "$ref": "#/components/schemas/GenerateContentResponse" } } } @@ -2101,19 +2224,27 @@ } } }, - "/files/{filesId}": { - "get": { - "description": "Gets the metadata for the given `File`.", - "operationId": "files.get", + "/tunedModels/{tunedModelsId}/permissions/{permissionsId}": { + "delete": { + "description": "Deletes the permission.", + "operationId": "tunedModels.permissions.delete", "parameters": [ { - "name": "filesId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The name of the `File` to get. Example: `files/abc-123`", + "schema": { + "type": "string" + } + }, + { + "name": "permissionsId", + "in": "path", + "required": true, + "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", "schema": { "type": "string", - "pattern": "^files/[^/]+$" + "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" } } ], @@ -2123,25 +2254,33 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/File" + "$ref": "#/components/schemas/Empty" } } } } } }, - "delete": { - "description": "Deletes the `File`.", - "operationId": "files.delete", + "get": { + "description": "Gets information about a specific Permission.", + "operationId": "tunedModels.permissions.get", "parameters": [ { - "name": "filesId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The name of the `File` to delete. Example: `files/abc-123`", + "schema": { + "type": "string" + } + }, + { + "name": "permissionsId", + "in": "path", + "required": true, + "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", "schema": { "type": "string", - "pattern": "^files/[^/]+$" + "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" } } ], @@ -2151,27 +2290,42 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/Permission" } } } } } - } - }, - "/fileSearchStores/{fileSearchStoresId}:uploadToFileSearchStore": { - "post": { - "description": "Uploads data to a FileSearchStore, preprocesses and chunks before storing it in a FileSearchStore Document.", - "operationId": "media.uploadToFileSearchStore", + }, + "patch": { + "description": "Updates the permission.", + "operationId": "tunedModels.permissions.patch", "parameters": [ { - "name": "fileSearchStoresId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. Immutable. The name of the `FileSearchStore` to upload the file into. Example: `fileSearchStores/my-file-search-store-123`", + "schema": { + "type": "string" + } + }, + { + "name": "permissionsId", + "in": "path", + "required": true, + "description": "Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+$" + "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" + } + }, + { + "name": "updateMask", + "in": "query", + "description": "Required. The list of fields to update. Accepted ones: - role (`Permission.role` field)", + "schema": { + "type": "string", + "format": "google-fieldmask" } } ], @@ -2179,7 +2333,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/UploadToFileSearchStoreRequest" + "$ref": "#/components/schemas/Permission" } } } @@ -2190,7 +2344,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CustomLongRunningOperation" + "$ref": "#/components/schemas/Permission" } } } @@ -2198,15 +2352,15 @@ } } }, - "/generatedFiles": { + "/tunedModels/{tunedModelsId}/permissions": { "get": { - "description": "Lists the generated files owned by the requesting project.", - "operationId": "generatedFiles.list", + "description": "Lists permissions for the specific resource.", + "operationId": "tunedModels.permissions.list", "parameters": [ { "name": "pageSize", "in": "query", - "description": "Optional. Maximum number of `GeneratedFile`s to return per page. If unspecified, defaults to 10. Maximum `page_size` is 50.", + "description": "Optional. The maximum number of `Permission`s to return (per page). The service may return fewer permissions. If unspecified, at most 10 permissions will be returned. This method returns at most 1000 permissions per page, even if you pass larger page_size.", "schema": { "type": "integer", "format": "int32" @@ -2215,10 +2369,20 @@ { "name": "pageToken", "in": "query", - "description": "Optional. A page token from a previous `ListGeneratedFiles` call.", + "description": "Optional. A page token, received from a previous `ListPermissions` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListPermissions` must match the call that provided the page token.", "schema": { "type": "string" } + }, + { + "name": "tunedModelsId", + "in": "path", + "required": true, + "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", + "schema": { + "type": "string", + "pattern": "^tunedModels/[^/]+$" + } } ], "responses": { @@ -2227,152 +2391,78 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListGeneratedFilesResponse" + "$ref": "#/components/schemas/ListPermissionsResponse" } } } } } - } - }, - "/generatedFiles/{generatedFilesId}/operations/{operationsId}": { - "get": { - "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "generatedFiles.operations.get", - "parameters": [ - { - "name": "operationsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, + }, + "post": { + "description": "Create a permission to a specific resource.", + "operationId": "tunedModels.permissions.create", + "parameters": [ { - "name": "generatedFilesId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "The name of the operation resource.", + "description": "Required. The parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", "schema": { "type": "string", - "pattern": "^generatedFiles/[^/]+/operations/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Operation" - } + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Permission" } } } - } - } - }, - "/corpora/{corporaId}": { - "get": { - "description": "Gets information about a specific `Corpus`.", - "operationId": "corpora.get", - "parameters": [ - { - "name": "corporaId", - "in": "path", - "required": true, - "description": "Required. The name of the `Corpus`. Example: `corpora/my-corpus-123`", - "schema": { - "type": "string", - "pattern": "^corpora/[^/]+$" - } - } - ], + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Corpus" + "$ref": "#/components/schemas/Permission" } } } } } - }, - "delete": { - "description": "Deletes a `Corpus`.", - "operationId": "corpora.delete", + } + }, + "/tunedModels/{tunedModelsId}/operations": { + "get": { + "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.", + "operationId": "tunedModels.operations.list", "parameters": [ { - "name": "force", + "name": "filter", "in": "query", - "description": "Optional. If set to true, any `Document`s and objects related to this `Corpus` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `Corpus` contains any `Document`s.", + "description": "The standard list filter.", "schema": { - "type": "boolean" + "type": "string" } }, { - "name": "corporaId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The resource name of the `Corpus`. Example: `corpora/my-corpus-123`", + "description": "The name of the operation's parent resource.", "schema": { "type": "string", - "pattern": "^corpora/[^/]+$" - } - } - ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Empty" - } - } - } - } - } - } - }, - "/corpora": { - "post": { - "description": "Creates an empty `Corpus`.", - "operationId": "corpora.create", - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Corpus" - } - } - } - }, - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Corpus" - } - } + "pattern": "^tunedModels/[^/]+$" } - } - } - }, - "get": { - "description": "Lists all `Corpora` owned by the user.", - "operationId": "corpora.list", - "parameters": [ + }, { "name": "pageSize", "in": "query", - "description": "Optional. The maximum number of `Corpora` to return (per page). The service may return fewer `Corpora`. If unspecified, at most 10 `Corpora` will be returned. The maximum size limit is 20 `Corpora` per page.", + "description": "The standard list page size.", "schema": { "type": "integer", "format": "int32" @@ -2381,10 +2471,18 @@ { "name": "pageToken", "in": "query", - "description": "Optional. A page token, received from a previous `ListCorpora` call. Provide the `next_page_token` returned in the response as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListCorpora` must match the call that provided the page token.", + "description": "The standard list page token.", "schema": { "type": "string" } + }, + { + "name": "returnPartialSuccess", + "in": "query", + "description": "When set to `true`, operations that are reachable are returned as normal, and those that are unreachable are returned in the ListOperationsResponse.unreachable field. This can only be `true` when reading across collections. For example, when `parent` is set to `\"projects/example/locations/-\"`. This field is not supported by default and will result in an `UNIMPLEMENTED` error if set unless explicitly documented otherwise in service or product specific documentation.", + "schema": { + "type": "boolean" + } } ], "responses": { @@ -2393,7 +2491,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListCorporaResponse" + "$ref": "#/components/schemas/ListOperationsResponse" } } } @@ -2401,13 +2499,13 @@ } } }, - "/corpora/{corporaId}/operations/{operationsId}": { + "/tunedModels/{tunedModelsId}/operations/{operationsId}": { "get": { "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "corpora.operations.get", + "operationId": "tunedModels.operations.get", "parameters": [ { - "name": "operationsId", + "name": "tunedModelsId", "in": "path", "required": true, "schema": { @@ -2415,13 +2513,13 @@ } }, { - "name": "corporaId", + "name": "operationsId", "in": "path", "required": true, "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^corpora/[^/]+/operations/[^/]+$" + "pattern": "^tunedModels/[^/]+/operations/[^/]+$" } } ], @@ -2439,27 +2537,26 @@ } } }, - "/corpora/{corporaId}/permissions/{permissionsId}": { + "/generatedFiles": { "get": { - "description": "Gets information about a specific Permission.", - "operationId": "corpora.permissions.get", + "description": "Lists the generated files owned by the requesting project.", + "operationId": "generatedFiles.list", "parameters": [ { - "name": "permissionsId", - "in": "path", - "required": true, + "name": "pageSize", + "in": "query", + "description": "Optional. Maximum number of `GeneratedFile`s to return per page. If unspecified, defaults to 10. Maximum `page_size` is 50.", "schema": { - "type": "string" + "type": "integer", + "format": "int32" } }, { - "name": "corporaId", - "in": "path", - "required": true, - "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", + "name": "pageToken", + "in": "query", + "description": "Optional. A page token from a previous `ListGeneratedFiles` call.", "schema": { - "type": "string", - "pattern": "^corpora/[^/]+/permissions/[^/]+$" + "type": "string" } } ], @@ -2469,19 +2566,21 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/ListGeneratedFilesResponse" } } } } } - }, - "patch": { - "description": "Updates the permission.", - "operationId": "corpora.permissions.patch", + } + }, + "/generatedFiles/{generatedFilesId}/operations/{operationsId}": { + "get": { + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "generatedFiles.operations.get", "parameters": [ { - "name": "permissionsId", + "name": "operationsId", "in": "path", "required": true, "schema": { @@ -2489,161 +2588,62 @@ } }, { - "name": "corporaId", + "name": "generatedFilesId", "in": "path", "required": true, - "description": "Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.", - "schema": { - "type": "string", - "pattern": "^corpora/[^/]+/permissions/[^/]+$" - } - }, - { - "name": "updateMask", - "in": "query", - "description": "Required. The list of fields to update. Accepted ones: - role (`Permission.role` field)", + "description": "The name of the operation resource.", "schema": { "type": "string", - "format": "google-fieldmask" + "pattern": "^generatedFiles/[^/]+/operations/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Permission" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/Operation" } } } } } - }, - "delete": { - "description": "Deletes the permission.", - "operationId": "corpora.permissions.delete", + } + }, + "/fileSearchStores/{fileSearchStoresId}:uploadToFileSearchStore": { + "post": { + "description": "Uploads data to a FileSearchStore, preprocesses and chunks before storing it in a FileSearchStore Document.", + "operationId": "media.uploadToFileSearchStore", "parameters": [ { - "name": "permissionsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "corporaId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", + "description": "Required. Immutable. The name of the `FileSearchStore` to upload the file into. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "pattern": "^corpora/[^/]+/permissions/[^/]+$" + "pattern": "^fileSearchStores/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/UploadToFileSearchStoreRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" - } - } - } - } - } - } - }, - "/corpora/{corporaId}/permissions": { - "get": { - "description": "Lists permissions for the specific resource.", - "operationId": "corpora.permissions.list", - "parameters": [ - { - "name": "pageSize", - "in": "query", - "description": "Optional. The maximum number of `Permission`s to return (per page). The service may return fewer permissions. If unspecified, at most 10 permissions will be returned. This method returns at most 1000 permissions per page, even if you pass larger page_size.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "Optional. A page token, received from a previous `ListPermissions` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListPermissions` must match the call that provided the page token.", - "schema": { - "type": "string" - } - }, - { - "name": "corporaId", - "in": "path", - "required": true, - "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", - "schema": { - "type": "string", - "pattern": "^corpora/[^/]+$" - } - } - ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/ListPermissionsResponse" - } - } - } - } - } - }, - "post": { - "description": "Create a permission to a specific resource.", - "operationId": "corpora.permissions.create", - "parameters": [ - { - "name": "corporaId", - "in": "path", - "required": true, - "description": "Required. The parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", - "schema": { - "type": "string", - "pattern": "^corpora/[^/]+$" - } - } - ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Permission" - } - } - } - }, - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/CustomLongRunningOperation" } } } @@ -2654,243 +2654,367 @@ }, "components": { "schemas": { - "Part": { - "description": "A datatype containing media that is part of a multi-part `Content` message. A `Part` consists of data which has an associated datatype. A `Part` can only contain one of the accepted types in `Part.data`. A `Part` must have a fixed IANA MIME type identifying the type and subtype of the media if the `inline_data` field is filled with raw bytes.", + "CodeExecutionResult": { + "description": "Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used.", "properties": { - "inlineData": { - "description": "Inline media bytes.", - "$ref": "#/components/schemas/Blob" - }, - "toolCall": { - "description": "Server-side tool call. This field is populated when the model predicts a tool invocation that should be executed on the server. The client is expected to echo this message back to the API.", - "$ref": "#/components/schemas/ToolCall" - }, - "thoughtSignature": { - "description": "Optional. An opaque signature for the thought so it can be reused in subsequent requests.", - "format": "byte", + "id": { + "description": "Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id.", "type": "string" }, - "text": { - "description": "Inline text.", + "output": { + "description": "Optional. Contains stdout when code execution is successful, stderr or other description otherwise.", "type": "string" }, - "mediaResolution": { - "$ref": "#/components/schemas/MediaResolution", - "description": "Optional. Media resolution for the input media." - }, - "fileData": { - "$ref": "#/components/schemas/FileData", - "description": "URI based data." - }, - "videoMetadata": { - "description": "Optional. Video metadata. The metadata should only be specified while the video data is presented in inline_data or file_data.", - "$ref": "#/components/schemas/VideoMetadata" - }, - "toolResponse": { - "description": "The output from a server-side `ToolCall` execution. This field is populated by the client with the results of executing the corresponding `ToolCall`.", - "$ref": "#/components/schemas/ToolResponse" - }, - "functionResponse": { - "description": "The result output of a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model.", - "$ref": "#/components/schemas/FunctionResponse" - }, - "executableCode": { - "$ref": "#/components/schemas/ExecutableCode", - "description": "Code generated by the model that is meant to be executed." - }, - "partMetadata": { - "description": "Custom metadata associated with the Part. Agents using genai.Part as content representation may need to keep track of the additional information. For example it can be name of a file/source from which the Part originates or a way to multiplex multiple Part streams.", - "type": "object", - "additionalProperties": { - "description": "Properties of the object." - } - }, - "functionCall": { - "description": "A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values.", - "$ref": "#/components/schemas/FunctionCall" - }, - "codeExecutionResult": { - "$ref": "#/components/schemas/CodeExecutionResult", - "description": "Result of executing the `ExecutableCode`." - }, - "thought": { - "description": "Optional. Indicates if the part is thought from the model.", - "type": "boolean" + "outcome": { + "type": "string", + "x-enum-descriptions": [ + "Unspecified status. This value should not be used.", + "Code execution completed successfully. `output` contains the stdout, if any.", + "Code execution failed. `output` contains the stderr and stdout, if any.", + "Code execution ran for too long, and was cancelled. There may or may not be a partial `output` present." + ], + "enum": [ + "OUTCOME_UNSPECIFIED", + "OUTCOME_OK", + "OUTCOME_FAILED", + "OUTCOME_DEADLINE_EXCEEDED" + ], + "description": "Required. Outcome of the code execution." } }, "type": "object" }, - "Image": { + "EmbedContentBatch": { "type": "object", - "description": "Chunk from image search.", + "description": "A resource representing a batch of `EmbedContent` requests.", "properties": { - "title": { + "output": { + "description": "Output only. The output of the batch request.", + "readOnly": true, + "$ref": "#/components/schemas/EmbedContentBatchOutput" + }, + "endTime": { "type": "string", - "description": "The title of the web page that the image is from." + "format": "google-datetime", + "description": "Output only. The time at which the batch processing completed.", + "readOnly": true }, - "sourceUri": { + "createTime": { "type": "string", - "description": "The web page URI for attribution." + "format": "google-datetime", + "readOnly": true, + "description": "Output only. The time at which the batch was created." }, - "imageUri": { - "description": "The image asset URL.", + "state": { + "x-enum-descriptions": [ + "The batch state is unspecified.", + "The service is preparing to run the batch.", + "The batch is in progress.", + "The batch completed successfully.", + "The batch failed.", + "The batch has been cancelled.", + "The batch has expired." + ], + "enum": [ + "BATCH_STATE_UNSPECIFIED", + "BATCH_STATE_PENDING", + "BATCH_STATE_RUNNING", + "BATCH_STATE_SUCCEEDED", + "BATCH_STATE_FAILED", + "BATCH_STATE_CANCELLED", + "BATCH_STATE_EXPIRED" + ], + "description": "Output only. The state of the batch.", + "type": "string", + "readOnly": true + }, + "updateTime": { + "readOnly": true, + "description": "Output only. The time at which the batch was last updated.", + "type": "string", + "format": "google-datetime" + }, + "displayName": { + "description": "Required. The user-defined name of this batch.", "type": "string" }, - "domain": { - "description": "The root domain of the web page that the image is from, e.g. \"example.com\".", + "inputConfig": { + "$ref": "#/components/schemas/InputEmbedContentConfig", + "description": "Required. Input configuration of the instances on which batch processing are performed." + }, + "batchStats": { + "description": "Output only. Stats about the batch.", + "readOnly": true, + "$ref": "#/components/schemas/EmbedContentBatchStats" + }, + "model": { + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "type": "string" + }, + "name": { + "readOnly": true, + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", "type": "string" + }, + "priority": { + "type": "string", + "format": "int64", + "description": "Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0." } } }, - "ListFilesResponse": { - "description": "Response for `ListFiles`.", + "WhiteSpaceConfig": { "properties": { - "files": { - "type": "array", - "items": { - "$ref": "#/components/schemas/File" - }, - "description": "The list of `File`s." + "maxTokensPerChunk": { + "type": "integer", + "format": "int32", + "description": "Maximum number of tokens per chunk. Tokens are defined as words for this chunking algorithm. Note: we are defining tokens as words split by whitespace as opposed to the output of a tokenizer. The context window of the latest gemini embedding model as of 2025-04-17 is currently 8192 tokens. We assume that the average word is 5 characters. Therefore, we set the upper limit to 2**9, which is 512 words, or 2560 tokens, assuming worst case a character per token. This is a conservative estimate meant to prevent context window overflow." }, - "nextPageToken": { - "description": "A token that can be sent as a `page_token` into a subsequent `ListFiles` call.", - "type": "string" + "maxOverlapTokens": { + "type": "integer", + "format": "int32", + "description": "Maximum number of overlapping tokens between two adjacent chunks." } }, + "description": "Configuration for a white space chunking algorithm [white space delimited].", "type": "object" }, - "BatchGenerateContentRequest": { + "InlinedEmbedContentResponses": { "type": "object", - "description": "Request for a `BatchGenerateContent` operation.", "properties": { - "batch": { - "$ref": "#/components/schemas/GenerateContentBatch", - "description": "Required. The batch to create." + "inlinedResponses": { + "type": "array", + "items": { + "$ref": "#/components/schemas/InlinedEmbedContentResponse" + }, + "readOnly": true, + "description": "Output only. The responses to the requests in the batch." } - } + }, + "description": "The responses to the requests in the batch." }, - "FunctionCall": { - "description": "A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values.", + "Tool": { + "description": "Tool details that the model may use to generate response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the model. Next ID: 16", "properties": { - "id": { - "description": "Optional. Unique identifier of the function call. If populated, the client to execute the `function_call` and return the response with the matching `id`.", - "type": "string" + "functionDeclarations": { + "description": "Optional. A list of `FunctionDeclarations` available to the model that can be used for function calling. The model or system does not execute the function. Instead the defined function may be returned as a FunctionCall with arguments to the client side for execution. The model may decide to call a subset of these functions by populating FunctionCall in the response. The next conversation turn may contain a FunctionResponse with the Content.role \"function\" generation context for the next model turn.", + "type": "array", + "items": { + "$ref": "#/components/schemas/FunctionDeclaration" + } }, - "name": { - "type": "string", - "description": "Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128." + "codeExecution": { + "description": "Optional. Enables the model to execute code as part of generation.", + "$ref": "#/components/schemas/CodeExecution" }, - "args": { - "type": "object", - "additionalProperties": { - "description": "Properties of the object." + "computerUse": { + "$ref": "#/components/schemas/ComputerUse", + "description": "Optional. Tool to support the model interacting directly with the computer. If enabled, it automatically populates computer-use specific Function Declarations." + }, + "googleSearch": { + "$ref": "#/components/schemas/GoogleSearch", + "description": "Optional. GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google." + }, + "urlContext": { + "$ref": "#/components/schemas/UrlContext", + "description": "Optional. Tool to support URL context retrieval." + }, + "fileSearch": { + "description": "Optional. FileSearch tool type. Tool to retrieve knowledge from Semantic Retrieval corpora.", + "$ref": "#/components/schemas/FileSearch" + }, + "mcpServers": { + "type": "array", + "items": { + "$ref": "#/components/schemas/McpServer" }, - "description": "Optional. The function parameters and values in JSON object format." + "description": "Optional. MCP Servers to connect to." + }, + "googleSearchRetrieval": { + "description": "Optional. Retrieval tool that is powered by Google search.", + "$ref": "#/components/schemas/GoogleSearchRetrieval" + }, + "googleMaps": { + "description": "Optional. Tool that allows grounding the model's response with geospatial context related to the user's query.", + "$ref": "#/components/schemas/GoogleMaps" } }, "type": "object" }, - "ListTunedModelsResponse": { - "type": "object", - "description": "Response from `ListTunedModels` containing a paginated list of Models.", + "ListDocumentsResponse": { + "description": "Response from `ListDocuments` containing a paginated list of `Document`s. The `Document`s are sorted by ascending `document.create_time`.", "properties": { - "tunedModels": { + "documents": { "type": "array", "items": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/Document" }, - "description": "The returned Models." + "description": "The returned `Document`s." }, "nextPageToken": { "type": "string", "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages." } - } + }, + "type": "object" }, - "ThinkingConfig": { - "type": "object", - "description": "Config for thinking features.", + "ListFilesResponse": { "properties": { - "thinkingBudget": { - "description": "The number of thoughts tokens that the model should generate.", - "format": "int32", - "type": "integer" + "nextPageToken": { + "type": "string", + "description": "A token that can be sent as a `page_token` into a subsequent `ListFiles` call." }, - "includeThoughts": { - "description": "Indicates whether to include thoughts in the response. If true, thoughts are returned only when available.", - "type": "boolean" + "files": { + "type": "array", + "items": { + "$ref": "#/components/schemas/File" + }, + "description": "The list of `File`s." + } + }, + "description": "Response for `ListFiles`.", + "type": "object" + }, + "Document": { + "properties": { + "customMetadata": { + "type": "array", + "items": { + "$ref": "#/components/schemas/CustomMetadata" + }, + "description": "Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`." }, - "thinkingLevel": { - "description": "Optional. Controls the maximum depth of the model's internal reasoning process before it produces a response. If not specified, the default is HIGH. Recommended for Gemini 3 or later models. Use with earlier models results in an error.", - "enum": [ - "THINKING_LEVEL_UNSPECIFIED", - "MINIMAL", - "LOW", - "MEDIUM", - "HIGH" - ], + "createTime": { + "type": "string", + "format": "google-datetime", + "description": "Output only. The Timestamp of when the `Document` was created.", + "readOnly": true + }, + "mimeType": { + "description": "Output only. The mime type of the Document.", + "readOnly": true, + "type": "string" + }, + "state": { + "readOnly": true, "type": "string", + "description": "Output only. Current state of the `Document`.", "x-enum-descriptions": [ - "Default value.", - "Little to no thinking.", - "Low thinking level.", - "Medium thinking level.", - "High thinking level." + "The default value. This value is used if the state is omitted.", + "Some `Chunks` of the `Document` are being processed (embedding and vector storage).", + "All `Chunks` of the `Document` is processed and available for querying.", + "Some `Chunks` of the `Document` failed processing." + ], + "enum": [ + "STATE_UNSPECIFIED", + "STATE_PENDING", + "STATE_ACTIVE", + "STATE_FAILED" ] + }, + "updateTime": { + "type": "string", + "format": "google-datetime", + "description": "Output only. The Timestamp of when the `Document` was last updated.", + "readOnly": true + }, + "displayName": { + "description": "Optional. The human-readable display name for the `Document`. The display name must be no more than 512 characters in length, including spaces. Example: \"Semantic Retriever Documentation\"", + "type": "string" + }, + "sizeBytes": { + "readOnly": true, + "description": "Output only. The size of raw bytes ingested into the Document.", + "type": "string", + "format": "int64" + }, + "name": { + "description": "Immutable. Identifier. The `Document` resource name. The ID (name excluding the \"fileSearchStores/*/documents/\" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/{file_search_store_id}/documents/my-awesome-doc-123a456b789c`", + "type": "string" } - } + }, + "description": "A `Document` is a collection of `Chunk`s.", + "type": "object" }, - "CreateFileResponse": { - "type": "object", - "description": "Response for `CreateFile`.", - "properties": { - "file": { - "$ref": "#/components/schemas/File", - "description": "Metadata for the created file." - } - } + "Empty": { + "description": "A generic empty message that you can re-use to avoid defining duplicated empty messages in your APIs. A typical example is to use it as the request or the response type of an API method. For instance: service Foo { rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); }", + "properties": {}, + "type": "object" }, - "CitationMetadata": { + "CountTokensResponse": { "type": "object", - "description": "A collection of source attributions for a piece of content.", + "description": "A response from `CountTokens`. It returns the model's `token_count` for the `prompt`.", "properties": { - "citationSources": { + "totalTokens": { + "type": "integer", + "format": "int32", + "description": "The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative." + }, + "cachedContentTokenCount": { + "type": "integer", + "format": "int32", + "description": "Number of tokens in the cached part of the prompt (the cached content)." + }, + "promptTokensDetails": { + "readOnly": true, + "description": "Output only. List of modalities that were processed in the request input.", "type": "array", "items": { - "$ref": "#/components/schemas/CitationSource" - }, - "description": "Citations to sources for a specific response." + "$ref": "#/components/schemas/ModalityTokenCount" + } + }, + "cacheTokensDetails": { + "readOnly": true, + "description": "Output only. List of modalities that were processed in the cached content.", + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + } } } }, - "AsyncBatchEmbedContentRequest": { + "LogprobsResult": { "type": "object", - "description": "Request for an `AsyncBatchEmbedContent` operation.", "properties": { - "batch": { - "description": "Required. The batch to create.", - "$ref": "#/components/schemas/EmbedContentBatch" + "logProbabilitySum": { + "description": "Sum of log probabilities for all tokens.", + "type": "number", + "format": "float" + }, + "chosenCandidates": { + "description": "Length = total number of decoding steps. The chosen candidates may or may not be in top_candidates.", + "type": "array", + "items": { + "$ref": "#/components/schemas/LogprobsResultCandidate" + } + }, + "topCandidates": { + "type": "array", + "items": { + "$ref": "#/components/schemas/TopCandidates" + }, + "description": "Length = total number of decoding steps." } - } + }, + "description": "Logprobs Result" }, "EmbedContentBatchOutput": { "type": "object", - "description": "The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field.", "properties": { + "responsesFile": { + "type": "string", + "readOnly": true, + "description": "Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `EmbedContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests." + }, "inlinedResponses": { "readOnly": true, "$ref": "#/components/schemas/InlinedEmbedContentResponses", "description": "Output only. The responses to the requests in the batch. Returned when the batch was built using inlined requests. The responses will be in the same order as the input requests." - }, - "responsesFile": { - "readOnly": true, - "type": "string", - "description": "Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `EmbedContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests." } - } + }, + "description": "The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field." }, "GoogleSearch": { - "description": "GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google.", "properties": { "timeRangeFilter": { "description": "Optional. Filter search results to a specific time range. If customers set a start time, they must set an end time (and vice versa).", @@ -2901,617 +3025,564 @@ "$ref": "#/components/schemas/SearchTypes" } }, + "description": "GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google.", "type": "object" }, - "Maps": { - "description": "A grounding chunk from Google Maps. A Maps chunk corresponds to a single place.", + "UrlContext": { + "properties": {}, + "description": "Tool to support URL context retrieval.", + "type": "object" + }, + "StreamableHttpTransport": { "properties": { - "placeId": { - "type": "string", - "description": "The ID of the place, in `places/{place_id}` format. A user can use this ID to look up that place." - }, - "title": { - "description": "Title of the place.", + "url": { + "description": "The full URL for the MCPServer endpoint. Example: \"https://api.example.com/mcp\"", "type": "string" }, - "text": { - "description": "Text description of the place answer.", - "type": "string" + "terminateOnClose": { + "description": "Whether to close the client session when the transport closes.", + "type": "boolean" }, - "uri": { + "sseReadTimeout": { "type": "string", - "description": "URI reference of the place." + "format": "google-duration", + "description": "Timeout for SSE read operations." }, - "placeAnswerSources": { - "description": "Sources that provide answers about the features of a given place in Google Maps.", - "$ref": "#/components/schemas/PlaceAnswerSources" + "headers": { + "type": "object", + "additionalProperties": { + "type": "string" + }, + "description": "Optional: Fields for authentication headers, timeouts, etc., if needed." + }, + "timeout": { + "description": "HTTP timeout for regular operations.", + "type": "string", + "format": "google-duration" } }, + "description": "A transport that can stream HTTP requests and responses. Next ID: 6", "type": "object" }, - "UrlMetadata": { - "description": "Context of the a single url retrieval.", + "FunctionDeclaration": { + "type": "object", "properties": { - "retrievedUrl": { - "type": "string", - "description": "Retrieved url by the tool." + "responseJsonSchema": { + "description": "Optional. Describes the output from this function in JSON Schema format. The value specified by the schema is the response value of the function. This field is mutually exclusive with `response`." }, - "urlRetrievalStatus": { - "description": "Status of the url retrieval.", - "enum": [ - "URL_RETRIEVAL_STATUS_UNSPECIFIED", - "URL_RETRIEVAL_STATUS_SUCCESS", - "URL_RETRIEVAL_STATUS_ERROR", - "URL_RETRIEVAL_STATUS_PAYWALL", - "URL_RETRIEVAL_STATUS_UNSAFE" - ], + "name": { "type": "string", - "x-enum-descriptions": [ - "Default value. This value is unused.", - "Url retrieval is successful.", - "Url retrieval is failed due to error.", - "Url retrieval is failed because the content is behind paywall.", - "Url retrieval is failed because the content is unsafe." + "description": "Required. The name of the function. Must be a-z, A-Z, 0-9, or contain underscores, colons, dots, and dashes, with a maximum length of 128." + }, + "parametersJsonSchema": { + "description": "Optional. Describes the parameters to the function in JSON Schema format. The schema must describe an object where the properties are the parameters to the function. For example: ``` { \"type\": \"object\", \"properties\": { \"name\": { \"type\": \"string\" }, \"age\": { \"type\": \"integer\" } }, \"additionalProperties\": false, \"required\": [\"name\", \"age\"], \"propertyOrdering\": [\"name\", \"age\"] } ``` This field is mutually exclusive with `parameters`." + }, + "response": { + "$ref": "#/components/schemas/Schema", + "description": "Optional. Describes the output from this function in JSON Schema format. Reflects the Open API 3.03 Response Object. The Schema defines the type used for the response value of the function." + }, + "description": { + "type": "string", + "description": "Required. A brief description of the function." + }, + "behavior": { + "description": "Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method.", + "type": "string", + "x-enum-descriptions": [ + "This value is unused.", + "If set, the system will wait to receive the function response before continuing the conversation.", + "If set, the system will not wait to receive the function response. Instead, it will attempt to handle function responses as they become available while maintaining the conversation between the user and the model." + ], + "enum": [ + "UNSPECIFIED", + "BLOCKING", + "NON_BLOCKING" ] + }, + "parameters": { + "$ref": "#/components/schemas/Schema", + "description": "Optional. Describes the parameters to this function. Reflects the Open API 3.03 Parameter Object string Key: the name of the parameter. Parameter names are case sensitive. Schema Value: the Schema defining the type used for the parameter." + } + }, + "description": "Structured representation of a function declaration as defined by the [OpenAPI 3.03 specification](https://spec.openapis.org/oas/v3.0.3). Included in this declaration are the function name and parameters. This FunctionDeclaration is a representation of a block of code that can be used as a `Tool` by the model and executed by the client." + }, + "RetrievedContext": { + "description": "Chunk from context retrieved by the file search tool.", + "properties": { + "customMetadata": { + "type": "array", + "items": { + "$ref": "#/components/schemas/GroundingChunkCustomMetadata" + }, + "description": "Optional. User-provided metadata about the retrieved context." + }, + "title": { + "description": "Optional. Title of the document.", + "type": "string" + }, + "text": { + "description": "Optional. Text of the chunk.", + "type": "string" + }, + "fileSearchStore": { + "description": "Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123`", + "type": "string" + }, + "uri": { + "type": "string", + "description": "Optional. URI reference of the semantic retrieval document." } }, "type": "object" }, - "InlinedResponses": { + "GroundingChunk": { + "description": "A `GroundingChunk` represents a segment of supporting evidence that grounds the model's response. It can be a chunk from the web, a retrieved context from a file, or information from Google Maps.", + "properties": { + "web": { + "$ref": "#/components/schemas/Web", + "description": "Grounding chunk from the web." + }, + "retrievedContext": { + "$ref": "#/components/schemas/RetrievedContext", + "description": "Optional. Grounding chunk from context retrieved by the file search tool." + }, + "maps": { + "description": "Optional. Grounding chunk from Google Maps.", + "$ref": "#/components/schemas/Maps" + }, + "image": { + "description": "Optional. Grounding chunk from image search.", + "$ref": "#/components/schemas/Image" + } + }, + "type": "object" + }, + "UrlContextMetadata": { "type": "object", - "description": "The responses to the requests in the batch.", "properties": { - "inlinedResponses": { - "description": "Output only. The responses to the requests in the batch.", - "readOnly": true, + "urlMetadata": { + "description": "List of url context.", "type": "array", "items": { - "$ref": "#/components/schemas/InlinedResponse" + "$ref": "#/components/schemas/UrlMetadata" } } - } + }, + "description": "Metadata related to url context retrieval tool." }, - "Model": { - "description": "Information about a Generative Language Model.", + "Operation": { "properties": { - "outputTokenLimit": { - "description": "Maximum number of output tokens available for this model.", - "format": "int32", - "type": "integer" - }, - "version": { - "type": "string", - "description": "Required. The version number of the model. This represents the major version (`1.0` or `1.5`)" - }, - "topK": { - "description": "For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. If empty, indicates the model doesn't use top-k sampling, and `top_k` isn't allowed as a generation parameter.", - "type": "integer", - "format": "int32" + "done": { + "description": "If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available.", + "type": "boolean" }, - "inputTokenLimit": { - "format": "int32", - "type": "integer", - "description": "Maximum number of input tokens allowed for this model." + "error": { + "$ref": "#/components/schemas/Status", + "description": "The error result of the operation in case of failure or cancellation." }, - "thinking": { - "type": "boolean", - "description": "Whether the model supports thinking." + "response": { + "description": "The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.", + "type": "object", + "additionalProperties": { + "description": "Properties of the object. Contains field @type with type URL." + } }, "name": { "type": "string", - "description": "Required. The resource name of the `Model`. Refer to [Model variants](https://ai.google.dev/gemini-api/docs/models/gemini#model-variations) for all allowed values. Format: `models/{model}` with a `{model}` naming convention of: * \"{base_model_id}-{version}\" Examples: * `models/gemini-1.5-flash-001`" - }, - "displayName": { - "description": "The human-readable name of the model. E.g. \"Gemini 1.5 Flash\". The name can be up to 128 characters long and can consist of any UTF-8 characters.", - "type": "string" - }, - "baseModelId": { - "type": "string", - "description": "Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash`" - }, - "topP": { - "description": "For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model.", - "format": "float", - "type": "number" - }, - "description": { - "description": "A short description of the model.", - "type": "string" - }, - "temperature": { - "description": "Controls the randomness of the output. Values can range over `[0.0,max_temperature]`, inclusive. A higher value will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be used by the backend while making the call to the model.", - "format": "float", - "type": "number" + "description": "The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`." }, - "supportedGenerationMethods": { - "type": "array", - "items": { - "type": "string" + "metadata": { + "type": "object", + "additionalProperties": { + "description": "Properties of the object. Contains field @type with type URL." }, - "description": "The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`." - }, - "maxTemperature": { - "type": "number", - "format": "float", - "description": "The maximum temperature this model can use." + "description": "Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any." } }, + "description": "This resource represents a long-running operation that is the result of a network API call.", "type": "object" }, - "GenerationConfig": { - "type": "object", - "description": "Configuration options for model generation and outputs. Not all parameters are configurable for every model.", + "GeneratedFile": { + "description": "A file generated on behalf of a user.", "properties": { - "responseSchema": { - "description": "Optional. Output schema of the generated candidate text. Schemas must be a subset of the [OpenAPI schema](https://spec.openapis.org/oas/v3.0.3#schema) and can be objects, primitives or arrays. If set, a compatible `response_mime_type` must also be set. Compatible MIME types: `application/json`: Schema for JSON response. Refer to the [JSON text generation guide](https://ai.google.dev/gemini-api/docs/json-mode) for more details.", - "$ref": "#/components/schemas/Schema" - }, - "mediaResolution": { - "type": "string", + "state": { "x-enum-descriptions": [ - "Media resolution has not been set.", - "Media resolution set to low (64 tokens).", - "Media resolution set to medium (256 tokens).", - "Media resolution set to high (zoomed reframing with 256 tokens)." + "The default value. This value is used if the state is omitted.", + "Being generated.", + "Generated and is ready for download.", + "Failed to generate the GeneratedFile." ], "enum": [ - "MEDIA_RESOLUTION_UNSPECIFIED", - "MEDIA_RESOLUTION_LOW", - "MEDIA_RESOLUTION_MEDIUM", - "MEDIA_RESOLUTION_HIGH" + "STATE_UNSPECIFIED", + "GENERATING", + "GENERATED", + "FAILED" ], - "description": "Optional. If specified, the media resolution specified will be used." - }, - "frequencyPenalty": { - "description": "Optional. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit.", - "type": "number", - "format": "float" + "description": "Output only. The state of the GeneratedFile.", + "type": "string", + "readOnly": true }, - "responseLogprobs": { - "type": "boolean", - "description": "Optional. If true, export the logprobs results in response." + "name": { + "description": "Identifier. The name of the generated file. Example: `generatedFiles/abc-123`", + "type": "string" }, - "responseModalities": { - "type": "array", - "items": { - "enum": [ - "MODALITY_UNSPECIFIED", - "TEXT", - "IMAGE", - "AUDIO", - "VIDEO" - ], - "type": "string", - "x-enum-descriptions": [ - "Default value.", - "Indicates the model should return text.", - "Indicates the model should return images.", - "Indicates the model should return audio.", - "Indicates the model should return video." - ] - }, - "description": "Optional. The requested modalities of the response. Represents the set of modalities that the model can return, and should be expected in the response. This is an exact match to the modalities of the response. A model may have multiple combinations of supported modalities. If the requested modalities do not match any of the supported combinations, an error will be returned. An empty list is equivalent to requesting only text." + "mimeType": { + "type": "string", + "description": "MIME type of the generatedFile." }, - "responseMimeType": { - "description": "Optional. MIME type of the generated candidate text. Supported MIME types are: `text/plain`: (default) Text output. `application/json`: JSON response in the response candidates. `text/x.enum`: ENUM as a string response in the response candidates. Refer to the [docs](https://ai.google.dev/gemini-api/docs/prompting_with_media#plain_text_formats) for a list of all supported text MIME types.", + "error": { + "description": "Error details if the GeneratedFile ends up in the STATE_FAILED state.", + "$ref": "#/components/schemas/Status" + } + }, + "type": "object" + }, + "ImageConfig": { + "type": "object", + "properties": { + "imageSize": { + "description": "Optional. Specifies the size of generated images. Supported values are `512`, `1K`, `2K`, `4K`. If not specified, the model will use default value `1K`.", "type": "string" }, - "presencePenalty": { - "description": "Optional. Presence penalty applied to the next token's logprobs if the token has already been seen in the response. This penalty is binary on/off and not dependant on the number of times the token is used (after the first). Use frequency_penalty for a penalty that increases with each use. A positive penalty will discourage the use of tokens that have already been used in the response, increasing the vocabulary. A negative penalty will encourage the use of tokens that have already been used in the response, decreasing the vocabulary.", - "type": "number", - "format": "float" + "aspectRatio": { + "type": "string", + "description": "Optional. The aspect ratio of the image to generate. Supported aspect ratios: `1:1`, `1:4`, `4:1`, `1:8`, `8:1`, `2:3`, `3:2`, `3:4`, `4:3`, `4:5`, `5:4`, `9:16`, `16:9`, or `21:9`. If not specified, the model will choose a default aspect ratio based on any reference images provided." + } + }, + "description": "Config for image generation features." + }, + "FunctionResponse": { + "description": "The result output from a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model. This should contain the result of a`FunctionCall` made based on model prediction.", + "properties": { + "id": { + "type": "string", + "description": "Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`." }, - "stopSequences": { + "parts": { "type": "array", "items": { - "type": "string" + "$ref": "#/components/schemas/FunctionResponsePart" }, - "description": "Optional. The set of character sequences (up to 5) that will stop output generation. If specified, the API will stop at the first appearance of a `stop_sequence`. The stop sequence will not be included as part of the response." + "description": "Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types." }, - "seed": { - "type": "integer", - "format": "int32", - "description": "Optional. Seed used in decoding. If not set, the request uses a randomly generated seed." + "willContinue": { + "description": "Optional. Signals that function call continues, and more responses will be returned, turning the function call into a generator. Is only applicable to NON_BLOCKING function calls, is ignored otherwise. If set to false, future responses will not be considered. It is allowed to return empty `response` with `will_continue=False` to signal that the function call is finished. This may still trigger the model generation. To avoid triggering the generation and finish the function call, additionally set `scheduling` to `SILENT`.", + "type": "boolean" }, - "enableEnhancedCivicAnswers": { - "type": "boolean", - "description": "Optional. Enables enhanced civic answers. It may not be available for all models." + "name": { + "type": "string", + "description": "Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128." }, - "temperature": { - "description": "Optional. Controls the randomness of the output. Note: The default value varies by model, see the `Model.temperature` attribute of the `Model` returned from the `getModel` function. Values can range from [0.0, 2.0].", - "type": "number", - "format": "float" - }, - "speechConfig": { - "description": "Optional. The speech generation config.", - "$ref": "#/components/schemas/SpeechConfig" - }, - "topP": { - "type": "number", - "format": "float", - "description": "Optional. The maximum cumulative probability of tokens to consider when sampling. The model uses combined Top-k and Top-p (nucleus) sampling. Tokens are sorted based on their assigned probabilities so that only the most likely tokens are considered. Top-k sampling directly limits the maximum number of tokens to consider, while Nucleus sampling limits the number of tokens based on the cumulative probability. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests." - }, - "candidateCount": { - "description": "Optional. Number of generated responses to return. If unset, this will default to 1. Please note that this doesn't work for previous generation models (Gemini 1.0 family)", - "format": "int32", - "type": "integer" - }, - "responseJsonSchema": { - "description": "Optional. An internal detail. Use `responseJsonSchema` rather than this field." - }, - "imageConfig": { - "$ref": "#/components/schemas/ImageConfig", - "description": "Optional. Config for image generation. An error will be returned if this field is set for models that don't support these config options." - }, - "logprobs": { - "type": "integer", - "format": "int32", - "description": "Optional. Only valid if response_logprobs=True. This sets the number of top logprobs, including the chosen candidate, to return at each decoding step in the Candidate.logprobs_result. The number must be in the range of [0, 20]." - }, - "topK": { - "type": "integer", - "format": "int32", - "description": "Optional. The maximum number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests." - }, - "maxOutputTokens": { - "type": "integer", - "format": "int32", - "description": "Optional. The maximum number of tokens to include in a response candidate. Note: The default value varies by model, see the `Model.output_token_limit` attribute of the `Model` returned from the `getModel` function." + "scheduling": { + "description": "Optional. Specifies how the response should be scheduled in the conversation. Only applicable to NON_BLOCKING function calls, is ignored otherwise. Defaults to WHEN_IDLE.", + "type": "string", + "x-enum-descriptions": [ + "This value is unused.", + "Only add the result to the conversation context, do not interrupt or trigger generation.", + "Add the result to the conversation context, and prompt to generate output without interrupting ongoing generation.", + "Add the result to the conversation context, interrupt ongoing generation and prompt to generate output." + ], + "enum": [ + "SCHEDULING_UNSPECIFIED", + "SILENT", + "WHEN_IDLE", + "INTERRUPT" + ] }, - "thinkingConfig": { - "$ref": "#/components/schemas/ThinkingConfig", - "description": "Optional. Config for thinking features. An error will be returned if this field is set for models that don't support thinking." - } - } - }, - "CodeExecution": { - "description": "Tool that executes code generated by the model, and automatically returns the result to the model. See also `ExecutableCode` and `CodeExecutionResult` which are only generated when using this tool.", - "properties": {}, - "type": "object" - }, - "MultiSpeakerVoiceConfig": { - "description": "The configuration for the multi-speaker setup.", - "properties": { - "speakerVoiceConfigs": { - "description": "Required. All the enabled speaker voices.", - "type": "array", - "items": { - "$ref": "#/components/schemas/SpeakerVoiceConfig" + "response": { + "description": "Required. The function response in JSON object format. Callers can use any keys of their choice that fit the function's syntax to return the function output, e.g. \"output\", \"result\", etc. In particular, if the function call failed to execute, the response can have an \"error\" key to return error details to the model.", + "type": "object", + "additionalProperties": { + "description": "Properties of the object." } } }, "type": "object" }, - "SearchTypes": { - "type": "object", - "description": "Different types of search that can be enabled on the GoogleSearch tool.", - "properties": { - "webSearch": { - "$ref": "#/components/schemas/WebSearch", - "description": "Optional. Enables web search. Only text results are returned." - }, - "imageSearch": { - "description": "Optional. Enables image search. Image bytes are returned.", - "$ref": "#/components/schemas/ImageSearch" - } - } - }, - "SearchEntryPoint": { - "type": "object", - "description": "Google search entry point.", - "properties": { - "renderedContent": { - "type": "string", - "description": "Optional. Web content snippet that can be embedded in a web page or an app webview." - }, - "sdkBlob": { - "type": "string", - "format": "byte", - "description": "Optional. Base64 encoded JSON representing array of tuple." - } - } - }, - "FunctionDeclaration": { - "description": "Structured representation of a function declaration as defined by the [OpenAPI 3.03 specification](https://spec.openapis.org/oas/v3.0.3). Included in this declaration are the function name and parameters. This FunctionDeclaration is a representation of a block of code that can be used as a `Tool` by the model and executed by the client.", + "GroundingMetadata": { "properties": { - "parametersJsonSchema": { - "description": "Optional. Describes the parameters to the function in JSON Schema format. The schema must describe an object where the properties are the parameters to the function. For example: ``` { \"type\": \"object\", \"properties\": { \"name\": { \"type\": \"string\" }, \"age\": { \"type\": \"integer\" } }, \"additionalProperties\": false, \"required\": [\"name\", \"age\"], \"propertyOrdering\": [\"name\", \"age\"] } ``` This field is mutually exclusive with `parameters`." + "searchEntryPoint": { + "description": "Optional. Google search entry for the following-up web searches.", + "$ref": "#/components/schemas/SearchEntryPoint" }, - "parameters": { - "description": "Optional. Describes the parameters to this function. Reflects the Open API 3.03 Parameter Object string Key: the name of the parameter. Parameter names are case sensitive. Schema Value: the Schema defining the type used for the parameter.", - "$ref": "#/components/schemas/Schema" + "retrievalMetadata": { + "$ref": "#/components/schemas/RetrievalMetadata", + "description": "Metadata related to retrieval in the grounding flow." }, - "responseJsonSchema": { - "description": "Optional. Describes the output from this function in JSON Schema format. The value specified by the schema is the response value of the function. This field is mutually exclusive with `response`." + "imageSearchQueries": { + "description": "Image search queries used for grounding.", + "type": "array", + "items": { + "type": "string" + } }, - "response": { - "$ref": "#/components/schemas/Schema", - "description": "Optional. Describes the output from this function in JSON Schema format. Reflects the Open API 3.03 Response Object. The Schema defines the type used for the response value of the function." + "groundingChunks": { + "type": "array", + "items": { + "$ref": "#/components/schemas/GroundingChunk" + }, + "description": "List of supporting references retrieved from specified grounding source. When streaming, this only contains the grounding chunks that have not been included in the grounding metadata of previous responses." }, - "description": { - "description": "Required. A brief description of the function.", - "type": "string" + "groundingSupports": { + "type": "array", + "items": { + "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaGroundingSupport" + }, + "description": "List of grounding support." }, - "behavior": { - "enum": [ - "UNSPECIFIED", - "BLOCKING", - "NON_BLOCKING" - ], - "type": "string", - "x-enum-descriptions": [ - "This value is unused.", - "If set, the system will wait to receive the function response before continuing the conversation.", - "If set, the system will not wait to receive the function response. Instead, it will attempt to handle function responses as they become available while maintaining the conversation between the user and the model." - ], - "description": "Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method." + "webSearchQueries": { + "type": "array", + "items": { + "type": "string" + }, + "description": "Web search queries for the following-up web search." }, - "name": { + "googleMapsWidgetContextToken": { "type": "string", - "description": "Required. The name of the function. Must be a-z, A-Z, 0-9, or contain underscores, colons, dots, and dashes, with a maximum length of 128." + "description": "Optional. Resource name of the Google Maps widget context token that can be used with the PlacesContextElement widget in order to render contextual data. Only populated in the case that grounding with Google Maps is enabled." } }, + "description": "Metadata returned to client when grounding is enabled.", "type": "object" }, - "Operation": { - "description": "This resource represents a long-running operation that is the result of a network API call.", + "BatchGenerateContentRequest": { + "type": "object", "properties": { - "done": { - "description": "If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available.", - "type": "boolean" + "batch": { + "description": "Required. The batch to create.", + "$ref": "#/components/schemas/GenerateContentBatch" + } + }, + "description": "Request for a `BatchGenerateContent` operation." + }, + "VideoMetadata": { + "description": "Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content.", + "deprecated": true, + "properties": { + "fps": { + "type": "number", + "format": "double", + "description": "Optional. The frame rate of the video sent to the model. If not specified, the default value will be 1.0. The fps range is (0.0, 24.0]." }, - "name": { + "endOffset": { "type": "string", - "description": "The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`." - }, - "error": { - "$ref": "#/components/schemas/Status", - "description": "The error result of the operation in case of failure or cancellation." - }, - "response": { - "type": "object", - "additionalProperties": { - "description": "Properties of the object. Contains field @type with type URL." - }, - "description": "The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`." + "format": "google-duration", + "description": "Optional. The end offset of the video." }, - "metadata": { - "type": "object", - "additionalProperties": { - "description": "Properties of the object. Contains field @type with type URL." - }, - "description": "Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any." + "startOffset": { + "type": "string", + "format": "google-duration", + "description": "Optional. The start offset of the video." } }, "type": "object" }, - "GoogleAiGenerativelanguageV1betaSegment": { + "GenerateContentResponse": { "type": "object", - "description": "Segment of the content.", "properties": { - "partIndex": { - "type": "integer", - "format": "int32", - "description": "The index of a Part object within its parent Content object." + "usageMetadata": { + "readOnly": true, + "$ref": "#/components/schemas/UsageMetadata", + "description": "Output only. Metadata on the generation requests' token usage." }, - "text": { - "description": "The text corresponding to the segment from the response.", + "responseId": { + "description": "Output only. response_id is used to identify each response.", + "readOnly": true, "type": "string" }, - "startIndex": { - "format": "int32", - "type": "integer", - "description": "Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero." + "modelVersion": { + "readOnly": true, + "description": "Output only. The model version used to generate the response.", + "type": "string" }, - "endIndex": { - "format": "int32", - "type": "integer", - "description": "End index in the given Part, measured in bytes. Offset from the start of the Part, exclusive, starting at zero." - } - } - }, - "TransferOwnershipResponse": { - "description": "Response from `TransferOwnership`.", - "properties": {}, - "type": "object" - }, - "GoogleAiGenerativelanguageV1betaGroundingSupport": { - "type": "object", - "description": "Grounding support.", - "properties": { - "groundingChunkIndices": { - "description": "Optional. A list of indices (into 'grounding_chunk' in `response.candidate.grounding_metadata`) specifying the citations associated with the claim. For instance [1,3,4] means that grounding_chunk[1], grounding_chunk[3], grounding_chunk[4] are the retrieved content attributed to the claim. If the response is streaming, the grounding_chunk_indices refer to the indices across all responses. It is the client's responsibility to accumulate the grounding chunks from all responses (while maintaining the same order).", - "type": "array", - "items": { - "type": "integer", - "format": "int32" - } + "promptFeedback": { + "$ref": "#/components/schemas/PromptFeedback", + "description": "Returns the prompt's feedback related to the content filters." }, - "confidenceScores": { + "candidates": { "type": "array", "items": { - "type": "number", - "format": "float" + "$ref": "#/components/schemas/Candidate" }, - "description": "Optional. Confidence score of the support references. Ranges from 0 to 1. 1 is the most confident. This list must have the same size as the grounding_chunk_indices." + "description": "Candidate responses from the model." }, - "segment": { - "description": "Segment of the content this support belongs to.", - "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaSegment" - }, - "renderedParts": { - "description": "Output only. Indices into the `parts` field of the candidate's content. These indices specify which rendered parts are associated with this support source.", + "modelStatus": { "readOnly": true, - "type": "array", - "items": { - "type": "integer", - "format": "int32" - } + "$ref": "#/components/schemas/ModelStatus", + "description": "Output only. The current model status of this model." } - } + }, + "description": "Response from the model supporting multiple candidate responses. Safety ratings and content filtering are reported for both prompt in `GenerateContentResponse.prompt_feedback` and for each candidate in `finish_reason` and in `safety_ratings`. The API: - Returns either all requested candidates or none of them - Returns no candidates at all only if there was something wrong with the prompt (check `prompt_feedback`) - Reports feedback on each candidate in `finish_reason` and `safety_ratings`." }, - "CachedContent": { - "description": "Content that has been preprocessed and can be used in subsequent request to GenerativeService. Cached content can be only used with model it was created for.", + "SafetySetting": { + "type": "object", + "description": "Safety setting, affecting the safety-blocking behavior. Passing a safety setting for a category changes the allowed probability that content is blocked.", "properties": { - "expireTime": { - "description": "Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input.", - "format": "google-datetime", - "type": "string" + "threshold": { + "type": "string", + "x-enum-descriptions": [ + "Threshold is unspecified.", + "Content with NEGLIGIBLE will be allowed.", + "Content with NEGLIGIBLE and LOW will be allowed.", + "Content with NEGLIGIBLE, LOW, and MEDIUM will be allowed.", + "All content will be allowed.", + "Turn off the safety filter." + ], + "enum": [ + "HARM_BLOCK_THRESHOLD_UNSPECIFIED", + "BLOCK_LOW_AND_ABOVE", + "BLOCK_MEDIUM_AND_ABOVE", + "BLOCK_ONLY_HIGH", + "BLOCK_NONE", + "OFF" + ], + "description": "Required. Controls the probability threshold at which harm is blocked." }, - "updateTime": { - "format": "google-datetime", - "readOnly": true, + "category": { "type": "string", - "description": "Output only. When the cache entry was last updated in UTC time." + "description": "Required. The category for this setting.", + "enumDeprecated": [ + false, + false, + false, + false, + false, + false, + false, + false, + false, + false, + false, + true + ], + "x-enum-descriptions": [ + "Category is unspecified.", + "**PaLM** - Negative or harmful comments targeting identity and/or protected attribute.", + "**PaLM** - Content that is rude, disrespectful, or profane.", + "**PaLM** - Describes scenarios depicting violence against an individual or group, or general descriptions of gore.", + "**PaLM** - Contains references to sexual acts or other lewd content.", + "**PaLM** - Promotes unchecked medical advice.", + "**PaLM** - Dangerous content that promotes, facilitates, or encourages harmful acts.", + "**Gemini** - Harassment content.", + "**Gemini** - Hate speech and content.", + "**Gemini** - Sexually explicit content.", + "**Gemini** - Dangerous content.", + "**Gemini** - Content that may be used to harm civic integrity. DEPRECATED: use enable_enhanced_civic_answers instead." + ], + "enum": [ + "HARM_CATEGORY_UNSPECIFIED", + "HARM_CATEGORY_DEROGATORY", + "HARM_CATEGORY_TOXICITY", + "HARM_CATEGORY_VIOLENCE", + "HARM_CATEGORY_SEXUAL", + "HARM_CATEGORY_MEDICAL", + "HARM_CATEGORY_DANGEROUS", + "HARM_CATEGORY_HARASSMENT", + "HARM_CATEGORY_HATE_SPEECH", + "HARM_CATEGORY_SEXUALLY_EXPLICIT", + "HARM_CATEGORY_DANGEROUS_CONTENT", + "HARM_CATEGORY_CIVIC_INTEGRITY" + ] + } + } + }, + "GenerateContentRequest": { + "description": "Request to generate a completion from the model.", + "properties": { + "cachedContent": { + "description": "Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}`", + "type": "string" }, "toolConfig": { - "$ref": "#/components/schemas/ToolConfig", - "description": "Optional. Input only. Immutable. Tool config. This config is shared for all tools." - }, - "displayName": { - "type": "string", - "description": "Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters." + "description": "Optional. Tool configuration for any `Tool` specified in the request. Refer to the [Function calling guide](https://ai.google.dev/gemini-api/docs/function-calling#function_calling_mode) for a usage example.", + "$ref": "#/components/schemas/ToolConfig" }, - "ttl": { - "format": "google-duration", - "type": "string", - "description": "Input only. New TTL for this resource, input only." + "systemInstruction": { + "description": "Optional. Developer set [system instruction(s)](https://ai.google.dev/gemini-api/docs/system-instructions). Currently, text only.", + "$ref": "#/components/schemas/Content" }, - "name": { - "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`", - "readOnly": true, - "type": "string" + "store": { + "type": "boolean", + "description": "Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config." }, - "createTime": { - "description": "Output only. Creation time of the cache entry.", - "format": "google-datetime", - "readOnly": true, - "type": "string" + "generationConfig": { + "description": "Optional. Configuration options for model generation and outputs.", + "$ref": "#/components/schemas/GenerationConfig" }, - "systemInstruction": { - "$ref": "#/components/schemas/Content", - "description": "Optional. Input only. Immutable. Developer set system instruction. Currently text only." + "serviceTier": { + "description": "Optional. The service tier of the request.", + "type": "string", + "x-enum-descriptions": [ + "Default service tier, which is standard.", + "Standard service tier.", + "Flex service tier.", + "Priority service tier." + ], + "enum": [ + "unspecified", + "standard", + "flex", + "priority" + ] }, "contents": { - "description": "Optional. Input only. Immutable. The content to cache.", "type": "array", "items": { "$ref": "#/components/schemas/Content" - } - }, - "usageMetadata": { - "description": "Output only. Metadata on the usage of the cached content.", - "readOnly": true, - "$ref": "#/components/schemas/CachedContentUsageMetadata" + }, + "description": "Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request." }, "tools": { - "description": "Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response", + "description": "Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more.", "type": "array", "items": { "$ref": "#/components/schemas/Tool" } }, "model": { - "description": "Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}`", - "type": "string" - } - }, - "type": "object" - }, - "CountTokensRequest": { - "type": "object", - "description": "Counts the number of tokens in the `prompt` sent to a model. Models may tokenize text differently, so each model may return a different `token_count`.", - "properties": { - "contents": { + "type": "string", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`." + }, + "safetySettings": { "type": "array", "items": { - "$ref": "#/components/schemas/Content" + "$ref": "#/components/schemas/SafetySetting" }, - "description": "Optional. The input given to the model as a prompt. This field is ignored when `generate_content_request` is set." - }, - "generateContentRequest": { - "$ref": "#/components/schemas/GenerateContentRequest", - "description": "Optional. The overall input given to the `Model`. This includes the prompt as well as other model steering information like [system instructions](https://ai.google.dev/gemini-api/docs/system-instructions), and/or function declarations for [function calling](https://ai.google.dev/gemini-api/docs/function-calling). `Model`s/`Content`s and `generate_content_request`s are mutually exclusive. You can either send `Model` + `Content`s or a `generate_content_request`, but never both." + "description": "Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications." } - } + }, + "type": "object" }, - "BatchStats": { - "type": "object", - "description": "Stats about the batch.", + "CreateFileResponse": { "properties": { - "requestCount": { - "readOnly": true, - "type": "string", - "format": "int64", - "description": "Output only. The number of requests in the batch." - }, - "pendingRequestCount": { - "description": "Output only. The number of requests that are still pending processing.", - "format": "int64", - "readOnly": true, - "type": "string" - }, - "successfulRequestCount": { - "readOnly": true, - "type": "string", - "format": "int64", - "description": "Output only. The number of requests that were successfully processed." - }, - "failedRequestCount": { - "format": "int64", - "readOnly": true, - "type": "string", - "description": "Output only. The number of requests that failed to be processed." + "file": { + "description": "Metadata for the created file.", + "$ref": "#/components/schemas/File" } - } + }, + "description": "Response for `CreateFile`.", + "type": "object" }, - "GroundingMetadata": { - "description": "Metadata returned to client when grounding is enabled.", + "ToolConfig": { + "description": "The Tool configuration containing parameters for specifying `Tool` use in the request.", "properties": { - "webSearchQueries": { - "description": "Web search queries for the following-up web search.", - "type": "array", - "items": { - "type": "string" - } - }, - "searchEntryPoint": { - "$ref": "#/components/schemas/SearchEntryPoint", - "description": "Optional. Google search entry for the following-up web searches." - }, - "groundingSupports": { - "type": "array", - "items": { - "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaGroundingSupport" - }, - "description": "List of grounding support." - }, - "groundingChunks": { - "description": "List of supporting references retrieved from specified grounding source. When streaming, this only contains the grounding chunks that have not been included in the grounding metadata of previous responses.", - "type": "array", - "items": { - "$ref": "#/components/schemas/GroundingChunk" - } - }, - "imageSearchQueries": { - "description": "Image search queries used for grounding.", - "type": "array", - "items": { - "type": "string" - } + "functionCallingConfig": { + "$ref": "#/components/schemas/FunctionCallingConfig", + "description": "Optional. Function calling config." }, - "googleMapsWidgetContextToken": { - "type": "string", - "description": "Optional. Resource name of the Google Maps widget context token that can be used with the PlacesContextElement widget in order to render contextual data. Only populated in the case that grounding with Google Maps is enabled." + "retrievalConfig": { + "description": "Optional. Retrieval config.", + "$ref": "#/components/schemas/RetrievalConfig" }, - "retrievalMetadata": { - "description": "Metadata related to retrieval in the grounding flow.", - "$ref": "#/components/schemas/RetrievalMetadata" + "includeServerSideToolInvocations": { + "type": "boolean", + "description": "Optional. If true, the API response will include the server-side tool calls and responses within the `Content` message. This allows clients to observe the server's tool interactions." } }, "type": "object" }, "InlinedRequest": { + "type": "object", "description": "The request to be processed in the batch.", "properties": { "request": { @@ -3519,1526 +3590,1299 @@ "$ref": "#/components/schemas/GenerateContentRequest" }, "metadata": { + "description": "Optional. The metadata to be associated with the request.", "type": "object", "additionalProperties": { "description": "Properties of the object." - }, - "description": "Optional. The metadata to be associated with the request." + } } - }, - "type": "object" + } }, - "UrlContext": { - "description": "Tool to support URL context retrieval.", - "properties": {}, + "ListFileSearchStoresResponse": { + "description": "Response from `ListFileSearchStores` containing a paginated list of `FileSearchStores`. The results are sorted by ascending `file_search_store.create_time`.", + "properties": { + "fileSearchStores": { + "description": "The returned rag_stores.", + "type": "array", + "items": { + "$ref": "#/components/schemas/FileSearchStore" + } + }, + "nextPageToken": { + "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", + "type": "string" + } + }, "type": "object" }, - "FunctionCallingConfig": { - "description": "Configuration for specifying function calling behavior.", - "properties": { - "mode": { - "description": "Optional. Specifies the mode in which function calling should execute. If unspecified, the default value will be set to AUTO.", - "type": "string", - "x-enum-descriptions": [ - "Unspecified function calling mode. This value should not be used.", - "Default model behavior, model decides to predict either a function call or a natural language response.", - "Model is constrained to always predicting a function call only. If \"allowed_function_names\" are set, the predicted function call will be limited to any one of \"allowed_function_names\", else the predicted function call will be any one of the provided \"function_declarations\".", - "Model will not predict any function call. Model behavior is same as when not passing any function declarations.", - "Model decides to predict either a function call or a natural language response, but will validate function calls with constrained decoding. If \"allowed_function_names\" are set, the predicted function call will be limited to any one of \"allowed_function_names\", else the predicted function call will be any one of the provided \"function_declarations\"." - ], - "enum": [ - "MODE_UNSPECIFIED", - "AUTO", - "ANY", - "NONE", - "VALIDATED" - ] - }, - "allowedFunctionNames": { - "description": "Optional. A set of function names that, when provided, limits the functions the model will call. This should only be set when the Mode is ANY or VALIDATED. Function names should match [FunctionDeclaration.name]. When set, model will predict a function call from only allowed function names.", - "type": "array", - "items": { - "type": "string" - } + "FunctionResponsePart": { + "description": "A datatype containing media that is part of a `FunctionResponse` message. A `FunctionResponsePart` consists of data which has an associated datatype. A `FunctionResponsePart` can only contain one of the accepted types in `FunctionResponsePart.data`. A `FunctionResponsePart` must have a fixed IANA MIME type identifying the type and subtype of the media if the `inline_data` field is filled with raw bytes.", + "properties": { + "inlineData": { + "description": "Inline media bytes.", + "$ref": "#/components/schemas/FunctionResponseBlob" } }, "type": "object" }, - "Document": { - "description": "A `Document` is a collection of `Chunk`s.", + "InlinedResponse": { "properties": { - "updateTime": { - "format": "google-datetime", - "readOnly": true, - "type": "string", - "description": "Output only. The Timestamp of when the `Document` was last updated." - }, - "mimeType": { - "readOnly": true, - "type": "string", - "description": "Output only. The mime type of the Document." - }, - "customMetadata": { - "type": "array", - "items": { - "$ref": "#/components/schemas/CustomMetadata" - }, - "description": "Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`." - }, - "name": { - "type": "string", - "description": "Immutable. Identifier. The `Document` resource name. The ID (name excluding the \"fileSearchStores/*/documents/\" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/{file_search_store_id}/documents/my-awesome-doc-123a456b789c`" - }, - "displayName": { - "type": "string", - "description": "Optional. The human-readable display name for the `Document`. The display name must be no more than 512 characters in length, including spaces. Example: \"Semantic Retriever Documentation\"" - }, - "state": { - "description": "Output only. Current state of the `Document`.", - "enum": [ - "STATE_UNSPECIFIED", - "STATE_PENDING", - "STATE_ACTIVE", - "STATE_FAILED" - ], + "metadata": { "readOnly": true, - "x-enum-descriptions": [ - "The default value. This value is used if the state is omitted.", - "Some `Chunks` of the `Document` are being processed (embedding and vector storage).", - "All `Chunks` of the `Document` is processed and available for querying.", - "Some `Chunks` of the `Document` failed processing." - ], - "type": "string" + "description": "Output only. The metadata associated with the request.", + "type": "object", + "additionalProperties": { + "description": "Properties of the object." + } }, - "sizeBytes": { + "error": { + "description": "Output only. The error encountered while processing the request.", "readOnly": true, - "type": "string", - "format": "int64", - "description": "Output only. The size of raw bytes ingested into the Document." + "$ref": "#/components/schemas/Status" }, - "createTime": { - "description": "Output only. The Timestamp of when the `Document` was created.", + "response": { "readOnly": true, - "type": "string", - "format": "google-datetime" + "$ref": "#/components/schemas/GenerateContentResponse", + "description": "Output only. The response to the request." } }, + "description": "The response to a single request in the batch.", "type": "object" }, - "ListOperationsResponse": { - "description": "The response message for Operations.ListOperations.", + "PromptFeedback": { + "description": "A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`.", "properties": { - "nextPageToken": { + "blockReason": { "type": "string", - "description": "The standard List next-page token." - }, - "operations": { - "description": "A list of operations that matches the specified filter in the request.", - "type": "array", - "items": { - "$ref": "#/components/schemas/Operation" - } + "x-enum-descriptions": [ + "Default value. This value is unused.", + "Prompt was blocked due to safety reasons. Inspect `safety_ratings` to understand which safety category blocked it.", + "Prompt was blocked due to unknown reasons.", + "Prompt was blocked due to the terms which are included from the terminology blocklist.", + "Prompt was blocked due to prohibited content.", + "Candidates blocked due to unsafe image generation content." + ], + "enum": [ + "BLOCK_REASON_UNSPECIFIED", + "SAFETY", + "OTHER", + "BLOCKLIST", + "PROHIBITED_CONTENT", + "IMAGE_SAFETY" + ], + "description": "Optional. If set, the prompt was blocked and no candidates are returned. Rephrase the prompt." }, - "unreachable": { - "description": "Unordered list. Unreachable resources. Populated when the request sets `ListOperationsRequest.return_partial_success` and reads across collections. For example, when attempting to list all resources across all supported locations.", + "safetyRatings": { + "description": "Ratings for safety of the prompt. There is at most one rating per category.", "type": "array", "items": { - "type": "string" + "$ref": "#/components/schemas/SafetyRating" } } }, "type": "object" }, - "BatchEmbedContentsRequest": { + "FileData": { "type": "object", - "description": "Batch request to get embeddings from the model for a list of prompts.", + "description": "URI based data.", "properties": { - "requests": { - "type": "array", - "items": { - "$ref": "#/components/schemas/EmbedContentRequest" - }, - "description": "Required. Embed requests for the batch. The model in each of these requests must match the model specified `BatchEmbedContentsRequest.model`." + "fileUri": { + "type": "string", + "description": "Required. URI." + }, + "mimeType": { + "description": "Optional. The IANA standard MIME type of the source data.", + "type": "string" } } }, - "BatchEmbedContentsResponse": { + "PrebuiltVoiceConfig": { "type": "object", - "description": "The response to a `BatchEmbedContentsRequest`.", "properties": { - "embeddings": { - "readOnly": true, - "type": "array", - "items": { - "$ref": "#/components/schemas/ContentEmbedding" - }, - "description": "Output only. The embeddings for each request, in the same order as provided in the batch request." - }, - "usageMetadata": { - "readOnly": true, - "$ref": "#/components/schemas/EmbeddingUsageMetadata", - "description": "Output only. The usage metadata for the request." + "voiceName": { + "type": "string", + "description": "The name of the preset voice to use." } - } + }, + "description": "The configuration for the prebuilt speaker to use." }, - "Schema": { + "ListCachedContentsResponse": { "type": "object", - "description": "The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema).", + "description": "Response with CachedContents list.", "properties": { - "nullable": { - "description": "Optional. Indicates if the value may be null.", - "type": "boolean" - }, - "maximum": { - "format": "double", - "type": "number", - "description": "Optional. Maximum value of the Type.INTEGER and Type.NUMBER" - }, - "minItems": { - "description": "Optional. Minimum number of the elements for Type.ARRAY.", - "format": "int64", - "type": "string" - }, - "minProperties": { - "type": "string", - "format": "int64", - "description": "Optional. Minimum number of the properties for Type.OBJECT." - }, - "minLength": { - "format": "int64", - "type": "string", - "description": "Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING" - }, - "maxProperties": { - "description": "Optional. Maximum number of the properties for Type.OBJECT.", - "format": "int64", - "type": "string" - }, - "anyOf": { - "description": "Optional. The value should be validated against any (one or more) of the subschemas in the list.", + "cachedContents": { + "description": "List of cached contents.", "type": "array", "items": { - "$ref": "#/components/schemas/Schema" + "$ref": "#/components/schemas/CachedContent" } }, - "type": { - "description": "Required. Data type.", - "enum": [ - "TYPE_UNSPECIFIED", - "STRING", - "NUMBER", - "INTEGER", - "BOOLEAN", - "ARRAY", - "OBJECT", - "NULL" - ], + "nextPageToken": { + "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.", + "type": "string" + } + } + }, + "SafetyRating": { + "description": "Safety rating for a piece of content. The safety rating contains the category of harm and the harm probability level in that category for a piece of content. Content is classified for safety across a number of harm categories and the probability of the harm classification is included here.", + "properties": { + "probability": { "type": "string", "x-enum-descriptions": [ - "Not specified, should not be used.", - "String type.", - "Number type.", - "Integer type.", - "Boolean type.", - "Array type.", - "Object type.", - "Null type." - ] + "Probability is unspecified.", + "Content has a negligible chance of being unsafe.", + "Content has a low chance of being unsafe.", + "Content has a medium chance of being unsafe.", + "Content has a high chance of being unsafe." + ], + "enum": [ + "HARM_PROBABILITY_UNSPECIFIED", + "NEGLIGIBLE", + "LOW", + "MEDIUM", + "HIGH" + ], + "description": "Required. The probability of harm for this content." }, - "minimum": { - "description": "Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER", - "type": "number", - "format": "double" + "blocked": { + "type": "boolean", + "description": "Was this content blocked because of this rating?" }, - "format": { - "description": "Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality.", + "category": { + "description": "Required. The category for this rating.", + "enumDeprecated": [ + false, + false, + false, + false, + false, + false, + false, + false, + false, + false, + false, + true + ], + "x-enum-descriptions": [ + "Category is unspecified.", + "**PaLM** - Negative or harmful comments targeting identity and/or protected attribute.", + "**PaLM** - Content that is rude, disrespectful, or profane.", + "**PaLM** - Describes scenarios depicting violence against an individual or group, or general descriptions of gore.", + "**PaLM** - Contains references to sexual acts or other lewd content.", + "**PaLM** - Promotes unchecked medical advice.", + "**PaLM** - Dangerous content that promotes, facilitates, or encourages harmful acts.", + "**Gemini** - Harassment content.", + "**Gemini** - Hate speech and content.", + "**Gemini** - Sexually explicit content.", + "**Gemini** - Dangerous content.", + "**Gemini** - Content that may be used to harm civic integrity. DEPRECATED: use enable_enhanced_civic_answers instead." + ], + "enum": [ + "HARM_CATEGORY_UNSPECIFIED", + "HARM_CATEGORY_DEROGATORY", + "HARM_CATEGORY_TOXICITY", + "HARM_CATEGORY_VIOLENCE", + "HARM_CATEGORY_SEXUAL", + "HARM_CATEGORY_MEDICAL", + "HARM_CATEGORY_DANGEROUS", + "HARM_CATEGORY_HARASSMENT", + "HARM_CATEGORY_HATE_SPEECH", + "HARM_CATEGORY_SEXUALLY_EXPLICIT", + "HARM_CATEGORY_DANGEROUS_CONTENT", + "HARM_CATEGORY_CIVIC_INTEGRITY" + ], "type": "string" + } + }, + "type": "object" + }, + "BatchEmbedContentsResponse": { + "type": "object", + "description": "The response to a `BatchEmbedContentsRequest`.", + "properties": { + "usageMetadata": { + "description": "Output only. The usage metadata for the request.", + "readOnly": true, + "$ref": "#/components/schemas/EmbeddingUsageMetadata" }, - "enum": { + "embeddings": { "type": "array", "items": { - "type": "string" + "$ref": "#/components/schemas/ContentEmbedding" }, - "description": "Optional. Possible values of the element of Type.STRING with enum format. For example we can define an Enum Direction as : {type:STRING, format:enum, enum:[\"EAST\", NORTH\", \"SOUTH\", \"WEST\"]}" - }, - "pattern": { - "type": "string", - "description": "Optional. Pattern of the Type.STRING to restrict a string to a regular expression." - }, - "required": { - "description": "Optional. Required properties of Type.OBJECT.", - "type": "array", - "items": { - "type": "string" - } - }, - "default": { - "description": "Optional. Default value of the field. Per JSON Schema, this field is intended for documentation generators and doesn't affect validation. Thus it's included here and ignored so that developers who send schemas with a `default` field don't get unknown-field errors." - }, - "example": { - "description": "Optional. Example of the object. Will only populated when the object is the root." - }, - "maxLength": { - "format": "int64", - "type": "string", - "description": "Optional. Maximum length of the Type.STRING" - }, - "maxItems": { - "type": "string", - "format": "int64", - "description": "Optional. Maximum number of the elements for Type.ARRAY." - }, - "description": { + "description": "Output only. The embeddings for each request, in the same order as provided in the batch request.", + "readOnly": true + } + } + }, + "VideoFileMetadata": { + "type": "object", + "description": "Metadata for a video `File`.", + "properties": { + "videoDuration": { "type": "string", - "description": "Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown." - }, - "items": { - "description": "Optional. Schema of the elements of Type.ARRAY.", - "$ref": "#/components/schemas/Schema" - }, - "title": { - "description": "Optional. The title of the schema.", - "type": "string" - }, - "propertyOrdering": { - "description": "Optional. The order of the properties. Not a standard field in open api spec. Used to determine the order of the properties in the response.", - "type": "array", - "items": { - "type": "string" - } - }, - "properties": { - "description": "Optional. Properties of Type.OBJECT.", - "type": "object", - "additionalProperties": { - "$ref": "#/components/schemas/Schema" - } + "format": "google-duration", + "description": "Duration of the video." } } }, - "GenerateContentResponse": { + "ToolCall": { "type": "object", - "description": "Response from the model supporting multiple candidate responses. Safety ratings and content filtering are reported for both prompt in `GenerateContentResponse.prompt_feedback` and for each candidate in `finish_reason` and in `safety_ratings`. The API: - Returns either all requested candidates or none of them - Returns no candidates at all only if there was something wrong with the prompt (check `prompt_feedback`) - Reports feedback on each candidate in `finish_reason` and `safety_ratings`.", + "description": "A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`.", "properties": { - "usageMetadata": { - "description": "Output only. Metadata on the generation requests' token usage.", - "readOnly": true, - "$ref": "#/components/schemas/UsageMetadata" - }, - "modelStatus": { - "readOnly": true, - "$ref": "#/components/schemas/ModelStatus", - "description": "Output only. The current model status of this model." - }, - "modelVersion": { - "readOnly": true, + "toolType": { + "description": "Required. The type of tool that was called.", "type": "string", - "description": "Output only. The model version used to generate the response." - }, - "candidates": { - "description": "Candidate responses from the model.", - "type": "array", - "items": { - "$ref": "#/components/schemas/Candidate" - } - }, - "promptFeedback": { - "$ref": "#/components/schemas/PromptFeedback", - "description": "Returns the prompt's feedback related to the content filters." + "x-enum-descriptions": [ + "Unspecified tool type.", + "Google search tool, maps to Tool.google_search.search_types.web_search.", + "Image search tool, maps to Tool.google_search.search_types.image_search.", + "URL context tool, maps to Tool.url_context.", + "Google maps tool, maps to Tool.google_maps.", + "File search tool, maps to Tool.file_search." + ], + "enum": [ + "TOOL_TYPE_UNSPECIFIED", + "GOOGLE_SEARCH_WEB", + "GOOGLE_SEARCH_IMAGE", + "URL_CONTEXT", + "GOOGLE_MAPS", + "FILE_SEARCH" + ] }, - "responseId": { - "description": "Output only. response_id is used to identify each response.", - "readOnly": true, + "id": { + "description": "Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`.", "type": "string" + }, + "args": { + "description": "Optional. The tool call arguments. Example: {\"arg1\" : \"value1\", \"arg2\" : \"value2\" , ...}", + "type": "object", + "additionalProperties": { + "description": "Properties of the object." + } } } }, - "FunctionResponsePart": { - "type": "object", - "description": "A datatype containing media that is part of a `FunctionResponse` message. A `FunctionResponsePart` consists of data which has an associated datatype. A `FunctionResponsePart` can only contain one of the accepted types in `FunctionResponsePart.data`. A `FunctionResponsePart` must have a fixed IANA MIME type identifying the type and subtype of the media if the `inline_data` field is filled with raw bytes.", + "GoogleSearchRetrieval": { "properties": { - "inlineData": { - "$ref": "#/components/schemas/FunctionResponseBlob", - "description": "Inline media bytes." + "dynamicRetrievalConfig": { + "description": "Specifies the dynamic retrieval configuration for the given source.", + "$ref": "#/components/schemas/DynamicRetrievalConfig" } - } + }, + "description": "Tool to retrieve public web data for grounding, powered by Google.", + "type": "object" }, - "ListModelsResponse": { - "description": "Response from `ListModel` containing a paginated list of Models.", + "Image": { + "description": "Chunk from image search.", "properties": { - "models": { - "description": "The returned Models.", - "type": "array", - "items": { - "$ref": "#/components/schemas/Model" - } + "imageUri": { + "type": "string", + "description": "The image asset URL." + }, + "domain": { + "type": "string", + "description": "The root domain of the web page that the image is from, e.g. \"example.com\"." + }, + "sourceUri": { + "description": "The web page URI for attribution.", + "type": "string" }, - "nextPageToken": { - "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", + "title": { + "description": "The title of the web page that the image is from.", "type": "string" } }, "type": "object" }, - "ListCorporaResponse": { - "description": "Response from `ListCorpora` containing a paginated list of `Corpora`. The results are sorted by ascending `corpus.create_time`.", + "UploadToFileSearchStoreRequest": { + "description": "Request for `UploadToFileSearchStore`.", "properties": { - "corpora": { + "chunkingConfig": { + "description": "Optional. Config for telling the service how to chunk the data. If not provided, the service will use default parameters.", + "$ref": "#/components/schemas/ChunkingConfig" + }, + "displayName": { + "type": "string", + "description": "Optional. Display name of the created document." + }, + "customMetadata": { "type": "array", "items": { - "$ref": "#/components/schemas/Corpus" + "$ref": "#/components/schemas/CustomMetadata" }, - "description": "The returned corpora." + "description": "Custom metadata to be associated with the data." }, - "nextPageToken": { + "mimeType": { "type": "string", - "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages." + "description": "Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content." } }, "type": "object" }, - "ImportFileRequest": { - "description": "Request for `ImportFile` to import a File API file with a `FileSearchStore`.", + "PlaceAnswerSources": { "properties": { - "customMetadata": { + "reviewSnippets": { + "description": "Snippets of reviews that are used to generate answers about the features of a given place in Google Maps.", "type": "array", "items": { - "$ref": "#/components/schemas/CustomMetadata" - }, - "description": "Custom metadata to be associated with the file." - }, - "chunkingConfig": { - "description": "Optional. Config for telling the service how to chunk the file. If not provided, the service will use default parameters.", - "$ref": "#/components/schemas/ChunkingConfig" - }, - "fileName": { - "description": "Required. The name of the `File` to import. Example: `files/abc-123`", - "type": "string" + "$ref": "#/components/schemas/ReviewSnippet" + } } }, + "description": "Collection of sources that provide answers about the features of a given place in Google Maps. Each PlaceAnswerSources message corresponds to a specific place in Google Maps. The Google Maps tool used these sources in order to answer questions about features of the place (e.g: \"does Bar Foo have Wifi\" or \"is Foo Bar wheelchair accessible?\"). Currently we only support review snippets as sources.", "type": "object" }, - "ModelStatus": { + "InlinedEmbedContentResponse": { "type": "object", - "description": "The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable.", + "description": "The response to a single request in the batch.", "properties": { - "modelStage": { - "x-enum-descriptions": [ - "Unspecified model stage.", - "The underlying model is subject to lots of tunings.", - "Models in this stage are for experimental purposes only.", - "Models in this stage are more mature than experimental models.", - "Models in this stage are considered stable and ready for production use.", - "If the model is on this stage, it means that this model is on the path to deprecation in near future. Only existing customers can use this model.", - "Models in this stage are deprecated. These models cannot be used.", - "Models in this stage are retired. These models cannot be used." - ], - "enum": [ - "MODEL_STAGE_UNSPECIFIED", - "UNSTABLE_EXPERIMENTAL", - "EXPERIMENTAL", - "PREVIEW", - "STABLE", - "LEGACY", - "DEPRECATED", - "RETIRED" - ], - "description": "The stage of the underlying model.", - "type": "string", - "enumDeprecated": [ - false, - true, - false, - false, - false, - false, - true, - false - ] - }, - "retirementTime": { - "description": "The time at which the model will be retired.", - "type": "string", - "format": "google-datetime" + "metadata": { + "readOnly": true, + "description": "Output only. The metadata associated with the request.", + "type": "object", + "additionalProperties": { + "description": "Properties of the object." + } }, - "message": { - "description": "A message explaining the model status.", - "type": "string" - } - } - }, - "GeneratedFile": { - "description": "A file generated on behalf of a user.", - "properties": { "error": { - "description": "Error details if the GeneratedFile ends up in the STATE_FAILED state.", + "description": "Output only. The error encountered while processing the request.", + "readOnly": true, "$ref": "#/components/schemas/Status" }, - "mimeType": { - "description": "MIME type of the generatedFile.", - "type": "string" - }, - "state": { - "type": "string", - "enum": [ - "STATE_UNSPECIFIED", - "GENERATING", - "GENERATED", - "FAILED" - ], + "response": { "readOnly": true, - "x-enum-descriptions": [ - "The default value. This value is used if the state is omitted.", - "Being generated.", - "Generated and is ready for download.", - "Failed to generate the GeneratedFile." - ], - "description": "Output only. The state of the GeneratedFile." - }, - "name": { - "type": "string", - "description": "Identifier. The name of the generated file. Example: `generatedFiles/abc-123`" + "$ref": "#/components/schemas/EmbedContentResponse", + "description": "Output only. The response to the request." } - }, - "type": "object" + } }, - "GenerateContentBatch": { - "type": "object", - "description": "A resource representing a batch of `GenerateContent` requests.", + "Model": { "properties": { - "displayName": { - "type": "string", - "description": "Required. The user-defined name of this batch." + "temperature": { + "type": "number", + "format": "float", + "description": "Controls the randomness of the output. Values can range over `[0.0,max_temperature]`, inclusive. A higher value will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be used by the backend while making the call to the model." }, "name": { - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", - "readOnly": true, + "description": "Required. The resource name of the `Model`. Refer to [Model variants](https://ai.google.dev/gemini-api/docs/models/gemini#model-variations) for all allowed values. Format: `models/{model}` with a `{model}` naming convention of: * \"{base_model_id}-{version}\" Examples: * `models/gemini-1.5-flash-001`", "type": "string" }, - "createTime": { - "format": "google-datetime", - "readOnly": true, + "version": { "type": "string", - "description": "Output only. The time at which the batch was created." + "description": "Required. The version number of the model. This represents the major version (`1.0` or `1.5`)" }, - "updateTime": { - "format": "google-datetime", - "readOnly": true, + "topP": { + "type": "number", + "format": "float", + "description": "For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model." + }, + "displayName": { "type": "string", - "description": "Output only. The time at which the batch was last updated." + "description": "The human-readable name of the model. E.g. \"Gemini 1.5 Flash\". The name can be up to 128 characters long and can consist of any UTF-8 characters." }, - "output": { - "description": "Output only. The output of the batch request.", - "readOnly": true, - "$ref": "#/components/schemas/GenerateContentBatchOutput" + "topK": { + "type": "integer", + "format": "int32", + "description": "For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. If empty, indicates the model doesn't use top-k sampling, and `top_k` isn't allowed as a generation parameter." }, - "endTime": { - "description": "Output only. The time at which the batch processing completed.", - "readOnly": true, - "type": "string", - "format": "google-datetime" + "supportedGenerationMethods": { + "type": "array", + "items": { + "type": "string" + }, + "description": "The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`." }, - "state": { - "readOnly": true, - "x-enum-descriptions": [ - "The batch state is unspecified.", - "The service is preparing to run the batch.", - "The batch is in progress.", - "The batch completed successfully.", - "The batch failed.", - "The batch has been cancelled.", - "The batch has expired." - ], - "enum": [ - "BATCH_STATE_UNSPECIFIED", - "BATCH_STATE_PENDING", - "BATCH_STATE_RUNNING", - "BATCH_STATE_SUCCEEDED", - "BATCH_STATE_FAILED", - "BATCH_STATE_CANCELLED", - "BATCH_STATE_EXPIRED" - ], - "description": "Output only. The state of the batch.", + "thinking": { + "type": "boolean", + "description": "Whether the model supports thinking." + }, + "description": { + "description": "A short description of the model.", "type": "string" }, - "model": { - "type": "string", - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`." + "maxTemperature": { + "description": "The maximum temperature this model can use.", + "type": "number", + "format": "float" }, - "inputConfig": { - "$ref": "#/components/schemas/InputConfig", - "description": "Required. Input configuration of the instances on which batch processing are performed." + "outputTokenLimit": { + "type": "integer", + "format": "int32", + "description": "Maximum number of output tokens available for this model." }, - "batchStats": { - "readOnly": true, - "$ref": "#/components/schemas/BatchStats", - "description": "Output only. Stats about the batch." + "inputTokenLimit": { + "description": "Maximum number of input tokens allowed for this model.", + "type": "integer", + "format": "int32" }, - "priority": { - "description": "Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0.", + "baseModelId": { "type": "string", - "format": "int64" - } - } - }, - "RegisterFilesResponse": { - "type": "object", - "description": "Response for `RegisterFiles`.", - "properties": { - "files": { - "type": "array", - "items": { - "$ref": "#/components/schemas/File" - }, - "description": "The registered files to be used when calling GenerateContent." - } - } - }, - "ListFileSearchStoresResponse": { - "type": "object", - "description": "Response from `ListFileSearchStores` containing a paginated list of `FileSearchStores`. The results are sorted by ascending `file_search_store.create_time`.", - "properties": { - "nextPageToken": { - "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", - "type": "string" - }, - "fileSearchStores": { - "type": "array", - "items": { - "$ref": "#/components/schemas/FileSearchStore" - }, - "description": "The returned rag_stores." + "description": "Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash`" } - } + }, + "description": "Information about a Generative Language Model.", + "type": "object" }, - "TopCandidates": { - "description": "Candidates with top log probabilities at each decoding step.", + "ListPermissionsResponse": { + "description": "Response from `ListPermissions` containing a paginated list of permissions.", "properties": { - "candidates": { - "description": "Sorted by log probability in descending order.", + "permissions": { + "description": "Returned permissions.", "type": "array", "items": { - "$ref": "#/components/schemas/LogprobsResultCandidate" + "$ref": "#/components/schemas/Permission" } + }, + "nextPageToken": { + "type": "string", + "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages." } }, "type": "object" }, - "ReviewSnippet": { - "type": "object", - "description": "Encapsulates a snippet of a user review that answers a question about the features of a specific place in Google Maps.", - "properties": { - "reviewId": { - "type": "string", - "description": "The ID of the review snippet." - }, - "title": { - "description": "Title of the review.", - "type": "string" - }, - "googleMapsUri": { - "type": "string", - "description": "A link that corresponds to the user review on Google Maps." - } - } + "TransferOwnershipResponse": { + "description": "Response from `TransferOwnership`.", + "properties": {}, + "type": "object" }, - "SemanticRetrieverChunk": { + "Dataset": { "type": "object", - "description": "Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`.", "properties": { - "source": { - "description": "Output only. Name of the source matching the request's `SemanticRetrieverConfig.source`. Example: `corpora/123` or `corpora/123/documents/abc`", - "readOnly": true, - "type": "string" - }, - "chunk": { - "description": "Output only. Name of the `Chunk` containing the attributed text. Example: `corpora/123/documents/abc/chunks/xyz`", - "readOnly": true, - "type": "string" + "examples": { + "description": "Optional. Inline examples with simple input/output text.", + "$ref": "#/components/schemas/TuningExamples" } - } + }, + "description": "Dataset for training or validation." }, - "ImageConfig": { - "type": "object", - "description": "Config for image generation features.", + "CitationSource": { + "description": "A citation to a source for a portion of a specific response.", "properties": { - "aspectRatio": { - "description": "Optional. The aspect ratio of the image to generate. Supported aspect ratios: `1:1`, `1:4`, `4:1`, `1:8`, `8:1`, `2:3`, `3:2`, `3:4`, `4:3`, `4:5`, `5:4`, `9:16`, `16:9`, or `21:9`. If not specified, the model will choose a default aspect ratio based on any reference images provided.", - "type": "string" + "endIndex": { + "type": "integer", + "format": "int32", + "description": "Optional. End of the attributed segment, exclusive." }, - "imageSize": { - "description": "Optional. Specifies the size of generated images. Supported values are `512`, `1K`, `2K`, `4K`. If not specified, the model will use default value `1K`.", - "type": "string" - } - } - }, - "Web": { - "description": "Chunk from the web.", - "properties": { "uri": { - "description": "Output only. URI reference of the chunk.", - "readOnly": true, - "type": "string" + "type": "string", + "description": "Optional. URI that is attributed as a source for a portion of the text." }, - "title": { - "description": "Output only. Title of the chunk.", - "readOnly": true, + "startIndex": { + "type": "integer", + "format": "int32", + "description": "Optional. Start of segment of the response that is attributed to this source. Index indicates the start of the segment, measured in bytes." + }, + "license": { + "description": "Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations.", "type": "string" } }, "type": "object" }, - "GroundingChunkCustomMetadata": { - "type": "object", - "description": "User provided metadata about the GroundingFact.", + "GoogleAiGenerativelanguageV1betaSegment": { + "description": "Segment of the content.", "properties": { - "stringListValue": { - "description": "Optional. A list of string values for the metadata.", - "$ref": "#/components/schemas/GroundingChunkStringList" + "partIndex": { + "type": "integer", + "format": "int32", + "description": "The index of a Part object within its parent Content object." }, - "numericValue": { - "type": "number", - "format": "float", - "description": "Optional. The numeric value of the metadata. The expected range for this value depends on the specific `key` used." + "startIndex": { + "type": "integer", + "format": "int32", + "description": "Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero." }, - "key": { - "type": "string", - "description": "The key of the metadata." + "endIndex": { + "type": "integer", + "format": "int32", + "description": "End index in the given Part, measured in bytes. Offset from the start of the Part, exclusive, starting at zero." }, - "stringValue": { - "description": "Optional. The string value of the metadata.", + "text": { + "description": "The text corresponding to the segment from the response.", "type": "string" } - } - }, - "GroundingAttribution": { - "description": "Attribution for a source that contributed to an answer.", - "properties": { - "sourceId": { - "description": "Output only. Identifier for the source contributing to this attribution.", - "readOnly": true, - "$ref": "#/components/schemas/AttributionSourceId" - }, - "content": { - "$ref": "#/components/schemas/Content", - "description": "Grounding source content that makes up this attribution." - } }, "type": "object" }, - "CustomLongRunningOperation": { + "Part": { "type": "object", + "description": "A datatype containing media that is part of a multi-part `Content` message. A `Part` consists of data which has an associated datatype. A `Part` can only contain one of the accepted types in `Part.data`. A `Part` must have a fixed IANA MIME type identifying the type and subtype of the media if the `inline_data` field is filled with raw bytes.", "properties": { - "done": { - "description": "If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available.", - "type": "boolean" + "inlineData": { + "description": "Inline media bytes.", + "$ref": "#/components/schemas/Blob" }, - "name": { - "description": "The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`.", + "text": { + "description": "Inline text.", "type": "string" }, - "error": { - "description": "The error result of the operation in case of failure or cancellation.", - "$ref": "#/components/schemas/Status" - }, - "response": { - "description": "The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.", + "partMetadata": { + "description": "Custom metadata associated with the Part. Agents using genai.Part as content representation may need to keep track of the additional information. For example it can be name of a file/source from which the Part originates or a way to multiplex multiple Part streams.", "type": "object", "additionalProperties": { - "description": "Properties of the object. Contains field @type with type URL." + "description": "Properties of the object." } }, - "metadata": { - "description": "Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any.", - "type": "object", - "additionalProperties": { - "description": "Properties of the object. Contains field @type with type URL." - } - } - } - }, - "PrebuiltVoiceConfig": { - "type": "object", - "description": "The configuration for the prebuilt speaker to use.", - "properties": { - "voiceName": { + "functionCall": { + "$ref": "#/components/schemas/FunctionCall", + "description": "A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values." + }, + "videoMetadata": { + "description": "Optional. Video metadata. The metadata should only be specified while the video data is presented in inline_data or file_data.", + "$ref": "#/components/schemas/VideoMetadata" + }, + "thought": { + "description": "Optional. Indicates if the part is thought from the model.", + "type": "boolean" + }, + "toolCall": { + "description": "Server-side tool call. This field is populated when the model predicts a tool invocation that should be executed on the server. The client is expected to echo this message back to the API.", + "$ref": "#/components/schemas/ToolCall" + }, + "fileData": { + "description": "URI based data.", + "$ref": "#/components/schemas/FileData" + }, + "executableCode": { + "description": "Code generated by the model that is meant to be executed.", + "$ref": "#/components/schemas/ExecutableCode" + }, + "mediaResolution": { + "$ref": "#/components/schemas/MediaResolution", + "description": "Optional. Media resolution for the input media." + }, + "codeExecutionResult": { + "description": "Result of executing the `ExecutableCode`.", + "$ref": "#/components/schemas/CodeExecutionResult" + }, + "toolResponse": { + "$ref": "#/components/schemas/ToolResponse", + "description": "The output from a server-side `ToolCall` execution. This field is populated by the client with the results of executing the corresponding `ToolCall`." + }, + "functionResponse": { + "description": "The result output of a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model.", + "$ref": "#/components/schemas/FunctionResponse" + }, + "thoughtSignature": { + "description": "Optional. An opaque signature for the thought so it can be reused in subsequent requests.", "type": "string", - "description": "The name of the preset voice to use." + "format": "byte" } } }, - "UrlContextMetadata": { + "Permission": { "type": "object", - "description": "Metadata related to url context retrieval tool.", - "properties": { - "urlMetadata": { - "type": "array", - "items": { - "$ref": "#/components/schemas/UrlMetadata" - }, - "description": "List of url context." - } - } - }, - "Corpus": { - "description": "A `Corpus` is a collection of `Document`s. A project can create up to 10 corpora.", "properties": { - "name": { - "description": "Output only. Immutable. Identifier. The `Corpus` resource name. The ID (name excluding the \"corpora/\" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `corpora/my-awesome-corpora-123a456b789c`", - "readOnly": true, - "type": "string" - }, - "displayName": { + "granteeType": { "type": "string", - "description": "Optional. The human-readable display name for the `Corpus`. The display name must be no more than 512 characters in length, including spaces. Example: \"Docs on Semantic Retriever\"" + "x-enum-descriptions": [ + "The default value. This value is unused.", + "Represents a user. When set, you must provide email_address for the user.", + "Represents a group. When set, you must provide email_address for the group.", + "Represents access to everyone. No extra information is required." + ], + "enum": [ + "GRANTEE_TYPE_UNSPECIFIED", + "USER", + "GROUP", + "EVERYONE" + ], + "description": "Optional. Immutable. The type of the grantee." }, - "updateTime": { - "readOnly": true, + "emailAddress": { "type": "string", - "format": "google-datetime", - "description": "Output only. The Timestamp of when the `Corpus` was last updated." + "description": "Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE." }, - "createTime": { - "description": "Output only. The Timestamp of when the `Corpus` was created.", + "name": { "readOnly": true, + "description": "Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.", + "type": "string" + }, + "role": { "type": "string", - "format": "google-datetime" + "x-enum-descriptions": [ + "The default value. This value is unused.", + "Owner can use, update, share and delete the resource.", + "Writer can use, update and share the resource.", + "Reader can use the resource." + ], + "enum": [ + "ROLE_UNSPECIFIED", + "OWNER", + "WRITER", + "READER" + ], + "description": "Required. The role granted by this permission." } }, - "type": "object" + "description": "Permission resource grants user, group or the rest of the world access to the PaLM API resource (e.g. a tuned model, corpus). A role is a collection of permitted operations that allows users to perform specific actions on PaLM API resources. To make them available to users, groups, or service accounts, you assign roles. When you assign a role, you grant permissions that the role contains. There are three concentric roles. Each role is a superset of the previous role's permitted operations: - reader can use the resource (e.g. tuned model, corpus) for inference - writer has reader's permissions and additionally can edit and share - owner has writer's permissions and additionally can delete" }, - "TransferOwnershipRequest": { + "CodeExecution": { + "type": "object", + "properties": {}, + "description": "Tool that executes code generated by the model, and automatically returns the result to the model. See also `ExecutableCode` and `CodeExecutionResult` which are only generated when using this tool." + }, + "SpeechConfig": { "type": "object", - "description": "Request to transfer the ownership of the tuned model.", "properties": { - "emailAddress": { - "type": "string", - "description": "Required. The email address of the user to whom the tuned model is being transferred to." + "voiceConfig": { + "description": "The configuration in case of single-voice output.", + "$ref": "#/components/schemas/VoiceConfig" + }, + "multiSpeakerVoiceConfig": { + "$ref": "#/components/schemas/MultiSpeakerVoiceConfig", + "description": "Optional. The configuration for the multi-speaker setup. It is mutually exclusive with the voice_config field." + }, + "languageCode": { + "description": "Optional. The IETF [BCP-47](https://www.rfc-editor.org/rfc/bcp/bcp47.txt) language code that the user configured the app to use. Used for speech recognition and synthesis. Valid values are: `de-DE`, `en-AU`, `en-GB`, `en-IN`, `en-US`, `es-US`, `fr-FR`, `hi-IN`, `pt-BR`, `ar-XA`, `es-ES`, `fr-CA`, `id-ID`, `it-IT`, `ja-JP`, `tr-TR`, `vi-VN`, `bn-IN`, `gu-IN`, `kn-IN`, `ml-IN`, `mr-IN`, `ta-IN`, `te-IN`, `nl-NL`, `ko-KR`, `cmn-CN`, `pl-PL`, `ru-RU`, and `th-TH`.", + "type": "string" } - } + }, + "description": "Config for speech generation and transcription." }, - "TunedModel": { - "type": "object", - "description": "A fine-tuned model created using ModelService.CreateTunedModel.", + "File": { + "description": "A file uploaded to the API. Next ID: 15", "properties": { - "tunedModelSource": { - "description": "Optional. TunedModel to use as the starting point for training the new model.", - "$ref": "#/components/schemas/TunedModelSource" + "expirationTime": { + "type": "string", + "format": "google-datetime", + "description": "Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.", + "readOnly": true }, - "baseModel": { + "createTime": { "type": "string", - "description": "Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001`" + "format": "google-datetime", + "description": "Output only. The timestamp of when the `File` was created.", + "readOnly": true }, - "description": { + "downloadUri": { "type": "string", - "description": "Optional. A short description of this model." + "readOnly": true, + "description": "Output only. The download uri of the `File`." }, - "readerProjectNumbers": { - "description": "Optional. List of project numbers that have read access to the tuned model.", - "type": "array", - "items": { - "format": "int64", - "type": "string" - } + "error": { + "readOnly": true, + "$ref": "#/components/schemas/Status", + "description": "Output only. Error status if File processing failed." }, - "temperature": { - "type": "number", - "format": "float", - "description": "Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model." + "name": { + "description": "Immutable. Identifier. The `File` resource name. The ID (name excluding the \"files/\" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be generated. Example: `files/123-456`", + "type": "string" }, - "topP": { - "description": "Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model.", - "type": "number", - "format": "float" + "displayName": { + "type": "string", + "description": "Optional. The human-readable display name for the `File`. The display name must be no more than 512 characters in length, including spaces. Example: \"Welcome Image\"" + }, + "sha256Hash": { + "type": "string", + "format": "byte", + "readOnly": true, + "description": "Output only. SHA-256 hash of the uploaded bytes." + }, + "mimeType": { + "type": "string", + "readOnly": true, + "description": "Output only. MIME type of the file." }, "state": { + "x-enum-descriptions": [ + "The default value. This value is used if the state is omitted.", + "File is being processed and cannot be used for inference yet.", + "File is processed and available for inference.", + "File failed processing." + ], "enum": [ "STATE_UNSPECIFIED", - "CREATING", + "PROCESSING", "ACTIVE", "FAILED" ], - "readOnly": true, - "x-enum-descriptions": [ - "The default value. This value is unused.", - "The model is being created.", - "The model is ready to be used.", - "The model failed to be created." - ], - "description": "Output only. The state of the tuned model.", - "type": "string" - }, - "tuningTask": { - "description": "Required. The tuning task that creates the tuned model.", - "$ref": "#/components/schemas/TuningTask" - }, - "topK": { - "description": "Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model.", - "type": "integer", - "format": "int32" + "description": "Output only. Processing state of the File.", + "type": "string", + "readOnly": true }, "updateTime": { + "type": "string", "format": "google-datetime", + "description": "Output only. The timestamp of when the `File` was last updated.", + "readOnly": true + }, + "sizeBytes": { "readOnly": true, + "description": "Output only. Size of the file in bytes.", "type": "string", - "description": "Output only. The timestamp when this model was updated." + "format": "int64" }, - "createTime": { - "description": "Output only. The timestamp when this model was created.", - "readOnly": true, + "source": { + "description": "Source of the File.", "type": "string", - "format": "google-datetime" + "x-enum-descriptions": [ + "Used if source is not specified.", + "Indicates the file is uploaded by the user.", + "Indicates the file is generated by Google.", + "Indicates the file is a registered, i.e. a Google Cloud Storage file." + ], + "enum": [ + "SOURCE_UNSPECIFIED", + "UPLOADED", + "GENERATED", + "REGISTERED" + ] }, - "name": { + "videoMetadata": { + "description": "Output only. Metadata for a video.", "readOnly": true, - "type": "string", - "description": "Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`" + "$ref": "#/components/schemas/VideoFileMetadata" }, - "displayName": { + "uri": { "type": "string", - "description": "Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces." - } - } - }, - "RetrievalMetadata": { - "type": "object", - "description": "Metadata related to retrieval in the grounding flow.", - "properties": { - "googleSearchDynamicRetrievalScore": { - "description": "Optional. Score indicating how likely information from google search could help answer the prompt. The score is in the range [0, 1], where 0 is the least likely and 1 is the most likely. This score is only populated when google search grounding and dynamic retrieval is enabled. It will be compared to the threshold to determine whether to trigger google search.", - "format": "float", - "type": "number" - } - } - }, - "InlinedRequests": { - "description": "The requests to be processed in the batch if provided as part of the batch creation request.", - "properties": { - "requests": { - "type": "array", - "items": { - "$ref": "#/components/schemas/InlinedRequest" - }, - "description": "Required. The requests to be processed in the batch." - } - }, - "type": "object" - }, - "CreateFileRequest": { - "description": "Request for `CreateFile`.", - "properties": { - "file": { - "$ref": "#/components/schemas/File", - "description": "Optional. Metadata for the file to create." + "readOnly": true, + "description": "Output only. The uri of the `File`." } }, "type": "object" }, - "TuningExample": { - "type": "object", - "description": "A single example for tuning.", + "CachedContent": { "properties": { - "output": { + "expireTime": { "type": "string", - "description": "Required. The expected model output." + "format": "google-datetime", + "description": "Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input." }, - "textInput": { - "type": "string", - "description": "Optional. Text model input." - } - } - }, - "FileSearchStore": { - "type": "object", - "description": "A `FileSearchStore` is a collection of `Document`s.", - "properties": { - "failedDocumentsCount": { - "format": "int64", - "readOnly": true, + "ttl": { "type": "string", - "description": "Output only. The number of documents in the `FileSearchStore` that have failed processing." + "format": "google-duration", + "description": "Input only. New TTL for this resource, input only." }, - "activeDocumentsCount": { - "description": "Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.", - "format": "int64", - "readOnly": true, - "type": "string" + "toolConfig": { + "$ref": "#/components/schemas/ToolConfig", + "description": "Optional. Input only. Immutable. Tool config. This config is shared for all tools." + }, + "systemInstruction": { + "description": "Optional. Input only. Immutable. Developer set system instruction. Currently text only.", + "$ref": "#/components/schemas/Content" }, "updateTime": { + "description": "Output only. When the cache entry was last updated in UTC time.", "readOnly": true, "type": "string", - "format": "google-datetime", - "description": "Output only. The Timestamp of when the `FileSearchStore` was last updated." + "format": "google-datetime" }, - "sizeBytes": { - "description": "Output only. The size of raw bytes ingested into the `FileSearchStore`. This is the total size of all the documents in the `FileSearchStore`.", - "readOnly": true, - "type": "string", - "format": "int64" + "tools": { + "description": "Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response", + "type": "array", + "items": { + "$ref": "#/components/schemas/Tool" + } }, "createTime": { - "format": "google-datetime", - "readOnly": true, "type": "string", - "description": "Output only. The Timestamp of when the `FileSearchStore` was created." - }, - "name": { + "format": "google-datetime", "readOnly": true, - "type": "string", - "description": "Output only. Immutable. Identifier. The `FileSearchStore` resource name. It is an ID (name excluding the \"fileSearchStores/\" prefix) that can contain up to 40 characters that are lowercase alphanumeric or dashes (-). It is output only. The unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/my-awesome-file-search-store-123a456b789c` If `display_name` is not provided, the name will be randomly generated." + "description": "Output only. Creation time of the cache entry." }, - "displayName": { - "type": "string", - "description": "Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: \"Docs on Semantic Retriever\"" + "contents": { + "description": "Optional. Input only. Immutable. The content to cache.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Content" + } }, - "pendingDocumentsCount": { - "format": "int64", + "usageMetadata": { "readOnly": true, - "type": "string", - "description": "Output only. The number of documents in the `FileSearchStore` that are being processed." - } - } - }, - "CodeExecutionResult": { - "description": "Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used.", - "properties": { - "outcome": { - "description": "Required. Outcome of the code execution.", - "enum": [ - "OUTCOME_UNSPECIFIED", - "OUTCOME_OK", - "OUTCOME_FAILED", - "OUTCOME_DEADLINE_EXCEEDED" - ], - "type": "string", - "x-enum-descriptions": [ - "Unspecified status. This value should not be used.", - "Code execution completed successfully. `output` contains the stdout, if any.", - "Code execution failed. `output` contains the stderr and stdout, if any.", - "Code execution ran for too long, and was cancelled. There may or may not be a partial `output` present." - ] + "$ref": "#/components/schemas/CachedContentUsageMetadata", + "description": "Output only. Metadata on the usage of the cached content." }, - "id": { + "name": { "type": "string", - "description": "Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id." + "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`", + "readOnly": true }, - "output": { + "model": { "type": "string", - "description": "Optional. Contains stdout when code execution is successful, stderr or other description otherwise." + "description": "Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}`" + }, + "displayName": { + "description": "Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters.", + "type": "string" } }, + "description": "Content that has been preprocessed and can be used in subsequent request to GenerativeService. Cached content can be only used with model it was created for.", "type": "object" }, - "ImageSearch": { - "description": "Image search for grounding and related configurations.", - "properties": {}, - "type": "object" - }, - "ContentEmbedding": { + "TuningTask": { "type": "object", - "description": "A list of floats representing an embedding.", + "description": "Tuning tasks that create tuned models.", "properties": { - "values": { - "type": "array", - "items": { - "type": "number", - "format": "float" - }, - "description": "The embedding values. This is for 3P users only and will not be populated for 1P calls." + "startTime": { + "readOnly": true, + "description": "Output only. The timestamp when tuning this model started.", + "type": "string", + "format": "google-datetime" }, - "shape": { - "description": "This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048]).", + "snapshots": { + "description": "Output only. Metrics collected during tuning.", + "readOnly": true, "type": "array", "items": { - "type": "integer", - "format": "int32" + "$ref": "#/components/schemas/TuningSnapshot" } + }, + "hyperparameters": { + "description": "Immutable. Hyperparameters controlling the tuning process. If not provided, default values will be used.", + "$ref": "#/components/schemas/Hyperparameters" + }, + "completeTime": { + "readOnly": true, + "description": "Output only. The timestamp when tuning this model completed.", + "type": "string", + "format": "google-datetime" + }, + "trainingData": { + "$ref": "#/components/schemas/Dataset", + "description": "Required. Input only. Immutable. The model training data." } } }, "Status": { + "type": "object", "description": "The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors).", "properties": { - "message": { - "type": "string", - "description": "A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client." - }, "details": { + "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use.", "type": "array", "items": { "type": "object", "additionalProperties": { "description": "Properties of the object. Contains field @type with type URL." } - }, - "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use." + } }, "code": { "type": "integer", "format": "int32", "description": "The status code, which should be an enum value of google.rpc.Code." - } - }, - "type": "object" - }, - "FileData": { - "description": "URI based data.", - "properties": { - "fileUri": { - "type": "string", - "description": "Required. URI." }, - "mimeType": { - "description": "Optional. The IANA standard MIME type of the source data.", + "message": { + "description": "A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client.", "type": "string" } - }, - "type": "object" + } }, - "LogprobsResult": { - "type": "object", - "description": "Logprobs Result", + "ReviewSnippet": { "properties": { - "logProbabilitySum": { - "type": "number", - "format": "float", - "description": "Sum of log probabilities for all tokens." + "title": { + "description": "Title of the review.", + "type": "string" }, - "chosenCandidates": { - "description": "Length = total number of decoding steps. The chosen candidates may or may not be in top_candidates.", - "type": "array", - "items": { - "$ref": "#/components/schemas/LogprobsResultCandidate" - } + "googleMapsUri": { + "description": "A link that corresponds to the user review on Google Maps.", + "type": "string" }, - "topCandidates": { - "description": "Length = total number of decoding steps.", - "type": "array", - "items": { - "$ref": "#/components/schemas/TopCandidates" - } - } - } - }, - "InlinedEmbedContentResponses": { - "type": "object", - "description": "The responses to the requests in the batch.", - "properties": { - "inlinedResponses": { - "description": "Output only. The responses to the requests in the batch.", - "readOnly": true, - "type": "array", - "items": { - "$ref": "#/components/schemas/InlinedEmbedContentResponse" - } - } - } - }, - "ChunkingConfig": { - "type": "object", - "description": "Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto", - "properties": { - "whiteSpaceConfig": { - "$ref": "#/components/schemas/WhiteSpaceConfig", - "description": "White space chunking configuration." + "reviewId": { + "type": "string", + "description": "The ID of the review snippet." } - } + }, + "description": "Encapsulates a snippet of a user review that answers a question about the features of a specific place in Google Maps.", + "type": "object" }, - "GroundingChunkStringList": { + "BatchEmbedContentsRequest": { "type": "object", - "description": "A list of string values.", "properties": { - "values": { + "requests": { "type": "array", "items": { - "type": "string" + "$ref": "#/components/schemas/EmbedContentRequest" }, - "description": "The string values of the list." + "description": "Required. Embed requests for the batch. The model in each of these requests must match the model specified `BatchEmbedContentsRequest.model`." } - } + }, + "description": "Batch request to get embeddings from the model for a list of prompts." }, - "SafetyRating": { - "type": "object", - "description": "Safety rating for a piece of content. The safety rating contains the category of harm and the harm probability level in that category for a piece of content. Content is classified for safety across a number of harm categories and the probability of the harm classification is included here.", + "FunctionCall": { + "description": "A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values.", "properties": { - "probability": { - "description": "Required. The probability of harm for this content.", - "enum": [ - "HARM_PROBABILITY_UNSPECIFIED", - "NEGLIGIBLE", - "LOW", - "MEDIUM", - "HIGH" - ], - "type": "string", - "x-enum-descriptions": [ - "Probability is unspecified.", - "Content has a negligible chance of being unsafe.", - "Content has a low chance of being unsafe.", - "Content has a medium chance of being unsafe.", - "Content has a high chance of being unsafe." - ] - }, - "category": { - "x-enum-descriptions": [ - "Category is unspecified.", - "**PaLM** - Negative or harmful comments targeting identity and/or protected attribute.", - "**PaLM** - Content that is rude, disrespectful, or profane.", - "**PaLM** - Describes scenarios depicting violence against an individual or group, or general descriptions of gore.", - "**PaLM** - Contains references to sexual acts or other lewd content.", - "**PaLM** - Promotes unchecked medical advice.", - "**PaLM** - Dangerous content that promotes, facilitates, or encourages harmful acts.", - "**Gemini** - Harassment content.", - "**Gemini** - Hate speech and content.", - "**Gemini** - Sexually explicit content.", - "**Gemini** - Dangerous content.", - "**Gemini** - Content that may be used to harm civic integrity. DEPRECATED: use enable_enhanced_civic_answers instead." - ], - "enum": [ - "HARM_CATEGORY_UNSPECIFIED", - "HARM_CATEGORY_DEROGATORY", - "HARM_CATEGORY_TOXICITY", - "HARM_CATEGORY_VIOLENCE", - "HARM_CATEGORY_SEXUAL", - "HARM_CATEGORY_MEDICAL", - "HARM_CATEGORY_DANGEROUS", - "HARM_CATEGORY_HARASSMENT", - "HARM_CATEGORY_HATE_SPEECH", - "HARM_CATEGORY_SEXUALLY_EXPLICIT", - "HARM_CATEGORY_DANGEROUS_CONTENT", - "HARM_CATEGORY_CIVIC_INTEGRITY" - ], - "description": "Required. The category for this rating.", + "name": { "type": "string", - "enumDeprecated": [ - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - true - ] - }, - "blocked": { - "type": "boolean", - "description": "Was this content blocked because of this rating?" - } - } - }, - "Hyperparameters": { - "description": "Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance", - "properties": { - "learningRate": { - "format": "float", - "type": "number", - "description": "Optional. Immutable. The learning rate hyperparameter for tuning. If not set, a default of 0.001 or 0.0002 will be calculated based on the number of training examples." - }, - "learningRateMultiplier": { - "type": "number", - "format": "float", - "description": "Optional. Immutable. The learning rate multiplier is used to calculate a final learning_rate based on the default (recommended) value. Actual learning rate := learning_rate_multiplier * default learning rate Default learning rate is dependent on base model and dataset size. If not set, a default of 1.0 will be used." + "description": "Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128." }, - "epochCount": { - "description": "Immutable. The number of training epochs. An epoch is one pass through the training data. If not set, a default of 5 will be used.", - "type": "integer", - "format": "int32" + "id": { + "description": "Optional. Unique identifier of the function call. If populated, the client to execute the `function_call` and return the response with the matching `id`.", + "type": "string" }, - "batchSize": { - "format": "int32", - "type": "integer", - "description": "Immutable. The batch size hyperparameter for tuning. If not set, a default of 4 or 16 will be used based on the number of training examples." + "args": { + "type": "object", + "additionalProperties": { + "description": "Properties of the object." + }, + "description": "Optional. The function parameters and values in JSON object format." } }, "type": "object" }, - "StreamableHttpTransport": { - "description": "A transport that can stream HTTP requests and responses. Next ID: 6", + "ContentEmbedding": { + "type": "object", + "description": "A list of floats representing an embedding.", "properties": { - "url": { - "description": "The full URL for the MCPServer endpoint. Example: \"https://api.example.com/mcp\"", - "type": "string" - }, - "terminateOnClose": { - "description": "Whether to close the client session when the transport closes.", - "type": "boolean" - }, - "timeout": { - "description": "HTTP timeout for regular operations.", - "type": "string", - "format": "google-duration" - }, - "headers": { - "description": "Optional: Fields for authentication headers, timeouts, etc., if needed.", - "type": "object", - "additionalProperties": { - "type": "string" + "values": { + "description": "The embedding values. This is for 3P users only and will not be populated for 1P calls.", + "type": "array", + "items": { + "type": "number", + "format": "float" } }, - "sseReadTimeout": { - "type": "string", - "format": "google-duration", - "description": "Timeout for SSE read operations." + "shape": { + "type": "array", + "items": { + "type": "integer", + "format": "int32" + }, + "description": "This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048])." } - }, - "type": "object" + } }, - "ToolConfig": { - "description": "The Tool configuration containing parameters for specifying `Tool` use in the request.", + "EmbedContentResponse": { + "type": "object", + "description": "The response to an `EmbedContentRequest`.", "properties": { - "includeServerSideToolInvocations": { - "description": "Optional. If true, the API response will include the server-side tool calls and responses within the `Content` message. This allows clients to observe the server's tool interactions.", - "type": "boolean" - }, - "functionCallingConfig": { - "description": "Optional. Function calling config.", - "$ref": "#/components/schemas/FunctionCallingConfig" + "embedding": { + "readOnly": true, + "$ref": "#/components/schemas/ContentEmbedding", + "description": "Output only. The embedding generated from the input content." }, - "retrievalConfig": { - "$ref": "#/components/schemas/RetrievalConfig", - "description": "Optional. Retrieval config." + "usageMetadata": { + "description": "Output only. The usage metadata for the request.", + "readOnly": true, + "$ref": "#/components/schemas/EmbeddingUsageMetadata" } - }, - "type": "object" + } }, - "Content": { - "description": "The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn.", + "ImportFileRequest": { "properties": { - "parts": { - "description": "Ordered `Parts` that constitute a single message. Parts may have different MIME types.", + "chunkingConfig": { + "$ref": "#/components/schemas/ChunkingConfig", + "description": "Optional. Config for telling the service how to chunk the file. If not provided, the service will use default parameters." + }, + "fileName": { + "description": "Required. The name of the `File` to import. Example: `files/abc-123`", + "type": "string" + }, + "customMetadata": { + "description": "Custom metadata to be associated with the file.", "type": "array", "items": { - "$ref": "#/components/schemas/Part" + "$ref": "#/components/schemas/CustomMetadata" } - }, - "role": { - "description": "Optional. The producer of the content. Must be either 'user' or 'model'. Useful to set for multi-turn conversations, otherwise can be left blank or unset.", - "type": "string" } }, + "description": "Request for `ImportFile` to import a File API file with a `FileSearchStore`.", "type": "object" }, "McpServer": { "type": "object", - "description": "A MCPServer is a server that can be called by the model to perform actions. It is a server that implements the MCP protocol. Next ID: 5", "properties": { "streamableHttpTransport": { "description": "A transport that can stream HTTP requests and responses.", "$ref": "#/components/schemas/StreamableHttpTransport" }, "name": { + "description": "The name of the MCPServer.", + "type": "string" + } + }, + "description": "A MCPServer is a server that can be called by the model to perform actions. It is a server that implements the MCP protocol. Next ID: 5" + }, + "UrlMetadata": { + "type": "object", + "properties": { + "retrievedUrl": { + "description": "Retrieved url by the tool.", + "type": "string" + }, + "urlRetrievalStatus": { "type": "string", - "description": "The name of the MCPServer." + "x-enum-descriptions": [ + "Default value. This value is unused.", + "Url retrieval is successful.", + "Url retrieval is failed due to error.", + "Url retrieval is failed because the content is behind paywall.", + "Url retrieval is failed because the content is unsafe." + ], + "enum": [ + "URL_RETRIEVAL_STATUS_UNSPECIFIED", + "URL_RETRIEVAL_STATUS_SUCCESS", + "URL_RETRIEVAL_STATUS_ERROR", + "URL_RETRIEVAL_STATUS_PAYWALL", + "URL_RETRIEVAL_STATUS_UNSAFE" + ], + "description": "Status of the url retrieval." + } + }, + "description": "Context of the a single url retrieval." + }, + "SearchTypes": { + "type": "object", + "description": "Different types of search that can be enabled on the GoogleSearch tool.", + "properties": { + "webSearch": { + "$ref": "#/components/schemas/WebSearch", + "description": "Optional. Enables web search. Only text results are returned." + }, + "imageSearch": { + "description": "Optional. Enables image search. Image bytes are returned.", + "$ref": "#/components/schemas/ImageSearch" } } }, - "InputConfig": { - "description": "Configures the input to the batch request.", + "ImageSearch": { + "type": "object", + "description": "Image search for grounding and related configurations.", + "properties": {} + }, + "BatchStats": { + "type": "object", + "description": "Stats about the batch.", "properties": { - "requests": { - "$ref": "#/components/schemas/InlinedRequests", - "description": "The requests to be processed in the batch." + "requestCount": { + "readOnly": true, + "description": "Output only. The number of requests in the batch.", + "type": "string", + "format": "int64" }, - "fileName": { + "failedRequestCount": { "type": "string", - "description": "The name of the `File` containing the input requests." + "format": "int64", + "description": "Output only. The number of requests that failed to be processed.", + "readOnly": true + }, + "pendingRequestCount": { + "description": "Output only. The number of requests that are still pending processing.", + "readOnly": true, + "type": "string", + "format": "int64" + }, + "successfulRequestCount": { + "type": "string", + "format": "int64", + "description": "Output only. The number of requests that were successfully processed.", + "readOnly": true } - }, - "type": "object" + } }, - "GroundingPassageId": { - "description": "Identifier for a part within a `GroundingPassage`.", + "TunedModel": { "properties": { - "partIndex": { - "description": "Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`.", - "format": "int32", + "readerProjectNumbers": { + "type": "array", + "items": { + "type": "string", + "format": "int64" + }, + "description": "Optional. List of project numbers that have read access to the tuned model." + }, + "tuningTask": { + "description": "Required. The tuning task that creates the tuned model.", + "$ref": "#/components/schemas/TuningTask" + }, + "updateTime": { + "type": "string", + "format": "google-datetime", "readOnly": true, - "type": "integer" + "description": "Output only. The timestamp when this model was updated." }, - "passageId": { + "tunedModelSource": { + "$ref": "#/components/schemas/TunedModelSource", + "description": "Optional. TunedModel to use as the starting point for training the new model." + }, + "state": { "readOnly": true, "type": "string", - "description": "Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`." + "description": "Output only. The state of the tuned model.", + "x-enum-descriptions": [ + "The default value. This value is unused.", + "The model is being created.", + "The model is ready to be used.", + "The model failed to be created." + ], + "enum": [ + "STATE_UNSPECIFIED", + "CREATING", + "ACTIVE", + "FAILED" + ] + }, + "baseModel": { + "description": "Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001`", + "type": "string" + }, + "description": { + "type": "string", + "description": "Optional. A short description of this model." + }, + "name": { + "description": "Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`", + "readOnly": true, + "type": "string" + }, + "topP": { + "description": "Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model.", + "type": "number", + "format": "float" + }, + "displayName": { + "description": "Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces.", + "type": "string" + }, + "topK": { + "description": "Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model.", + "type": "integer", + "format": "int32" + }, + "createTime": { + "description": "Output only. The timestamp when this model was created.", + "readOnly": true, + "type": "string", + "format": "google-datetime" + }, + "temperature": { + "type": "number", + "format": "float", + "description": "Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model." } }, + "description": "A fine-tuned model created using ModelService.CreateTunedModel.", "type": "object" }, - "CachedContentUsageMetadata": { - "type": "object", - "description": "Metadata on the usage of the cached content.", + "DynamicRetrievalConfig": { + "description": "Describes the options to customize dynamic retrieval.", "properties": { - "totalTokenCount": { - "format": "int32", - "type": "integer", - "description": "Total number of tokens that the cached content consumes." + "mode": { + "description": "The mode of the predictor to be used in dynamic retrieval.", + "type": "string", + "x-enum-descriptions": [ + "Always trigger retrieval.", + "Run retrieval only when system decides it is necessary." + ], + "enum": [ + "MODE_UNSPECIFIED", + "MODE_DYNAMIC" + ] + }, + "dynamicThreshold": { + "description": "The threshold to be used in dynamic retrieval. If not set, a system default value is used.", + "type": "number", + "format": "float" } - } + }, + "type": "object" }, - "TuningExamples": { - "description": "A set of tuning examples. Can be training or validation data.", + "ListTunedModelsResponse": { + "description": "Response from `ListTunedModels` containing a paginated list of Models.", "properties": { - "examples": { - "description": "The examples. Example input can be for text or discuss, but all examples in a set must be of the same type.", + "tunedModels": { "type": "array", "items": { - "$ref": "#/components/schemas/TuningExample" - } + "$ref": "#/components/schemas/TunedModel" + }, + "description": "The returned Models." + }, + "nextPageToken": { + "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", + "type": "string" } }, "type": "object" }, - "CitationSource": { + "ModelStatus": { "type": "object", - "description": "A citation to a source for a portion of a specific response.", + "description": "The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable.", "properties": { - "startIndex": { - "description": "Optional. Start of segment of the response that is attributed to this source. Index indicates the start of the segment, measured in bytes.", - "format": "int32", - "type": "integer" - }, - "endIndex": { - "description": "Optional. End of the attributed segment, exclusive.", - "format": "int32", - "type": "integer" + "modelStage": { + "type": "string", + "x-enum-descriptions": [ + "Unspecified model stage.", + "The underlying model is subject to lots of tunings.", + "Models in this stage are for experimental purposes only.", + "Models in this stage are more mature than experimental models.", + "Models in this stage are considered stable and ready for production use.", + "If the model is on this stage, it means that this model is on the path to deprecation in near future. Only existing customers can use this model.", + "Models in this stage are deprecated. These models cannot be used.", + "Models in this stage are retired. These models cannot be used." + ], + "enum": [ + "MODEL_STAGE_UNSPECIFIED", + "UNSTABLE_EXPERIMENTAL", + "EXPERIMENTAL", + "PREVIEW", + "STABLE", + "LEGACY", + "DEPRECATED", + "RETIRED" + ], + "description": "The stage of the underlying model.", + "enumDeprecated": [ + false, + true, + false, + false, + false, + false, + true, + false + ] }, - "uri": { - "description": "Optional. URI that is attributed as a source for a portion of the text.", + "message": { + "description": "A message explaining the model status.", "type": "string" }, - "license": { + "retirementTime": { + "description": "The time at which the model will be retired.", "type": "string", - "description": "Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations." + "format": "google-datetime" } } }, - "FunctionResponse": { - "type": "object", - "description": "The result output from a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model. This should contain the result of a`FunctionCall` made based on model prediction.", + "ToolResponse": { + "description": "The output from a server-side `ToolCall` execution. This message contains the results of a tool invocation that was initiated by a `ToolCall` from the model. The client should pass this `ToolResponse` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolCall`.", "properties": { - "willContinue": { - "description": "Optional. Signals that function call continues, and more responses will be returned, turning the function call into a generator. Is only applicable to NON_BLOCKING function calls, is ignored otherwise. If set to false, future responses will not be considered. It is allowed to return empty `response` with `will_continue=False` to signal that the function call is finished. This may still trigger the model generation. To avoid triggering the generation and finish the function call, additionally set `scheduling` to `SILENT`.", - "type": "boolean" - }, - "parts": { - "type": "array", - "items": { - "$ref": "#/components/schemas/FunctionResponsePart" - }, - "description": "Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types." + "id": { + "description": "Optional. The identifier of the tool call this response is for.", + "type": "string" }, "response": { - "description": "Required. The function response in JSON object format. Callers can use any keys of their choice that fit the function's syntax to return the function output, e.g. \"output\", \"result\", etc. In particular, if the function call failed to execute, the response can have an \"error\" key to return error details to the model.", + "description": "Optional. The tool response.", "type": "object", "additionalProperties": { "description": "Properties of the object." } }, - "id": { - "type": "string", - "description": "Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`." - }, - "name": { - "description": "Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128.", - "type": "string" - }, - "scheduling": { - "description": "Optional. Specifies how the response should be scheduled in the conversation. Only applicable to NON_BLOCKING function calls, is ignored otherwise. Defaults to WHEN_IDLE.", - "enum": [ - "SCHEDULING_UNSPECIFIED", - "SILENT", - "WHEN_IDLE", - "INTERRUPT" - ], - "type": "string", - "x-enum-descriptions": [ - "This value is unused.", - "Only add the result to the conversation context, do not interrupt or trigger generation.", - "Add the result to the conversation context, and prompt to generate output without interrupting ongoing generation.", - "Add the result to the conversation context, interrupt ongoing generation and prompt to generate output." - ] - } - } - }, - "SafetySetting": { - "type": "object", - "description": "Safety setting, affecting the safety-blocking behavior. Passing a safety setting for a category changes the allowed probability that content is blocked.", - "properties": { - "threshold": { + "toolType": { "type": "string", "x-enum-descriptions": [ - "Threshold is unspecified.", - "Content with NEGLIGIBLE will be allowed.", - "Content with NEGLIGIBLE and LOW will be allowed.", - "Content with NEGLIGIBLE, LOW, and MEDIUM will be allowed.", - "All content will be allowed.", - "Turn off the safety filter." - ], - "enum": [ - "HARM_BLOCK_THRESHOLD_UNSPECIFIED", - "BLOCK_LOW_AND_ABOVE", - "BLOCK_MEDIUM_AND_ABOVE", - "BLOCK_ONLY_HIGH", - "BLOCK_NONE", - "OFF" + "Unspecified tool type.", + "Google search tool, maps to Tool.google_search.search_types.web_search.", + "Image search tool, maps to Tool.google_search.search_types.image_search.", + "URL context tool, maps to Tool.url_context.", + "Google maps tool, maps to Tool.google_maps.", + "File search tool, maps to Tool.file_search." ], - "description": "Required. Controls the probability threshold at which harm is blocked." - }, - "category": { "enum": [ - "HARM_CATEGORY_UNSPECIFIED", - "HARM_CATEGORY_DEROGATORY", - "HARM_CATEGORY_TOXICITY", - "HARM_CATEGORY_VIOLENCE", - "HARM_CATEGORY_SEXUAL", - "HARM_CATEGORY_MEDICAL", - "HARM_CATEGORY_DANGEROUS", - "HARM_CATEGORY_HARASSMENT", - "HARM_CATEGORY_HATE_SPEECH", - "HARM_CATEGORY_SEXUALLY_EXPLICIT", - "HARM_CATEGORY_DANGEROUS_CONTENT", - "HARM_CATEGORY_CIVIC_INTEGRITY" - ], - "x-enum-descriptions": [ - "Category is unspecified.", - "**PaLM** - Negative or harmful comments targeting identity and/or protected attribute.", - "**PaLM** - Content that is rude, disrespectful, or profane.", - "**PaLM** - Describes scenarios depicting violence against an individual or group, or general descriptions of gore.", - "**PaLM** - Contains references to sexual acts or other lewd content.", - "**PaLM** - Promotes unchecked medical advice.", - "**PaLM** - Dangerous content that promotes, facilitates, or encourages harmful acts.", - "**Gemini** - Harassment content.", - "**Gemini** - Hate speech and content.", - "**Gemini** - Sexually explicit content.", - "**Gemini** - Dangerous content.", - "**Gemini** - Content that may be used to harm civic integrity. DEPRECATED: use enable_enhanced_civic_answers instead." - ], - "description": "Required. The category for this setting.", - "enumDeprecated": [ - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - true + "TOOL_TYPE_UNSPECIFIED", + "GOOGLE_SEARCH_WEB", + "GOOGLE_SEARCH_IMAGE", + "URL_CONTEXT", + "GOOGLE_MAPS", + "FILE_SEARCH" ], - "type": "string" + "description": "Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`." } - } + }, + "type": "object" }, "InlinedEmbedContentRequests": { - "type": "object", - "description": "The requests to be processed in the batch if provided as part of the batch creation request.", "properties": { "requests": { "type": "array", @@ -5047,1154 +4891,982 @@ }, "description": "Required. The requests to be processed in the batch." } - } - }, - "ExecutableCode": { - "type": "object", - "description": "Code generated by the model that is meant to be executed, and the result returned to the model. Only generated when using the `CodeExecution` tool, in which the code will be automatically executed, and a corresponding `CodeExecutionResult` will also be generated.", - "properties": { - "language": { - "description": "Required. Programming language of the `code`.", - "enum": [ - "LANGUAGE_UNSPECIFIED", - "PYTHON" - ], - "type": "string", - "x-enum-descriptions": [ - "Unspecified language. This value should not be used.", - "Python >= 3.10, with numpy and simpy available. Python is the default language." - ] - }, - "code": { - "type": "string", - "description": "Required. The code to be executed." - }, - "id": { - "type": "string", - "description": "Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`." - } - } + }, + "description": "The requests to be processed in the batch if provided as part of the batch creation request.", + "type": "object" }, - "VideoMetadata": { + "RetrievalConfig": { "type": "object", - "deprecated": true, - "description": "Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content.", "properties": { - "startOffset": { - "format": "google-duration", - "type": "string", - "description": "Optional. The start offset of the video." - }, - "endOffset": { - "format": "google-duration", - "type": "string", - "description": "Optional. The end offset of the video." + "latLng": { + "$ref": "#/components/schemas/LatLng", + "description": "Optional. The location of the user." }, - "fps": { - "description": "Optional. The frame rate of the video sent to the model. If not specified, the default value will be 1.0. The fps range is (0.0, 24.0].", - "format": "double", - "type": "number" - } - } - }, - "ComputerUse": { - "type": "object", - "description": "Computer Use tool type.", - "properties": { - "environment": { - "enum": [ - "ENVIRONMENT_UNSPECIFIED", - "ENVIRONMENT_BROWSER" - ], + "languageCode": { "type": "string", - "x-enum-descriptions": [ - "Defaults to browser.", - "Operates in a web browser." - ], - "description": "Required. The environment being operated." - }, - "excludedPredefinedFunctions": { - "type": "array", - "items": { - "type": "string" - }, - "description": "Optional. By default, predefined functions are included in the final model call. Some of them can be explicitly excluded from being automatically included. This can serve two purposes: 1. Using a more restricted / different action space. 2. Improving the definitions / instructions of predefined functions." - } - } - }, - "VoiceConfig": { - "description": "The configuration for the voice to use.", - "properties": { - "prebuiltVoiceConfig": { - "description": "The configuration for the prebuilt voice to use.", - "$ref": "#/components/schemas/PrebuiltVoiceConfig" + "description": "Optional. The language code of the user. Language code for content. Use language tags defined by [BCP47](https://www.rfc-editor.org/rfc/bcp/bcp47.txt)." } }, - "type": "object" + "description": "Retrieval config." }, - "ListCachedContentsResponse": { - "description": "Response with CachedContents list.", + "TopCandidates": { + "description": "Candidates with top log probabilities at each decoding step.", "properties": { - "nextPageToken": { - "type": "string", - "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages." - }, - "cachedContents": { + "candidates": { "type": "array", "items": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/LogprobsResultCandidate" }, - "description": "List of cached contents." + "description": "Sorted by log probability in descending order." } }, "type": "object" }, - "RegisterFilesRequest": { - "description": "Request for `RegisterFiles`.", + "TransferOwnershipRequest": { "properties": { - "uris": { - "description": "Required. The Google Cloud Storage URIs to register. Example: `gs://bucket/object`.", - "type": "array", - "items": { - "type": "string" - } + "emailAddress": { + "description": "Required. The email address of the user to whom the tuned model is being transferred to.", + "type": "string" } }, + "description": "Request to transfer the ownership of the tuned model.", "type": "object" }, - "InlinedResponse": { - "description": "The response to a single request in the batch.", + "CustomLongRunningOperation": { "properties": { "metadata": { - "description": "Output only. The metadata associated with the request.", - "readOnly": true, "type": "object", "additionalProperties": { - "description": "Properties of the object." + "description": "Properties of the object. Contains field @type with type URL." + }, + "description": "Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any." + }, + "name": { + "type": "string", + "description": "The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`." + }, + "response": { + "description": "The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.", + "type": "object", + "additionalProperties": { + "description": "Properties of the object. Contains field @type with type URL." } }, "error": { - "readOnly": true, "$ref": "#/components/schemas/Status", - "description": "Output only. The error encountered while processing the request." + "description": "The error result of the operation in case of failure or cancellation." }, - "response": { - "description": "Output only. The response to the request.", - "readOnly": true, - "$ref": "#/components/schemas/GenerateContentResponse" + "done": { + "description": "If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available.", + "type": "boolean" } }, "type": "object" }, - "ListDocumentsResponse": { - "description": "Response from `ListDocuments` containing a paginated list of `Document`s. The `Document`s are sorted by ascending `document.create_time`.", + "Blob": { + "description": "Raw media bytes. Text should not be sent as raw bytes, use the 'text' field.", "properties": { - "documents": { - "description": "The returned `Document`s.", - "type": "array", - "items": { - "$ref": "#/components/schemas/Document" - } + "mimeType": { + "type": "string", + "description": "The IANA standard MIME type of the source data. Examples: - image/png - image/jpeg If an unsupported MIME type is provided, an error will be returned. For a complete list of supported types, see [Supported file formats](https://ai.google.dev/gemini-api/docs/prompting_with_media#supported_file_formats)." }, - "nextPageToken": { - "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", - "type": "string" + "data": { + "type": "string", + "format": "byte", + "description": "Raw bytes for media formats." } }, "type": "object" }, - "WhiteSpaceConfig": { + "MultiSpeakerVoiceConfig": { "type": "object", - "description": "Configuration for a white space chunking algorithm [white space delimited].", + "description": "The configuration for the multi-speaker setup.", "properties": { - "maxTokensPerChunk": { - "type": "integer", - "format": "int32", - "description": "Maximum number of tokens per chunk. Tokens are defined as words for this chunking algorithm. Note: we are defining tokens as words split by whitespace as opposed to the output of a tokenizer. The context window of the latest gemini embedding model as of 2025-04-17 is currently 8192 tokens. We assume that the average word is 5 characters. Therefore, we set the upper limit to 2**9, which is 512 words, or 2560 tokens, assuming worst case a character per token. This is a conservative estimate meant to prevent context window overflow." - }, - "maxOverlapTokens": { - "type": "integer", - "format": "int32", - "description": "Maximum number of overlapping tokens between two adjacent chunks." + "speakerVoiceConfigs": { + "type": "array", + "items": { + "$ref": "#/components/schemas/SpeakerVoiceConfig" + }, + "description": "Required. All the enabled speaker voices." } } }, - "PlaceAnswerSources": { - "description": "Collection of sources that provide answers about the features of a given place in Google Maps. Each PlaceAnswerSources message corresponds to a specific place in Google Maps. The Google Maps tool used these sources in order to answer questions about features of the place (e.g: \"does Bar Foo have Wifi\" or \"is Foo Bar wheelchair accessible?\"). Currently we only support review snippets as sources.", + "CreateFileRequest": { + "description": "Request for `CreateFile`.", "properties": { - "reviewSnippets": { - "type": "array", - "items": { - "$ref": "#/components/schemas/ReviewSnippet" - }, - "description": "Snippets of reviews that are used to generate answers about the features of a given place in Google Maps." + "file": { + "description": "Optional. Metadata for the file to create.", + "$ref": "#/components/schemas/File" } }, "type": "object" }, - "Candidate": { - "description": "A response candidate generated from the model.", + "LogprobsResultCandidate": { "properties": { - "logprobsResult": { - "description": "Output only. Log-likelihood scores for the response tokens and top tokens", - "readOnly": true, - "$ref": "#/components/schemas/LogprobsResult" - }, - "citationMetadata": { - "readOnly": true, - "$ref": "#/components/schemas/CitationMetadata", - "description": "Output only. Citation information for model-generated candidate. This field may be populated with recitation information for any text included in the `content`. These are passages that are \"recited\" from copyrighted material in the foundational LLM's training data." + "logProbability": { + "type": "number", + "format": "float", + "description": "The candidate's log probability." }, - "tokenCount": { - "description": "Output only. Token count for this candidate.", - "readOnly": true, + "tokenId": { "type": "integer", - "format": "int32" - }, - "safetyRatings": { - "description": "List of ratings for the safety of a response candidate. There is at most one rating per category.", - "type": "array", - "items": { - "$ref": "#/components/schemas/SafetyRating" - } - }, - "urlContextMetadata": { - "readOnly": true, - "$ref": "#/components/schemas/UrlContextMetadata", - "description": "Output only. Metadata related to url context retrieval tool." - }, - "content": { - "description": "Output only. Generated content returned from the model.", - "readOnly": true, - "$ref": "#/components/schemas/Content" - }, - "finishReason": { - "readOnly": true, - "x-enum-descriptions": [ - "Default value. This value is unused.", - "Natural stop point of the model or provided stop sequence.", - "The maximum number of tokens as specified in the request was reached.", - "The response candidate content was flagged for safety reasons.", - "The response candidate content was flagged for recitation reasons.", - "The response candidate content was flagged for using an unsupported language.", - "Unknown reason.", - "Token generation stopped because the content contains forbidden terms.", - "Token generation stopped for potentially containing prohibited content.", - "Token generation stopped because the content potentially contains Sensitive Personally Identifiable Information (SPII).", - "The function call generated by the model is invalid.", - "Token generation stopped because generated images contain safety violations.", - "Image generation stopped because generated images has other prohibited content.", - "Image generation stopped because of other miscellaneous issue.", - "The model was expected to generate an image, but none was generated.", - "Image generation stopped due to recitation.", - "Model generated a tool call but no tools were enabled in the request.", - "Model called too many tools consecutively, thus the system exited execution.", - "Request has at least one thought signature missing.", - "Finished due to malformed response." - ], - "enum": [ - "FINISH_REASON_UNSPECIFIED", - "STOP", - "MAX_TOKENS", - "SAFETY", - "RECITATION", - "LANGUAGE", - "OTHER", - "BLOCKLIST", - "PROHIBITED_CONTENT", - "SPII", - "MALFORMED_FUNCTION_CALL", - "IMAGE_SAFETY", - "IMAGE_PROHIBITED_CONTENT", - "IMAGE_OTHER", - "NO_IMAGE", - "IMAGE_RECITATION", - "UNEXPECTED_TOOL_CALL", - "TOO_MANY_TOOL_CALLS", - "MISSING_THOUGHT_SIGNATURE", - "MALFORMED_RESPONSE" - ], - "description": "Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.", - "type": "string" - }, - "groundingMetadata": { - "description": "Output only. Grounding metadata for the candidate. This field is populated for `GenerateContent` calls.", - "readOnly": true, - "$ref": "#/components/schemas/GroundingMetadata" + "format": "int32", + "description": "The candidate\u2019s token id value." }, - "finishMessage": { - "description": "Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.", - "readOnly": true, + "token": { + "description": "The candidate\u2019s token string value.", "type": "string" - }, - "groundingAttributions": { - "description": "Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.", - "readOnly": true, - "type": "array", - "items": { - "$ref": "#/components/schemas/GroundingAttribution" - } - }, - "avgLogprobs": { - "format": "double", - "readOnly": true, - "type": "number", - "description": "Output only. Average log probability score of the candidate." - }, - "index": { - "format": "int32", - "readOnly": true, - "type": "integer", - "description": "Output only. Index of the candidate in the list of response candidates." } }, + "description": "Candidate for the logprobs token and score.", "type": "object" }, - "EmbedContentRequest": { - "type": "object", - "description": "Request containing the `Content` for the model to embed.", + "AsyncBatchEmbedContentRequest": { "properties": { - "taskType": { - "description": "Optional. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`).", - "enum": [ - "TASK_TYPE_UNSPECIFIED", - "RETRIEVAL_QUERY", - "RETRIEVAL_DOCUMENT", - "SEMANTIC_SIMILARITY", - "CLASSIFICATION", - "CLUSTERING", - "QUESTION_ANSWERING", - "FACT_VERIFICATION", - "CODE_RETRIEVAL_QUERY" - ], - "type": "string", - "x-enum-descriptions": [ - "Unset value, which will default to one of the other enum values.", - "Specifies the given text is a query in a search/retrieval setting.", - "Specifies the given text is a document from the corpus being searched.", - "Specifies the given text will be used for STS.", - "Specifies that the given text will be classified.", - "Specifies that the embeddings will be used for clustering.", - "Specifies that the given text will be used for question answering.", - "Specifies that the given text will be used for fact verification.", - "Specifies that the given text will be used for code retrieval." - ] - }, - "model": { - "type": "string", - "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`" - }, - "outputDimensionality": { - "format": "int32", - "type": "integer", - "description": "Optional. Optional reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. Supported by newer models since 2024 only. You cannot set this value if using the earlier model (`models/embedding-001`)." - }, - "content": { - "$ref": "#/components/schemas/Content", - "description": "Required. The content to embed. Only the `parts.text` fields will be counted." - }, - "title": { - "type": "string", - "description": "Optional. An optional title for the text. Only applicable when TaskType is `RETRIEVAL_DOCUMENT`. Note: Specifying a `title` for `RETRIEVAL_DOCUMENT` provides better quality embeddings for retrieval." + "batch": { + "description": "Required. The batch to create.", + "$ref": "#/components/schemas/EmbedContentBatch" } - } + }, + "description": "Request for an `AsyncBatchEmbedContent` operation.", + "type": "object" }, - "GenerateContentRequest": { - "description": "Request to generate a completion from the model.", + "GenerationConfig": { + "type": "object", "properties": { - "store": { + "responseLogprobs": { "type": "boolean", - "description": "Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config." - }, - "systemInstruction": { - "description": "Optional. Developer set [system instruction(s)](https://ai.google.dev/gemini-api/docs/system-instructions). Currently, text only.", - "$ref": "#/components/schemas/Content" + "description": "Optional. If true, export the logprobs results in response." }, - "contents": { + "responseModalities": { + "description": "Optional. The requested modalities of the response. Represents the set of modalities that the model can return, and should be expected in the response. This is an exact match to the modalities of the response. A model may have multiple combinations of supported modalities. If the requested modalities do not match any of the supported combinations, an error will be returned. An empty list is equivalent to requesting only text.", "type": "array", "items": { - "$ref": "#/components/schemas/Content" - }, - "description": "Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request." + "type": "string", + "x-enum-descriptions": [ + "Default value.", + "Indicates the model should return text.", + "Indicates the model should return images.", + "Indicates the model should return audio.", + "Indicates the model should return video." + ], + "enum": [ + "MODALITY_UNSPECIFIED", + "TEXT", + "IMAGE", + "AUDIO", + "VIDEO" + ] + } + }, + "thinkingConfig": { + "$ref": "#/components/schemas/ThinkingConfig", + "description": "Optional. Config for thinking features. An error will be returned if this field is set for models that don't support thinking." + }, + "temperature": { + "description": "Optional. Controls the randomness of the output. Note: The default value varies by model, see the `Model.temperature` attribute of the `Model` returned from the `getModel` function. Values can range from [0.0, 2.0].", + "type": "number", + "format": "float" + }, + "seed": { + "description": "Optional. Seed used in decoding. If not set, the request uses a randomly generated seed.", + "type": "integer", + "format": "int32" + }, + "enableEnhancedCivicAnswers": { + "type": "boolean", + "description": "Optional. Enables enhanced civic answers. It may not be available for all models." }, - "cachedContent": { - "type": "string", - "description": "Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}`" + "topK": { + "description": "Optional. The maximum number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests.", + "type": "integer", + "format": "int32" }, - "model": { - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", - "type": "string" + "responseJsonSchema": { + "description": "Optional. An internal detail. Use `responseJsonSchema` rather than this field." }, - "tools": { - "description": "Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more.", - "type": "array", - "items": { - "$ref": "#/components/schemas/Tool" - } + "frequencyPenalty": { + "type": "number", + "format": "float", + "description": "Optional. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit." }, - "generationConfig": { - "description": "Optional. Configuration options for model generation and outputs.", - "$ref": "#/components/schemas/GenerationConfig" + "topP": { + "description": "Optional. The maximum cumulative probability of tokens to consider when sampling. The model uses combined Top-k and Top-p (nucleus) sampling. Tokens are sorted based on their assigned probabilities so that only the most likely tokens are considered. Top-k sampling directly limits the maximum number of tokens to consider, while Nucleus sampling limits the number of tokens based on the cumulative probability. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests.", + "type": "number", + "format": "float" }, - "serviceTier": { - "enum": [ - "unspecified", - "standard", - "flex", - "priority" - ], + "mediaResolution": { "type": "string", "x-enum-descriptions": [ - "Default service tier, which is standard.", - "Standard service tier.", - "Flex service tier.", - "Priority service tier." + "Media resolution has not been set.", + "Media resolution set to low (64 tokens).", + "Media resolution set to medium (256 tokens).", + "Media resolution set to high (zoomed reframing with 256 tokens)." + ], + "enum": [ + "MEDIA_RESOLUTION_UNSPECIFIED", + "MEDIA_RESOLUTION_LOW", + "MEDIA_RESOLUTION_MEDIUM", + "MEDIA_RESOLUTION_HIGH" ], - "description": "Optional. The service tier of the request." + "description": "Optional. If specified, the media resolution specified will be used." }, - "toolConfig": { - "$ref": "#/components/schemas/ToolConfig", - "description": "Optional. Tool configuration for any `Tool` specified in the request. Refer to the [Function calling guide](https://ai.google.dev/gemini-api/docs/function-calling#function_calling_mode) for a usage example." + "speechConfig": { + "$ref": "#/components/schemas/SpeechConfig", + "description": "Optional. The speech generation config." }, - "safetySettings": { - "description": "Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications.", + "responseSchema": { + "description": "Optional. Output schema of the generated candidate text. Schemas must be a subset of the [OpenAPI schema](https://spec.openapis.org/oas/v3.0.3#schema) and can be objects, primitives or arrays. If set, a compatible `response_mime_type` must also be set. Compatible MIME types: `application/json`: Schema for JSON response. Refer to the [JSON text generation guide](https://ai.google.dev/gemini-api/docs/json-mode) for more details.", + "$ref": "#/components/schemas/Schema" + }, + "presencePenalty": { + "type": "number", + "format": "float", + "description": "Optional. Presence penalty applied to the next token's logprobs if the token has already been seen in the response. This penalty is binary on/off and not dependant on the number of times the token is used (after the first). Use frequency_penalty for a penalty that increases with each use. A positive penalty will discourage the use of tokens that have already been used in the response, increasing the vocabulary. A negative penalty will encourage the use of tokens that have already been used in the response, decreasing the vocabulary." + }, + "candidateCount": { + "description": "Optional. Number of generated responses to return. If unset, this will default to 1. Please note that this doesn't work for previous generation models (Gemini 1.0 family)", + "type": "integer", + "format": "int32" + }, + "responseMimeType": { + "description": "Optional. MIME type of the generated candidate text. Supported MIME types are: `text/plain`: (default) Text output. `application/json`: JSON response in the response candidates. `text/x.enum`: ENUM as a string response in the response candidates. Refer to the [docs](https://ai.google.dev/gemini-api/docs/prompting_with_media#plain_text_formats) for a list of all supported text MIME types.", + "type": "string" + }, + "imageConfig": { + "description": "Optional. Config for image generation. An error will be returned if this field is set for models that don't support these config options.", + "$ref": "#/components/schemas/ImageConfig" + }, + "stopSequences": { + "description": "Optional. The set of character sequences (up to 5) that will stop output generation. If specified, the API will stop at the first appearance of a `stop_sequence`. The stop sequence will not be included as part of the response.", "type": "array", "items": { - "$ref": "#/components/schemas/SafetySetting" + "type": "string" } + }, + "logprobs": { + "type": "integer", + "format": "int32", + "description": "Optional. Only valid if response_logprobs=True. This sets the number of top logprobs, including the chosen candidate, to return at each decoding step in the Candidate.logprobs_result. The number must be in the range of [0, 20]." + }, + "maxOutputTokens": { + "type": "integer", + "format": "int32", + "description": "Optional. The maximum number of tokens to include in a response candidate. Note: The default value varies by model, see the `Model.output_token_limit` attribute of the `Model` returned from the `getModel` function." } }, - "type": "object" + "description": "Configuration options for model generation and outputs. Not all parameters are configurable for every model." }, - "Blob": { - "type": "object", - "description": "Raw media bytes. Text should not be sent as raw bytes, use the 'text' field.", + "InputEmbedContentConfig": { + "description": "Configures the input to the batch request.", "properties": { - "mimeType": { + "fileName": { "type": "string", - "description": "The IANA standard MIME type of the source data. Examples: - image/png - image/jpeg If an unsupported MIME type is provided, an error will be returned. For a complete list of supported types, see [Supported file formats](https://ai.google.dev/gemini-api/docs/prompting_with_media#supported_file_formats)." + "description": "The name of the `File` containing the input requests." }, - "data": { - "format": "byte", - "type": "string", - "description": "Raw bytes for media formats." + "requests": { + "description": "The requests to be processed in the batch.", + "$ref": "#/components/schemas/InlinedEmbedContentRequests" } - } + }, + "type": "object" }, - "RetrievalConfig": { - "description": "Retrieval config.", + "CachedContentUsageMetadata": { + "type": "object", + "description": "Metadata on the usage of the cached content.", "properties": { - "latLng": { - "$ref": "#/components/schemas/LatLng", - "description": "Optional. The location of the user." - }, - "languageCode": { - "type": "string", - "description": "Optional. The language code of the user. Language code for content. Use language tags defined by [BCP47](https://www.rfc-editor.org/rfc/bcp/bcp47.txt)." + "totalTokenCount": { + "type": "integer", + "format": "int32", + "description": "Total number of tokens that the cached content consumes." } - }, - "type": "object" + } }, - "ModalityTokenCount": { - "description": "Represents token counting info for a single modality.", + "SpeakerVoiceConfig": { + "description": "The configuration for a single speaker in a multi speaker setup.", "properties": { - "modality": { - "description": "The modality associated with this token count.", + "speaker": { "type": "string", - "x-enum-descriptions": [ - "Unspecified modality.", - "Plain text.", - "Image.", - "Video.", - "Audio.", - "Document, e.g. PDF." - ], - "enum": [ - "MODALITY_UNSPECIFIED", - "TEXT", - "IMAGE", - "VIDEO", - "AUDIO", - "DOCUMENT" - ] + "description": "Required. The name of the speaker to use. Should be the same as in the prompt." }, - "tokenCount": { - "description": "Number of tokens.", - "type": "integer", - "format": "int32" + "voiceConfig": { + "description": "Required. The configuration for the voice to use.", + "$ref": "#/components/schemas/VoiceConfig" } }, "type": "object" }, - "TuningTask": { - "description": "Tuning tasks that create tuned models.", + "FunctionResponseBlob": { + "type": "object", "properties": { - "trainingData": { - "$ref": "#/components/schemas/Dataset", - "description": "Required. Input only. Immutable. The model training data." - }, - "completeTime": { - "description": "Output only. The timestamp when tuning this model completed.", - "format": "google-datetime", - "readOnly": true, + "mimeType": { + "description": "The IANA standard MIME type of the source data. Examples: - image/png - image/jpeg If an unsupported MIME type is provided, an error will be returned. For a complete list of supported types, see [Supported file formats](https://ai.google.dev/gemini-api/docs/prompting_with_media#supported_file_formats).", "type": "string" }, - "snapshots": { - "readOnly": true, - "type": "array", - "items": { - "$ref": "#/components/schemas/TuningSnapshot" - }, - "description": "Output only. Metrics collected during tuning." - }, - "startTime": { - "description": "Output only. The timestamp when tuning this model started.", - "readOnly": true, + "data": { "type": "string", - "format": "google-datetime" - }, - "hyperparameters": { - "$ref": "#/components/schemas/Hyperparameters", - "description": "Immutable. Hyperparameters controlling the tuning process. If not provided, default values will be used." + "format": "byte", + "description": "Raw bytes for media formats." } }, - "type": "object" + "description": "Raw media bytes for function response. Text should not be sent as raw bytes, use the 'FunctionResponse.response' field." }, - "GoogleSearchRetrieval": { - "description": "Tool to retrieve public web data for grounding, powered by Google.", + "RegisterFilesResponse": { + "type": "object", + "description": "Response for `RegisterFiles`.", "properties": { - "dynamicRetrievalConfig": { - "description": "Specifies the dynamic retrieval configuration for the given source.", - "$ref": "#/components/schemas/DynamicRetrievalConfig" + "files": { + "type": "array", + "items": { + "$ref": "#/components/schemas/File" + }, + "description": "The registered files to be used when calling GenerateContent." } - }, - "type": "object" + } }, - "File": { - "type": "object", - "description": "A file uploaded to the API. Next ID: 15", + "AttributionSourceId": { + "description": "Identifier for the source contributing to this attribution.", "properties": { - "mimeType": { - "description": "Output only. MIME type of the file.", - "readOnly": true, - "type": "string" - }, - "videoMetadata": { - "description": "Output only. Metadata for a video.", - "readOnly": true, - "$ref": "#/components/schemas/VideoFileMetadata" - }, - "createTime": { - "description": "Output only. The timestamp of when the `File` was created.", - "readOnly": true, - "type": "string", - "format": "google-datetime" - }, - "sizeBytes": { - "description": "Output only. Size of the file in bytes.", - "format": "int64", - "readOnly": true, - "type": "string" - }, - "source": { - "description": "Source of the File.", - "type": "string", - "x-enum-descriptions": [ - "Used if source is not specified.", - "Indicates the file is uploaded by the user.", - "Indicates the file is generated by Google.", - "Indicates the file is a registered, i.e. a Google Cloud Storage file." - ], - "enum": [ - "SOURCE_UNSPECIFIED", - "UPLOADED", - "GENERATED", - "REGISTERED" - ] - }, - "displayName": { - "description": "Optional. The human-readable display name for the `File`. The display name must be no more than 512 characters in length, including spaces. Example: \"Welcome Image\"", - "type": "string" - }, - "name": { - "type": "string", - "description": "Immutable. Identifier. The `File` resource name. The ID (name excluding the \"files/\" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be generated. Example: `files/123-456`" - }, - "downloadUri": { - "description": "Output only. The download uri of the `File`.", - "readOnly": true, - "type": "string" + "groundingPassage": { + "description": "Identifier for an inline passage.", + "$ref": "#/components/schemas/GroundingPassageId" }, - "error": { - "readOnly": true, - "$ref": "#/components/schemas/Status", - "description": "Output only. Error status if File processing failed." + "semanticRetrieverChunk": { + "$ref": "#/components/schemas/SemanticRetrieverChunk", + "description": "Identifier for a `Chunk` fetched via Semantic Retriever." + } + }, + "type": "object" + }, + "TuningSnapshot": { + "properties": { + "epoch": { + "type": "integer", + "format": "int32", + "description": "Output only. The epoch this step was part of.", + "readOnly": true }, - "expirationTime": { - "description": "Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.", - "format": "google-datetime", + "meanLoss": { + "type": "number", + "format": "float", "readOnly": true, - "type": "string" + "description": "Output only. The mean loss of the training examples for this step." }, - "updateTime": { + "computeTime": { "readOnly": true, + "description": "Output only. The timestamp when this metric was computed.", "type": "string", - "format": "google-datetime", - "description": "Output only. The timestamp of when the `File` was last updated." + "format": "google-datetime" }, - "sha256Hash": { + "step": { "readOnly": true, + "description": "Output only. The tuning step.", + "type": "integer", + "format": "int32" + } + }, + "description": "Record for a single tuning step.", + "type": "object" + }, + "FunctionCallingConfig": { + "type": "object", + "description": "Configuration for specifying function calling behavior.", + "properties": { + "mode": { "type": "string", - "format": "byte", - "description": "Output only. SHA-256 hash of the uploaded bytes." - }, - "state": { - "type": "string", - "readOnly": true, "x-enum-descriptions": [ - "The default value. This value is used if the state is omitted.", - "File is being processed and cannot be used for inference yet.", - "File is processed and available for inference.", - "File failed processing." + "Unspecified function calling mode. This value should not be used.", + "Default model behavior, model decides to predict either a function call or a natural language response.", + "Model is constrained to always predicting a function call only. If \"allowed_function_names\" are set, the predicted function call will be limited to any one of \"allowed_function_names\", else the predicted function call will be any one of the provided \"function_declarations\".", + "Model will not predict any function call. Model behavior is same as when not passing any function declarations.", + "Model decides to predict either a function call or a natural language response, but will validate function calls with constrained decoding. If \"allowed_function_names\" are set, the predicted function call will be limited to any one of \"allowed_function_names\", else the predicted function call will be any one of the provided \"function_declarations\"." ], "enum": [ - "STATE_UNSPECIFIED", - "PROCESSING", - "ACTIVE", - "FAILED" + "MODE_UNSPECIFIED", + "AUTO", + "ANY", + "NONE", + "VALIDATED" ], - "description": "Output only. Processing state of the File." + "description": "Optional. Specifies the mode in which function calling should execute. If unspecified, the default value will be set to AUTO." }, - "uri": { - "description": "Output only. The uri of the `File`.", - "readOnly": true, - "type": "string" + "allowedFunctionNames": { + "type": "array", + "items": { + "type": "string" + }, + "description": "Optional. A set of function names that, when provided, limits the functions the model will call. This should only be set when the Mode is ANY or VALIDATED. Function names should match [FunctionDeclaration.name]. When set, model will predict a function call from only allowed function names." } } }, - "Tool": { - "description": "Tool details that the model may use to generate response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the model. Next ID: 16", + "UsageMetadata": { + "type": "object", + "description": "Metadata on the generation request's token usage.", "properties": { - "codeExecution": { - "$ref": "#/components/schemas/CodeExecution", - "description": "Optional. Enables the model to execute code as part of generation." + "cacheTokensDetails": { + "readOnly": true, + "description": "Output only. List of modalities of the cached content in the request input.", + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + } }, - "urlContext": { - "description": "Optional. Tool to support URL context retrieval.", - "$ref": "#/components/schemas/UrlContext" + "candidatesTokenCount": { + "type": "integer", + "format": "int32", + "description": "Total number of tokens across all the generated response candidates." }, - "googleMaps": { - "description": "Optional. Tool that allows grounding the model's response with geospatial context related to the user's query.", - "$ref": "#/components/schemas/GoogleMaps" + "toolUsePromptTokenCount": { + "description": "Output only. Number of tokens present in tool-use prompt(s).", + "readOnly": true, + "type": "integer", + "format": "int32" }, - "computerUse": { - "description": "Optional. Tool to support the model interacting directly with the computer. If enabled, it automatically populates computer-use specific Function Declarations.", - "$ref": "#/components/schemas/ComputerUse" + "candidatesTokensDetails": { + "description": "Output only. List of modalities that were returned in the response.", + "readOnly": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + } }, - "fileSearch": { - "$ref": "#/components/schemas/FileSearch", - "description": "Optional. FileSearch tool type. Tool to retrieve knowledge from Semantic Retrieval corpora." + "thoughtsTokenCount": { + "description": "Output only. Number of tokens of thoughts for thinking models.", + "readOnly": true, + "type": "integer", + "format": "int32" }, - "functionDeclarations": { + "promptTokenCount": { + "type": "integer", + "format": "int32", + "description": "Number of tokens in the prompt. When `cached_content` is set, this is still the total effective prompt size meaning this includes the number of tokens in the cached content." + }, + "toolUsePromptTokensDetails": { + "description": "Output only. List of modalities that were processed for tool-use request inputs.", + "readOnly": true, "type": "array", "items": { - "$ref": "#/components/schemas/FunctionDeclaration" - }, - "description": "Optional. A list of `FunctionDeclarations` available to the model that can be used for function calling. The model or system does not execute the function. Instead the defined function may be returned as a FunctionCall with arguments to the client side for execution. The model may decide to call a subset of these functions by populating FunctionCall in the response. The next conversation turn may contain a FunctionResponse with the Content.role \"function\" generation context for the next model turn." - }, - "googleSearch": { - "$ref": "#/components/schemas/GoogleSearch", - "description": "Optional. GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google." + "$ref": "#/components/schemas/ModalityTokenCount" + } }, - "mcpServers": { - "description": "Optional. MCP Servers to connect to.", + "promptTokensDetails": { + "description": "Output only. List of modalities that were processed in the request input.", + "readOnly": true, "type": "array", "items": { - "$ref": "#/components/schemas/McpServer" + "$ref": "#/components/schemas/ModalityTokenCount" } }, - "googleSearchRetrieval": { - "description": "Optional. Retrieval tool that is powered by Google search.", - "$ref": "#/components/schemas/GoogleSearchRetrieval" + "cachedContentTokenCount": { + "description": "Number of tokens in the cached part of the prompt (the cached content)", + "type": "integer", + "format": "int32" + }, + "totalTokenCount": { + "type": "integer", + "format": "int32", + "description": "Total token count for the generation request (prompt + response candidates)." + }, + "responseTokenCount": { + "description": "Output only. Number of tokens in the response. Used by Gemini 3.1+ Live API models instead of candidatesTokenCount.", + "type": "integer", + "format": "int32", + "readOnly": true + }, + "responseTokensDetails": { + "description": "Output only. List of modalities returned in the response with per-modality token counts. Used by Gemini 3.1+ Live API models instead of candidatesTokensDetails.", + "type": "array", + "readOnly": true, + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + } } - }, - "type": "object" + } }, - "CustomMetadata": { + "CountTokensRequest": { "type": "object", - "description": "User provided metadata stored as key-value pairs.", + "description": "Counts the number of tokens in the `prompt` sent to a model. Models may tokenize text differently, so each model may return a different `token_count`.", "properties": { - "stringValue": { - "description": "The string value of the metadata to store.", - "type": "string" + "contents": { + "description": "Optional. The input given to the model as a prompt. This field is ignored when `generate_content_request` is set.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Content" + } }, - "key": { - "description": "Required. The key of the metadata to store.", - "type": "string" + "generateContentRequest": { + "$ref": "#/components/schemas/GenerateContentRequest", + "description": "Optional. The overall input given to the `Model`. This includes the prompt as well as other model steering information like [system instructions](https://ai.google.dev/gemini-api/docs/system-instructions), and/or function declarations for [function calling](https://ai.google.dev/gemini-api/docs/function-calling). `Model`s/`Content`s and `generate_content_request`s are mutually exclusive. You can either send `Model` + `Content`s or a `generate_content_request`, but never both." + } + } + }, + "Hyperparameters": { + "description": "Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance", + "properties": { + "batchSize": { + "type": "integer", + "format": "int32", + "description": "Immutable. The batch size hyperparameter for tuning. If not set, a default of 4 or 16 will be used based on the number of training examples." }, - "numericValue": { - "description": "The numeric value of the metadata to store.", + "learningRate": { + "description": "Optional. Immutable. The learning rate hyperparameter for tuning. If not set, a default of 0.001 or 0.0002 will be calculated based on the number of training examples.", "type": "number", "format": "float" }, - "stringListValue": { - "$ref": "#/components/schemas/StringList", - "description": "The StringList value of the metadata to store." + "learningRateMultiplier": { + "type": "number", + "format": "float", + "description": "Optional. Immutable. The learning rate multiplier is used to calculate a final learning_rate based on the default (recommended) value. Actual learning rate := learning_rate_multiplier * default learning rate Default learning rate is dependent on base model and dataset size. If not set, a default of 1.0 will be used." + }, + "epochCount": { + "type": "integer", + "format": "int32", + "description": "Immutable. The number of training epochs. An epoch is one pass through the training data. If not set, a default of 5 will be used." } - } + }, + "type": "object" }, - "ToolCall": { - "description": "A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`.", + "ExecutableCode": { + "description": "Code generated by the model that is meant to be executed, and the result returned to the model. Only generated when using the `CodeExecution` tool, in which the code will be automatically executed, and a corresponding `CodeExecutionResult` will also be generated.", "properties": { "id": { - "description": "Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`.", + "description": "Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`.", "type": "string" }, - "args": { - "type": "object", - "additionalProperties": { - "description": "Properties of the object." - }, - "description": "Optional. The tool call arguments. Example: {\"arg1\" : \"value1\", \"arg2\" : \"value2\" , ...}" - }, - "toolType": { + "language": { "type": "string", "x-enum-descriptions": [ - "Unspecified tool type.", - "Google search tool, maps to Tool.google_search.search_types.web_search.", - "Image search tool, maps to Tool.google_search.search_types.image_search.", - "URL context tool, maps to Tool.url_context.", - "Google maps tool, maps to Tool.google_maps.", - "File search tool, maps to Tool.file_search." + "Unspecified language. This value should not be used.", + "Python >= 3.10, with numpy and simpy available. Python is the default language." ], "enum": [ - "TOOL_TYPE_UNSPECIFIED", - "GOOGLE_SEARCH_WEB", - "GOOGLE_SEARCH_IMAGE", - "URL_CONTEXT", - "GOOGLE_MAPS", - "FILE_SEARCH" + "LANGUAGE_UNSPECIFIED", + "PYTHON" ], - "description": "Required. The type of tool that was called." - } - }, - "type": "object" - }, - "DynamicRetrievalConfig": { - "description": "Describes the options to customize dynamic retrieval.", - "properties": { - "dynamicThreshold": { - "description": "The threshold to be used in dynamic retrieval. If not set, a system default value is used.", - "type": "number", - "format": "float" + "description": "Required. Programming language of the `code`." }, - "mode": { - "description": "The mode of the predictor to be used in dynamic retrieval.", - "enum": [ - "MODE_UNSPECIFIED", - "MODE_DYNAMIC" - ], + "code": { "type": "string", - "x-enum-descriptions": [ - "Always trigger retrieval.", - "Run retrieval only when system decides it is necessary." - ] + "description": "Required. The code to be executed." } }, "type": "object" }, - "GenerateContentBatchOutput": { - "type": "object", - "description": "The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field.", + "Candidate": { "properties": { - "responsesFile": { - "readOnly": true, + "finishMessage": { "type": "string", - "description": "Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `GenerateContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests." - }, - "inlinedResponses": { - "description": "Output only. The responses to the requests in the batch. Returned when the batch was built using inlined requests. The responses will be in the same order as the input requests.", - "readOnly": true, - "$ref": "#/components/schemas/InlinedResponses" - } - } - }, - "EmbedContentBatchStats": { - "type": "object", - "description": "Stats about the batch.", - "properties": { - "pendingRequestCount": { "readOnly": true, - "type": "string", - "format": "int64", - "description": "Output only. The number of requests that are still pending processing." + "description": "Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set." }, - "requestCount": { - "description": "Output only. The number of requests in the batch.", - "format": "int64", + "groundingAttributions": { + "type": "array", + "items": { + "$ref": "#/components/schemas/GroundingAttribution" + }, "readOnly": true, - "type": "string" + "description": "Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls." }, - "successfulRequestCount": { + "groundingMetadata": { "readOnly": true, - "type": "string", - "format": "int64", - "description": "Output only. The number of requests that were successfully processed." + "$ref": "#/components/schemas/GroundingMetadata", + "description": "Output only. Grounding metadata for the candidate. This field is populated for `GenerateContent` calls." }, - "failedRequestCount": { - "description": "Output only. The number of requests that failed to be processed.", + "citationMetadata": { + "description": "Output only. Citation information for model-generated candidate. This field may be populated with recitation information for any text included in the `content`. These are passages that are \"recited\" from copyrighted material in the foundational LLM's training data.", "readOnly": true, - "type": "string", - "format": "int64" - } - } - }, - "CountTokensResponse": { - "type": "object", - "description": "A response from `CountTokens`. It returns the model's `token_count` for the `prompt`.", - "properties": { - "cachedContentTokenCount": { - "format": "int32", - "type": "integer", - "description": "Number of tokens in the cached part of the prompt (the cached content)." + "$ref": "#/components/schemas/CitationMetadata" }, - "promptTokensDetails": { - "description": "Output only. List of modalities that were processed in the request input.", + "avgLogprobs": { "readOnly": true, - "type": "array", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - } + "description": "Output only. Average log probability score of the candidate.", + "type": "number", + "format": "double" }, - "cacheTokensDetails": { + "index": { + "type": "integer", + "format": "int32", + "description": "Output only. Index of the candidate in the list of response candidates.", + "readOnly": true + }, + "content": { + "description": "Output only. Generated content returned from the model.", "readOnly": true, - "type": "array", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - }, - "description": "Output only. List of modalities that were processed in the cached content." + "$ref": "#/components/schemas/Content" }, - "totalTokens": { - "description": "The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative.", + "tokenCount": { + "type": "integer", "format": "int32", - "type": "integer" - } - } - }, - "ToolResponse": { - "type": "object", - "description": "The output from a server-side `ToolCall` execution. This message contains the results of a tool invocation that was initiated by a `ToolCall` from the model. The client should pass this `ToolResponse` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolCall`.", - "properties": { - "id": { - "description": "Optional. The identifier of the tool call this response is for.", - "type": "string" + "readOnly": true, + "description": "Output only. Token count for this candidate." }, - "toolType": { - "description": "Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`.", - "enum": [ - "TOOL_TYPE_UNSPECIFIED", - "GOOGLE_SEARCH_WEB", - "GOOGLE_SEARCH_IMAGE", - "URL_CONTEXT", - "GOOGLE_MAPS", - "FILE_SEARCH" - ], + "finishReason": { "type": "string", + "readOnly": true, "x-enum-descriptions": [ - "Unspecified tool type.", - "Google search tool, maps to Tool.google_search.search_types.web_search.", - "Image search tool, maps to Tool.google_search.search_types.image_search.", - "URL context tool, maps to Tool.url_context.", - "Google maps tool, maps to Tool.google_maps.", - "File search tool, maps to Tool.file_search." - ] + "Default value. This value is unused.", + "Natural stop point of the model or provided stop sequence.", + "The maximum number of tokens as specified in the request was reached.", + "The response candidate content was flagged for safety reasons.", + "The response candidate content was flagged for recitation reasons.", + "The response candidate content was flagged for using an unsupported language.", + "Unknown reason.", + "Token generation stopped because the content contains forbidden terms.", + "Token generation stopped for potentially containing prohibited content.", + "Token generation stopped because the content potentially contains Sensitive Personally Identifiable Information (SPII).", + "The function call generated by the model is invalid.", + "Token generation stopped because generated images contain safety violations.", + "Image generation stopped because generated images has other prohibited content.", + "Image generation stopped because of other miscellaneous issue.", + "The model was expected to generate an image, but none was generated.", + "Image generation stopped due to recitation.", + "Model generated a tool call but no tools were enabled in the request.", + "Model called too many tools consecutively, thus the system exited execution.", + "Request has at least one thought signature missing.", + "Finished due to malformed response." + ], + "enum": [ + "FINISH_REASON_UNSPECIFIED", + "STOP", + "MAX_TOKENS", + "SAFETY", + "RECITATION", + "LANGUAGE", + "OTHER", + "BLOCKLIST", + "PROHIBITED_CONTENT", + "SPII", + "MALFORMED_FUNCTION_CALL", + "IMAGE_SAFETY", + "IMAGE_PROHIBITED_CONTENT", + "IMAGE_OTHER", + "NO_IMAGE", + "IMAGE_RECITATION", + "UNEXPECTED_TOOL_CALL", + "TOO_MANY_TOOL_CALLS", + "MISSING_THOUGHT_SIGNATURE", + "MALFORMED_RESPONSE" + ], + "description": "Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens." }, - "response": { - "type": "object", - "additionalProperties": { - "description": "Properties of the object." + "safetyRatings": { + "type": "array", + "items": { + "$ref": "#/components/schemas/SafetyRating" }, - "description": "Optional. The tool response." - } - } - }, - "InputEmbedContentConfig": { - "type": "object", - "description": "Configures the input to the batch request.", - "properties": { - "requests": { - "description": "The requests to be processed in the batch.", - "$ref": "#/components/schemas/InlinedEmbedContentRequests" + "description": "List of ratings for the safety of a response candidate. There is at most one rating per category." }, - "fileName": { - "type": "string", - "description": "The name of the `File` containing the input requests." - } - } - }, - "FunctionResponseBlob": { - "description": "Raw media bytes for function response. Text should not be sent as raw bytes, use the 'FunctionResponse.response' field.", - "properties": { - "data": { - "format": "byte", - "type": "string", - "description": "Raw bytes for media formats." + "logprobsResult": { + "description": "Output only. Log-likelihood scores for the response tokens and top tokens", + "readOnly": true, + "$ref": "#/components/schemas/LogprobsResult" }, - "mimeType": { - "description": "The IANA standard MIME type of the source data. Examples: - image/png - image/jpeg If an unsupported MIME type is provided, an error will be returned. For a complete list of supported types, see [Supported file formats](https://ai.google.dev/gemini-api/docs/prompting_with_media#supported_file_formats).", - "type": "string" + "urlContextMetadata": { + "description": "Output only. Metadata related to url context retrieval tool.", + "readOnly": true, + "$ref": "#/components/schemas/UrlContextMetadata" } }, + "description": "A response candidate generated from the model.", "type": "object" }, - "ListGeneratedFilesResponse": { - "description": "Response for `ListGeneratedFiles`.", + "InlinedResponses": { + "type": "object", "properties": { - "generatedFiles": { - "description": "The list of `GeneratedFile`s.", + "inlinedResponses": { + "readOnly": true, + "description": "Output only. The responses to the requests in the batch.", "type": "array", "items": { - "$ref": "#/components/schemas/GeneratedFile" + "$ref": "#/components/schemas/InlinedResponse" } - }, - "nextPageToken": { - "type": "string", - "description": "A token that can be sent as a `page_token` into a subsequent `ListGeneratedFiles` call." } }, - "type": "object" + "description": "The responses to the requests in the batch." }, - "LogprobsResultCandidate": { + "LatLng": { "type": "object", - "description": "Candidate for the logprobs token and score.", "properties": { - "token": { - "description": "The candidate\u2019s token string value.", - "type": "string" - }, - "tokenId": { - "description": "The candidate\u2019s token id value.", - "type": "integer", - "format": "int32" + "latitude": { + "type": "number", + "format": "double", + "description": "The latitude in degrees. It must be in the range [-90.0, +90.0]." }, - "logProbability": { - "description": "The candidate's log probability.", + "longitude": { "type": "number", - "format": "float" + "format": "double", + "description": "The longitude in degrees. It must be in the range [-180.0, +180.0]." } - } + }, + "description": "An object that represents a latitude/longitude pair. This is expressed as a pair of doubles to represent degrees latitude and degrees longitude. Unless specified otherwise, this object must conform to the WGS84 standard. Values must be within normalized ranges." }, - "UsageMetadata": { + "ListModelsResponse": { "type": "object", - "description": "Metadata on the generation request's token usage.", + "description": "Response from `ListModel` containing a paginated list of Models.", "properties": { - "promptTokenCount": { - "description": "Number of tokens in the prompt. When `cached_content` is set, this is still the total effective prompt size meaning this includes the number of tokens in the cached content.", - "type": "integer", - "format": "int32" - }, - "cachedContentTokenCount": { - "description": "Number of tokens in the cached part of the prompt (the cached content)", - "format": "int32", - "type": "integer" + "nextPageToken": { + "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", + "type": "string" }, - "toolUsePromptTokensDetails": { - "readOnly": true, + "models": { "type": "array", "items": { - "$ref": "#/components/schemas/ModalityTokenCount" + "$ref": "#/components/schemas/Model" }, - "description": "Output only. List of modalities that were processed for tool-use request inputs." - }, - "toolUsePromptTokenCount": { - "description": "Output only. Number of tokens present in tool-use prompt(s).", + "description": "The returned Models." + } + } + }, + "EmbeddingUsageMetadata": { + "type": "object", + "properties": { + "promptTokenCount": { + "description": "Output only. Number of tokens in the prompt.", "readOnly": true, "type": "integer", "format": "int32" }, - "candidatesTokenCount": { - "description": "Total number of tokens across all the generated response candidates.", - "type": "integer", - "format": "int32" - }, - "totalTokenCount": { - "description": "Total token count for the generation request (prompt + response candidates).", - "type": "integer", - "format": "int32" - }, - "candidatesTokensDetails": { - "description": "Output only. List of modalities that were returned in the response.", - "readOnly": true, + "promptTokenDetails": { "type": "array", "items": { "$ref": "#/components/schemas/ModalityTokenCount" + }, + "description": "Output only. List of modalities that were processed in the request input.", + "readOnly": true + } + }, + "description": "Metadata on the usage of the embedding request." + }, + "ComputerUse": { + "type": "object", + "description": "Computer Use tool type.", + "properties": { + "excludedPredefinedFunctions": { + "description": "Optional. By default, predefined functions are included in the final model call. Some of them can be explicitly excluded from being automatically included. This can serve two purposes: 1. Using a more restricted / different action space. 2. Improving the definitions / instructions of predefined functions.", + "type": "array", + "items": { + "type": "string" } }, - "promptTokensDetails": { - "readOnly": true, + "environment": { + "type": "string", + "x-enum-descriptions": [ + "Defaults to browser.", + "Operates in a web browser." + ], + "enum": [ + "ENVIRONMENT_UNSPECIFIED", + "ENVIRONMENT_BROWSER" + ], + "description": "Required. The environment being operated." + } + } + }, + "GoogleAiGenerativelanguageV1betaGroundingSupport": { + "type": "object", + "properties": { + "renderedParts": { "type": "array", "items": { - "$ref": "#/components/schemas/ModalityTokenCount" + "type": "integer", + "format": "int32" }, - "description": "Output only. List of modalities that were processed in the request input." + "description": "Output only. Indices into the `parts` field of the candidate's content. These indices specify which rendered parts are associated with this support source.", + "readOnly": true }, - "cacheTokensDetails": { - "readOnly": true, + "groundingChunkIndices": { + "description": "Optional. A list of indices (into 'grounding_chunk' in `response.candidate.grounding_metadata`) specifying the citations associated with the claim. For instance [1,3,4] means that grounding_chunk[1], grounding_chunk[3], grounding_chunk[4] are the retrieved content attributed to the claim. If the response is streaming, the grounding_chunk_indices refer to the indices across all responses. It is the client's responsibility to accumulate the grounding chunks from all responses (while maintaining the same order).", "type": "array", "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - }, - "description": "Output only. List of modalities of the cached content in the request input." - }, - "thoughtsTokenCount": { - "description": "Output only. Number of tokens of thoughts for thinking models.", - "readOnly": true, - "type": "integer", - "format": "int32" + "type": "integer", + "format": "int32" + } }, - "responseTokenCount": { - "description": "Output only. Number of tokens in the response. Used by Gemini 3.1+ Live API models instead of candidatesTokenCount.", - "type": "integer", - "format": "int32", - "readOnly": true + "segment": { + "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaSegment", + "description": "Segment of the content this support belongs to." }, - "responseTokensDetails": { - "description": "Output only. List of modalities returned in the response with per-modality token counts. Used by Gemini 3.1+ Live API models instead of candidatesTokensDetails.", + "confidenceScores": { + "description": "Optional. Confidence score of the support references. Ranges from 0 to 1. 1 is the most confident. This list must have the same size as the grounding_chunk_indices.", "type": "array", - "readOnly": true, "items": { - "$ref": "#/components/schemas/ModalityTokenCount" + "type": "number", + "format": "float" } } - } + }, + "description": "Grounding support." }, - "GoogleMaps": { - "description": "The GoogleMaps Tool that provides geospatial context for the user's query.", + "ModalityTokenCount": { "properties": { - "enableWidget": { - "description": "Optional. Whether to return a widget context token in the GroundingMetadata of the response. Developers can use the widget context token to render a Google Maps widget with geospatial context related to the places that the model references in the response.", - "type": "boolean" + "modality": { + "description": "The modality associated with this token count.", + "type": "string", + "x-enum-descriptions": [ + "Unspecified modality.", + "Plain text.", + "Image.", + "Video.", + "Audio.", + "Document, e.g. PDF." + ], + "enum": [ + "MODALITY_UNSPECIFIED", + "TEXT", + "IMAGE", + "VIDEO", + "AUDIO", + "DOCUMENT" + ] + }, + "tokenCount": { + "description": "Number of tokens.", + "type": "integer", + "format": "int32" } }, + "description": "Represents token counting info for a single modality.", "type": "object" }, - "Interval": { - "type": "object", - "description": "Represents a time interval, encoded as a Timestamp start (inclusive) and a Timestamp end (exclusive). The start must be less than or equal to the end. When the start equals the end, the interval is empty (matches no time). When both start and end are unspecified, the interval matches any time.", + "EmbedContentRequest": { + "description": "Request containing the `Content` for the model to embed.", "properties": { - "startTime": { - "description": "Optional. Inclusive start of the interval. If specified, a Timestamp matching this interval will have to be the same or after the start.", - "format": "google-datetime", - "type": "string" + "outputDimensionality": { + "type": "integer", + "format": "int32", + "description": "Optional. Optional reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. Supported by newer models since 2024 only. You cannot set this value if using the earlier model (`models/embedding-001`)." }, - "endTime": { - "format": "google-datetime", - "type": "string", - "description": "Optional. Exclusive end of the interval. If specified, a Timestamp matching this interval will have to be before the end." - } - } - }, - "Permission": { - "type": "object", - "description": "Permission resource grants user, group or the rest of the world access to the PaLM API resource (e.g. a tuned model, corpus). A role is a collection of permitted operations that allows users to perform specific actions on PaLM API resources. To make them available to users, groups, or service accounts, you assign roles. When you assign a role, you grant permissions that the role contains. There are three concentric roles. Each role is a superset of the previous role's permitted operations: - reader can use the resource (e.g. tuned model, corpus) for inference - writer has reader's permissions and additionally can edit and share - owner has writer's permissions and additionally can delete", - "properties": { - "granteeType": { + "content": { + "description": "Required. The content to embed. Only the `parts.text` fields will be counted.", + "$ref": "#/components/schemas/Content" + }, + "taskType": { + "description": "Optional. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`).", "type": "string", "x-enum-descriptions": [ - "The default value. This value is unused.", - "Represents a user. When set, you must provide email_address for the user.", - "Represents a group. When set, you must provide email_address for the group.", - "Represents access to everyone. No extra information is required." + "Unset value, which will default to one of the other enum values.", + "Specifies the given text is a query in a search/retrieval setting.", + "Specifies the given text is a document from the corpus being searched.", + "Specifies the given text will be used for STS.", + "Specifies that the given text will be classified.", + "Specifies that the embeddings will be used for clustering.", + "Specifies that the given text will be used for question answering.", + "Specifies that the given text will be used for fact verification.", + "Specifies that the given text will be used for code retrieval." ], "enum": [ - "GRANTEE_TYPE_UNSPECIFIED", - "USER", - "GROUP", - "EVERYONE" - ], - "description": "Optional. Immutable. The type of the grantee." + "TASK_TYPE_UNSPECIFIED", + "RETRIEVAL_QUERY", + "RETRIEVAL_DOCUMENT", + "SEMANTIC_SIMILARITY", + "CLASSIFICATION", + "CLUSTERING", + "QUESTION_ANSWERING", + "FACT_VERIFICATION", + "CODE_RETRIEVAL_QUERY" + ] }, - "name": { - "description": "Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.", - "readOnly": true, + "model": { + "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", "type": "string" }, - "emailAddress": { - "type": "string", - "description": "Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE." + "title": { + "description": "Optional. An optional title for the text. Only applicable when TaskType is `RETRIEVAL_DOCUMENT`. Note: Specifying a `title` for `RETRIEVAL_DOCUMENT` provides better quality embeddings for retrieval.", + "type": "string" + } + }, + "type": "object" + }, + "StringList": { + "properties": { + "values": { + "description": "The string values of the metadata to store.", + "type": "array", + "items": { + "type": "string" + } + } + }, + "description": "User provided string values assigned to a single metadata key.", + "type": "object" + }, + "GroundingAttribution": { + "type": "object", + "description": "Attribution for a source that contributed to an answer.", + "properties": { + "sourceId": { + "readOnly": true, + "$ref": "#/components/schemas/AttributionSourceId", + "description": "Output only. Identifier for the source contributing to this attribution." }, - "role": { - "type": "string", - "x-enum-descriptions": [ - "The default value. This value is unused.", - "Owner can use, update, share and delete the resource.", - "Writer can use, update and share the resource.", - "Reader can use the resource." - ], - "enum": [ - "ROLE_UNSPECIFIED", - "OWNER", - "WRITER", - "READER" - ], - "description": "Required. The role granted by this permission." + "content": { + "description": "Grounding source content that makes up this attribution.", + "$ref": "#/components/schemas/Content" } } }, - "UploadToFileSearchStoreRequest": { - "description": "Request for `UploadToFileSearchStore`.", + "InlinedEmbedContentRequest": { + "type": "object", + "properties": { + "request": { + "description": "Required. The request to be processed in the batch.", + "$ref": "#/components/schemas/EmbedContentRequest" + }, + "metadata": { + "type": "object", + "additionalProperties": { + "description": "Properties of the object." + }, + "description": "Optional. The metadata to be associated with the request." + } + }, + "description": "The request to be processed in the batch." + }, + "Corpus": { + "type": "object", + "description": "A `Corpus` is a collection of `Document`s. A project can create up to 10 corpora.", "properties": { "displayName": { "type": "string", - "description": "Optional. Display name of the created document." + "description": "Optional. The human-readable display name for the `Corpus`. The display name must be no more than 512 characters in length, including spaces. Example: \"Docs on Semantic Retriever\"" }, - "mimeType": { + "createTime": { + "readOnly": true, + "description": "Output only. The Timestamp of when the `Corpus` was created.", "type": "string", - "description": "Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content." + "format": "google-datetime" }, - "customMetadata": { - "type": "array", - "items": { - "$ref": "#/components/schemas/CustomMetadata" - }, - "description": "Custom metadata to be associated with the data." + "name": { + "type": "string", + "readOnly": true, + "description": "Output only. Immutable. Identifier. The `Corpus` resource name. The ID (name excluding the \"corpora/\" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `corpora/my-awesome-corpora-123a456b789c`" }, - "chunkingConfig": { - "description": "Optional. Config for telling the service how to chunk the data. If not provided, the service will use default parameters.", - "$ref": "#/components/schemas/ChunkingConfig" + "updateTime": { + "description": "Output only. The Timestamp of when the `Corpus` was last updated.", + "readOnly": true, + "type": "string", + "format": "google-datetime" } - }, - "type": "object" - }, - "WebSearch": { - "type": "object", - "description": "Standard web search for grounding and related configurations.", - "properties": {} + } }, - "SpeakerVoiceConfig": { - "description": "The configuration for a single speaker in a multi speaker setup.", + "ChunkingConfig": { + "description": "Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto", "properties": { - "voiceConfig": { - "description": "Required. The configuration for the voice to use.", - "$ref": "#/components/schemas/VoiceConfig" - }, - "speaker": { - "description": "Required. The name of the speaker to use. Should be the same as in the prompt.", - "type": "string" + "whiteSpaceConfig": { + "description": "White space chunking configuration.", + "$ref": "#/components/schemas/WhiteSpaceConfig" } }, "type": "object" }, "FileSearch": { - "type": "object", - "description": "The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API.", "properties": { "fileSearchStoreNames": { - "description": "Required. The names of the file_search_stores to retrieve from. Example: `fileSearchStores/my-file-search-store-123`", "type": "array", "items": { "type": "string" - } + }, + "description": "Required. The names of the file_search_stores to retrieve from. Example: `fileSearchStores/my-file-search-store-123`" }, "topK": { "type": "integer", @@ -6202,399 +5874,727 @@ "description": "Optional. The number of semantic retrieval chunks to retrieve." }, "metadataFilter": { - "type": "string", - "description": "Optional. Metadata filter to apply to the semantic retrieval documents and chunks." + "description": "Optional. Metadata filter to apply to the semantic retrieval documents and chunks.", + "type": "string" + } + }, + "description": "The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API.", + "type": "object" + }, + "RetrievalMetadata": { + "type": "object", + "description": "Metadata related to retrieval in the grounding flow.", + "properties": { + "googleSearchDynamicRetrievalScore": { + "type": "number", + "format": "float", + "description": "Optional. Score indicating how likely information from google search could help answer the prompt. The score is in the range [0, 1], where 0 is the least likely and 1 is the most likely. This score is only populated when google search grounding and dynamic retrieval is enabled. It will be compared to the threshold to determine whether to trigger google search." } } }, - "PromptFeedback": { - "description": "A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`.", + "Interval": { "properties": { - "safetyRatings": { - "description": "Ratings for safety of the prompt. There is at most one rating per category.", - "type": "array", - "items": { - "$ref": "#/components/schemas/SafetyRating" - } + "startTime": { + "type": "string", + "format": "google-datetime", + "description": "Optional. Inclusive start of the interval. If specified, a Timestamp matching this interval will have to be the same or after the start." }, - "blockReason": { - "description": "Optional. If set, the prompt was blocked and no candidates are returned. Rephrase the prompt.", - "enum": [ - "BLOCK_REASON_UNSPECIFIED", - "SAFETY", - "OTHER", - "BLOCKLIST", - "PROHIBITED_CONTENT", - "IMAGE_SAFETY" - ], + "endTime": { "type": "string", - "x-enum-descriptions": [ - "Default value. This value is unused.", - "Prompt was blocked due to safety reasons. Inspect `safety_ratings` to understand which safety category blocked it.", - "Prompt was blocked due to unknown reasons.", - "Prompt was blocked due to the terms which are included from the terminology blocklist.", - "Prompt was blocked due to prohibited content.", - "Candidates blocked due to unsafe image generation content." - ] + "format": "google-datetime", + "description": "Optional. Exclusive end of the interval. If specified, a Timestamp matching this interval will have to be before the end." } }, + "description": "Represents a time interval, encoded as a Timestamp start (inclusive) and a Timestamp end (exclusive). The start must be less than or equal to the end. When the start equals the end, the interval is empty (matches no time). When both start and end are unspecified, the interval matches any time.", "type": "object" }, - "StringList": { - "type": "object", - "description": "User provided string values assigned to a single metadata key.", + "ListOperationsResponse": { + "description": "The response message for Operations.ListOperations.", "properties": { - "values": { - "description": "The string values of the metadata to store.", + "operations": { + "type": "array", + "items": { + "$ref": "#/components/schemas/Operation" + }, + "description": "A list of operations that matches the specified filter in the request." + }, + "unreachable": { "type": "array", "items": { "type": "string" - } + }, + "description": "Unordered list. Unreachable resources. Populated when the request sets `ListOperationsRequest.return_partial_success` and reads across collections. For example, when attempting to list all resources across all supported locations." + }, + "nextPageToken": { + "description": "The standard List next-page token.", + "type": "string" } - } + }, + "type": "object" }, - "TuningSnapshot": { - "description": "Record for a single tuning step.", + "GenerateContentBatch": { + "type": "object", + "description": "A resource representing a batch of `GenerateContent` requests.", "properties": { - "epoch": { + "displayName": { + "type": "string", + "description": "Required. The user-defined name of this batch." + }, + "inputConfig": { + "$ref": "#/components/schemas/InputConfig", + "description": "Required. Input configuration of the instances on which batch processing are performed." + }, + "batchStats": { "readOnly": true, - "type": "integer", - "format": "int32", - "description": "Output only. The epoch this step was part of." + "$ref": "#/components/schemas/BatchStats", + "description": "Output only. Stats about the batch." }, - "meanLoss": { + "model": { + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "type": "string" + }, + "name": { "readOnly": true, - "type": "number", - "format": "float", - "description": "Output only. The mean loss of the training examples for this step." + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", + "type": "string" }, - "step": { - "description": "Output only. The tuning step.", - "format": "int32", + "priority": { + "type": "string", + "format": "int64", + "description": "Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0." + }, + "createTime": { + "description": "Output only. The time at which the batch was created.", "readOnly": true, - "type": "integer" + "type": "string", + "format": "google-datetime" }, - "computeTime": { - "description": "Output only. The timestamp when this metric was computed.", + "state": { + "type": "string", + "readOnly": true, + "x-enum-descriptions": [ + "The batch state is unspecified.", + "The service is preparing to run the batch.", + "The batch is in progress.", + "The batch completed successfully.", + "The batch failed.", + "The batch has been cancelled.", + "The batch has expired." + ], + "enum": [ + "BATCH_STATE_UNSPECIFIED", + "BATCH_STATE_PENDING", + "BATCH_STATE_RUNNING", + "BATCH_STATE_SUCCEEDED", + "BATCH_STATE_FAILED", + "BATCH_STATE_CANCELLED", + "BATCH_STATE_EXPIRED" + ], + "description": "Output only. The state of the batch." + }, + "updateTime": { + "type": "string", + "format": "google-datetime", + "description": "Output only. The time at which the batch was last updated.", + "readOnly": true + }, + "endTime": { + "description": "Output only. The time at which the batch processing completed.", "readOnly": true, "type": "string", "format": "google-datetime" + }, + "output": { + "description": "Output only. The output of the batch request.", + "readOnly": true, + "$ref": "#/components/schemas/GenerateContentBatchOutput" + } + } + }, + "Content": { + "type": "object", + "properties": { + "role": { + "type": "string", + "description": "Optional. The producer of the content. Must be either 'user' or 'model'. Useful to set for multi-turn conversations, otherwise can be left blank or unset." + }, + "parts": { + "description": "Ordered `Parts` that constitute a single message. Parts may have different MIME types.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Part" + } + } + }, + "description": "The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn." + }, + "CustomMetadata": { + "properties": { + "stringValue": { + "type": "string", + "description": "The string value of the metadata to store." + }, + "numericValue": { + "description": "The numeric value of the metadata to store.", + "type": "number", + "format": "float" + }, + "key": { + "description": "Required. The key of the metadata to store.", + "type": "string" + }, + "stringListValue": { + "$ref": "#/components/schemas/StringList", + "description": "The StringList value of the metadata to store." } }, + "description": "User provided metadata stored as key-value pairs.", "type": "object" }, - "SpeechConfig": { - "description": "Config for speech generation and transcription.", + "ListGeneratedFilesResponse": { "properties": { - "voiceConfig": { - "$ref": "#/components/schemas/VoiceConfig", - "description": "The configuration in case of single-voice output." + "generatedFiles": { + "type": "array", + "items": { + "$ref": "#/components/schemas/GeneratedFile" + }, + "description": "The list of `GeneratedFile`s." }, - "multiSpeakerVoiceConfig": { - "description": "Optional. The configuration for the multi-speaker setup. It is mutually exclusive with the voice_config field.", - "$ref": "#/components/schemas/MultiSpeakerVoiceConfig" + "nextPageToken": { + "description": "A token that can be sent as a `page_token` into a subsequent `ListGeneratedFiles` call.", + "type": "string" + } + }, + "description": "Response for `ListGeneratedFiles`.", + "type": "object" + }, + "SearchEntryPoint": { + "description": "Google search entry point.", + "properties": { + "renderedContent": { + "type": "string", + "description": "Optional. Web content snippet that can be embedded in a web page or an app webview." }, - "languageCode": { + "sdkBlob": { + "type": "string", + "format": "byte", + "description": "Optional. Base64 encoded JSON representing array of tuple." + } + }, + "type": "object" + }, + "WebSearch": { + "properties": {}, + "description": "Standard web search for grounding and related configurations.", + "type": "object" + }, + "Web": { + "properties": { + "uri": { + "type": "string", + "readOnly": true, + "description": "Output only. URI reference of the chunk." + }, + "title": { "type": "string", - "description": "Optional. The IETF [BCP-47](https://www.rfc-editor.org/rfc/bcp/bcp47.txt) language code that the user configured the app to use. Used for speech recognition and synthesis. Valid values are: `de-DE`, `en-AU`, `en-GB`, `en-IN`, `en-US`, `es-US`, `fr-FR`, `hi-IN`, `pt-BR`, `ar-XA`, `es-ES`, `fr-CA`, `id-ID`, `it-IT`, `ja-JP`, `tr-TR`, `vi-VN`, `bn-IN`, `gu-IN`, `kn-IN`, `ml-IN`, `mr-IN`, `ta-IN`, `te-IN`, `nl-NL`, `ko-KR`, `cmn-CN`, `pl-PL`, `ru-RU`, and `th-TH`." + "description": "Output only. Title of the chunk.", + "readOnly": true } }, + "description": "Chunk from the web.", "type": "object" }, - "Empty": { - "description": "A generic empty message that you can re-use to avoid defining duplicated empty messages in your APIs. A typical example is to use it as the request or the response type of an API method. For instance: service Foo { rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); }", - "properties": {}, - "type": "object" + "GoogleMaps": { + "type": "object", + "description": "The GoogleMaps Tool that provides geospatial context for the user's query.", + "properties": { + "enableWidget": { + "description": "Optional. Whether to return a widget context token in the GroundingMetadata of the response. Developers can use the widget context token to render a Google Maps widget with geospatial context related to the places that the model references in the response.", + "type": "boolean" + } + } }, - "EmbeddingUsageMetadata": { - "description": "Metadata on the usage of the embedding request.", + "InputConfig": { + "type": "object", + "description": "Configures the input to the batch request.", "properties": { - "promptTokenCount": { - "format": "int32", - "readOnly": true, - "type": "integer", - "description": "Output only. Number of tokens in the prompt." + "fileName": { + "description": "The name of the `File` containing the input requests.", + "type": "string" }, - "promptTokenDetails": { - "readOnly": true, - "type": "array", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - }, - "description": "Output only. List of modalities that were processed in the request input." + "requests": { + "$ref": "#/components/schemas/InlinedRequests", + "description": "The requests to be processed in the batch." } - }, - "type": "object" + } }, - "ListPermissionsResponse": { - "description": "Response from `ListPermissions` containing a paginated list of permissions.", + "GenerateContentBatchOutput": { "properties": { - "permissions": { - "type": "array", - "items": { - "$ref": "#/components/schemas/Permission" - }, - "description": "Returned permissions." + "responsesFile": { + "type": "string", + "description": "Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `GenerateContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests.", + "readOnly": true }, - "nextPageToken": { - "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", - "type": "string" + "inlinedResponses": { + "readOnly": true, + "$ref": "#/components/schemas/InlinedResponses", + "description": "Output only. The responses to the requests in the batch. Returned when the batch was built using inlined requests. The responses will be in the same order as the input requests." } }, + "description": "The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field.", "type": "object" }, - "InlinedEmbedContentRequest": { - "description": "The request to be processed in the batch.", + "TuningExample": { + "description": "A single example for tuning.", "properties": { - "request": { - "$ref": "#/components/schemas/EmbedContentRequest", - "description": "Required. The request to be processed in the batch." + "output": { + "type": "string", + "description": "Required. The expected model output." }, - "metadata": { - "description": "Optional. The metadata to be associated with the request.", - "type": "object", - "additionalProperties": { - "description": "Properties of the object." - } + "textInput": { + "type": "string", + "description": "Optional. Text model input." } }, "type": "object" }, - "InlinedEmbedContentResponse": { - "description": "The response to a single request in the batch.", + "EmbedContentBatchStats": { + "type": "object", + "description": "Stats about the batch.", "properties": { - "error": { - "description": "Output only. The error encountered while processing the request.", + "requestCount": { + "type": "string", + "format": "int64", "readOnly": true, - "$ref": "#/components/schemas/Status" + "description": "Output only. The number of requests in the batch." }, - "response": { + "failedRequestCount": { + "type": "string", + "format": "int64", "readOnly": true, - "$ref": "#/components/schemas/EmbedContentResponse", - "description": "Output only. The response to the request." + "description": "Output only. The number of requests that failed to be processed." }, - "metadata": { - "description": "Output only. The metadata associated with the request.", + "successfulRequestCount": { + "type": "string", + "format": "int64", "readOnly": true, - "type": "object", - "additionalProperties": { - "description": "Properties of the object." - } + "description": "Output only. The number of requests that were successfully processed." + }, + "pendingRequestCount": { + "type": "string", + "format": "int64", + "description": "Output only. The number of requests that are still pending processing.", + "readOnly": true + } + } + }, + "TunedModelSource": { + "description": "Tuned model as a source for training a new model.", + "properties": { + "tunedModel": { + "description": "Immutable. The name of the `TunedModel` to use as the starting point for training the new model. Example: `tunedModels/my-tuned-model`", + "type": "string" + }, + "baseModel": { + "description": "Output only. The name of the base `Model` this `TunedModel` was tuned from. Example: `models/gemini-1.5-flash-001`", + "readOnly": true, + "type": "string" } }, "type": "object" }, - "EmbedContentBatch": { - "description": "A resource representing a batch of `EmbedContent` requests.", + "FileSearchStore": { + "type": "object", "properties": { "name": { "readOnly": true, - "type": "string", - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`." + "description": "Output only. Immutable. Identifier. The `FileSearchStore` resource name. It is an ID (name excluding the \"fileSearchStores/\" prefix) that can contain up to 40 characters that are lowercase alphanumeric or dashes (-). It is output only. The unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/my-awesome-file-search-store-123a456b789c` If `display_name` is not provided, the name will be randomly generated.", + "type": "string" }, - "displayName": { + "pendingDocumentsCount": { "type": "string", - "description": "Required. The user-defined name of this batch." + "format": "int64", + "description": "Output only. The number of documents in the `FileSearchStore` that are being processed.", + "readOnly": true }, - "createTime": { - "format": "google-datetime", + "sizeBytes": { "readOnly": true, + "description": "Output only. The size of raw bytes ingested into the `FileSearchStore`. This is the total size of all the documents in the `FileSearchStore`.", "type": "string", - "description": "Output only. The time at which the batch was created." + "format": "int64" }, - "output": { - "description": "Output only. The output of the batch request.", + "failedDocumentsCount": { "readOnly": true, - "$ref": "#/components/schemas/EmbedContentBatchOutput" + "description": "Output only. The number of documents in the `FileSearchStore` that have failed processing.", + "type": "string", + "format": "int64" + }, + "displayName": { + "description": "Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: \"Docs on Semantic Retriever\"", + "type": "string" }, "updateTime": { - "description": "Output only. The time at which the batch was last updated.", - "format": "google-datetime", "readOnly": true, - "type": "string" + "description": "Output only. The Timestamp of when the `FileSearchStore` was last updated.", + "type": "string", + "format": "google-datetime" }, - "endTime": { + "createTime": { + "description": "Output only. The Timestamp of when the `FileSearchStore` was created.", "readOnly": true, "type": "string", - "format": "google-datetime", - "description": "Output only. The time at which the batch processing completed." + "format": "google-datetime" }, - "state": { + "activeDocumentsCount": { + "readOnly": true, + "description": "Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.", + "type": "string", + "format": "int64" + } + }, + "description": "A `FileSearchStore` is a collection of `Document`s." + }, + "GroundingPassageId": { + "properties": { + "passageId": { "type": "string", - "description": "Output only. The state of the batch.", - "enum": [ - "BATCH_STATE_UNSPECIFIED", - "BATCH_STATE_PENDING", - "BATCH_STATE_RUNNING", - "BATCH_STATE_SUCCEEDED", - "BATCH_STATE_FAILED", - "BATCH_STATE_CANCELLED", - "BATCH_STATE_EXPIRED" - ], "readOnly": true, - "x-enum-descriptions": [ - "The batch state is unspecified.", - "The service is preparing to run the batch.", - "The batch is in progress.", - "The batch completed successfully.", - "The batch failed.", - "The batch has been cancelled.", - "The batch has expired." - ] + "description": "Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`." }, - "model": { + "partIndex": { + "type": "integer", + "format": "int32", + "description": "Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`.", + "readOnly": true + } + }, + "description": "Identifier for a part within a `GroundingPassage`.", + "type": "object" + }, + "Maps": { + "type": "object", + "description": "A grounding chunk from Google Maps. A Maps chunk corresponds to a single place.", + "properties": { + "uri": { + "description": "URI reference of the place.", + "type": "string" + }, + "text": { + "description": "Text description of the place answer.", + "type": "string" + }, + "placeId": { + "description": "The ID of the place, in `places/{place_id}` format. A user can use this ID to look up that place.", + "type": "string" + }, + "title": { "type": "string", - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`." + "description": "Title of the place." }, - "inputConfig": { - "description": "Required. Input configuration of the instances on which batch processing are performed.", - "$ref": "#/components/schemas/InputEmbedContentConfig" + "placeAnswerSources": { + "$ref": "#/components/schemas/PlaceAnswerSources", + "description": "Sources that provide answers about the features of a given place in Google Maps." + } + } + }, + "RegisterFilesRequest": { + "type": "object", + "description": "Request for `RegisterFiles`.", + "properties": { + "uris": { + "description": "Required. The Google Cloud Storage URIs to register. Example: `gs://bucket/object`.", + "type": "array", + "items": { + "type": "string" + } + } + } + }, + "VoiceConfig": { + "description": "The configuration for the voice to use.", + "properties": { + "prebuiltVoiceConfig": { + "$ref": "#/components/schemas/PrebuiltVoiceConfig", + "description": "The configuration for the prebuilt voice to use." + } + }, + "type": "object" + }, + "ThinkingConfig": { + "description": "Config for thinking features.", + "properties": { + "includeThoughts": { + "description": "Indicates whether to include thoughts in the response. If true, thoughts are returned only when available.", + "type": "boolean" }, - "batchStats": { - "readOnly": true, - "$ref": "#/components/schemas/EmbedContentBatchStats", - "description": "Output only. Stats about the batch." + "thinkingBudget": { + "description": "The number of thoughts tokens that the model should generate.", + "type": "integer", + "format": "int32" }, - "priority": { - "description": "Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0.", - "format": "int64", - "type": "string" + "thinkingLevel": { + "type": "string", + "x-enum-descriptions": [ + "Default value.", + "Little to no thinking.", + "Low thinking level.", + "Medium thinking level.", + "High thinking level." + ], + "enum": [ + "THINKING_LEVEL_UNSPECIFIED", + "MINIMAL", + "LOW", + "MEDIUM", + "HIGH" + ], + "description": "Optional. Controls the maximum depth of the model's internal reasoning process before it produces a response. If not specified, the default is HIGH. Recommended for Gemini 3 or later models. Use with earlier models results in an error." } }, "type": "object" }, - "LatLng": { - "description": "An object that represents a latitude/longitude pair. This is expressed as a pair of doubles to represent degrees latitude and degrees longitude. Unless specified otherwise, this object must conform to the WGS84 standard. Values must be within normalized ranges.", + "GroundingChunkCustomMetadata": { + "type": "object", "properties": { - "longitude": { - "format": "double", + "stringListValue": { + "description": "Optional. A list of string values for the metadata.", + "$ref": "#/components/schemas/GroundingChunkStringList" + }, + "stringValue": { + "type": "string", + "description": "Optional. The string value of the metadata." + }, + "numericValue": { + "description": "Optional. The numeric value of the metadata. The expected range for this value depends on the specific `key` used.", "type": "number", - "description": "The longitude in degrees. It must be in the range [-180.0, +180.0]." + "format": "float" }, - "latitude": { - "description": "The latitude in degrees. It must be in the range [-90.0, +90.0].", - "format": "double", - "type": "number" + "key": { + "description": "The key of the metadata.", + "type": "string" } }, - "type": "object" + "description": "User provided metadata about the GroundingFact." }, - "EmbedContentResponse": { - "description": "The response to an `EmbedContentRequest`.", + "SemanticRetrieverChunk": { + "description": "Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`.", "properties": { - "embedding": { - "description": "Output only. The embedding generated from the input content.", - "readOnly": true, - "$ref": "#/components/schemas/ContentEmbedding" - }, - "usageMetadata": { + "source": { "readOnly": true, - "$ref": "#/components/schemas/EmbeddingUsageMetadata", - "description": "Output only. The usage metadata for the request." - } - }, - "type": "object" - }, - "TunedModelSource": { - "description": "Tuned model as a source for training a new model.", - "properties": { - "tunedModel": { - "type": "string", - "description": "Immutable. The name of the `TunedModel` to use as the starting point for training the new model. Example: `tunedModels/my-tuned-model`" + "description": "Output only. Name of the source matching the request's `SemanticRetrieverConfig.source`. Example: `corpora/123` or `corpora/123/documents/abc`", + "type": "string" }, - "baseModel": { + "chunk": { + "description": "Output only. Name of the `Chunk` containing the attributed text. Example: `corpora/123/documents/abc/chunks/xyz`", "readOnly": true, - "type": "string", - "description": "Output only. The name of the base `Model` this `TunedModel` was tuned from. Example: `models/gemini-1.5-flash-001`" + "type": "string" } }, "type": "object" }, - "RetrievedContext": { + "Schema": { "type": "object", - "description": "Chunk from context retrieved by the file search tool.", "properties": { - "customMetadata": { - "description": "Optional. User-provided metadata about the retrieved context.", + "propertyOrdering": { + "description": "Optional. The order of the properties. Not a standard field in open api spec. Used to determine the order of the properties in the response.", "type": "array", "items": { - "$ref": "#/components/schemas/GroundingChunkCustomMetadata" + "type": "string" } }, - "uri": { + "pattern": { + "description": "Optional. Pattern of the Type.STRING to restrict a string to a regular expression.", + "type": "string" + }, + "enum": { + "description": "Optional. Possible values of the element of Type.STRING with enum format. For example we can define an Enum Direction as : {type:STRING, format:enum, enum:[\"EAST\", NORTH\", \"SOUTH\", \"WEST\"]}", + "type": "array", + "items": { + "type": "string" + } + }, + "minProperties": { + "description": "Optional. Minimum number of the properties for Type.OBJECT.", "type": "string", - "description": "Optional. URI reference of the semantic retrieval document." + "format": "int64" + }, + "maxLength": { + "description": "Optional. Maximum length of the Type.STRING", + "type": "string", + "format": "int64" + }, + "example": { + "description": "Optional. Example of the object. Will only populated when the object is the root." + }, + "minItems": { + "type": "string", + "format": "int64", + "description": "Optional. Minimum number of the elements for Type.ARRAY." + }, + "minimum": { + "description": "Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER", + "type": "number", + "format": "double" + }, + "anyOf": { + "type": "array", + "items": { + "$ref": "#/components/schemas/Schema" + }, + "description": "Optional. The value should be validated against any (one or more) of the subschemas in the list." }, "title": { - "description": "Optional. Title of the document.", + "description": "Optional. The title of the schema.", "type": "string" }, - "text": { + "maximum": { + "description": "Optional. Maximum value of the Type.INTEGER and Type.NUMBER", + "type": "number", + "format": "double" + }, + "maxItems": { + "description": "Optional. Maximum number of the elements for Type.ARRAY.", "type": "string", - "description": "Optional. Text of the chunk." + "format": "int64" }, - "fileSearchStore": { + "properties": { + "description": "Optional. Properties of Type.OBJECT.", + "type": "object", + "additionalProperties": { + "$ref": "#/components/schemas/Schema" + } + }, + "nullable": { + "type": "boolean", + "description": "Optional. Indicates if the value may be null." + }, + "description": { + "description": "Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown.", + "type": "string" + }, + "maxProperties": { + "description": "Optional. Maximum number of the properties for Type.OBJECT.", "type": "string", - "description": "Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123`" + "format": "int64" + }, + "minLength": { + "description": "Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING", + "type": "string", + "format": "int64" + }, + "items": { + "description": "Optional. Schema of the elements of Type.ARRAY.", + "$ref": "#/components/schemas/Schema" + }, + "required": { + "description": "Optional. Required properties of Type.OBJECT.", + "type": "array", + "items": { + "type": "string" + } + }, + "default": { + "description": "Optional. Default value of the field. Per JSON Schema, this field is intended for documentation generators and doesn't affect validation. Thus it's included here and ignored so that developers who send schemas with a `default` field don't get unknown-field errors." + }, + "type": { + "type": "string", + "x-enum-descriptions": [ + "Not specified, should not be used.", + "String type.", + "Number type.", + "Integer type.", + "Boolean type.", + "Array type.", + "Object type.", + "Null type." + ], + "enum": [ + "TYPE_UNSPECIFIED", + "STRING", + "NUMBER", + "INTEGER", + "BOOLEAN", + "ARRAY", + "OBJECT", + "NULL" + ], + "description": "Required. Data type." + }, + "format": { + "type": "string", + "description": "Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality." } - } + }, + "description": "The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema)." }, - "AttributionSourceId": { - "description": "Identifier for the source contributing to this attribution.", + "CitationMetadata": { + "type": "object", "properties": { - "groundingPassage": { - "description": "Identifier for an inline passage.", - "$ref": "#/components/schemas/GroundingPassageId" - }, - "semanticRetrieverChunk": { - "$ref": "#/components/schemas/SemanticRetrieverChunk", - "description": "Identifier for a `Chunk` fetched via Semantic Retriever." + "citationSources": { + "type": "array", + "items": { + "$ref": "#/components/schemas/CitationSource" + }, + "description": "Citations to sources for a specific response." } }, - "type": "object" + "description": "A collection of source attributions for a piece of content." }, - "GroundingChunk": { + "InlinedRequests": { "type": "object", - "description": "A `GroundingChunk` represents a segment of supporting evidence that grounds the model's response. It can be a chunk from the web, a retrieved context from a file, or information from Google Maps.", + "description": "The requests to be processed in the batch if provided as part of the batch creation request.", "properties": { - "maps": { - "$ref": "#/components/schemas/Maps", - "description": "Optional. Grounding chunk from Google Maps." - }, - "image": { - "description": "Optional. Grounding chunk from image search.", - "$ref": "#/components/schemas/Image" - }, - "web": { - "$ref": "#/components/schemas/Web", - "description": "Grounding chunk from the web." - }, - "retrievedContext": { - "description": "Optional. Grounding chunk from context retrieved by the file search tool.", - "$ref": "#/components/schemas/RetrievedContext" + "requests": { + "type": "array", + "items": { + "$ref": "#/components/schemas/InlinedRequest" + }, + "description": "Required. The requests to be processed in the batch." } } }, - "VideoFileMetadata": { + "GroundingChunkStringList": { + "description": "A list of string values.", + "properties": { + "values": { + "description": "The string values of the list.", + "type": "array", + "items": { + "type": "string" + } + } + }, + "type": "object" + }, + "TuningExamples": { "type": "object", - "description": "Metadata for a video `File`.", + "description": "A set of tuning examples. Can be training or validation data.", "properties": { - "videoDuration": { - "description": "Duration of the video.", - "format": "google-duration", - "type": "string" + "examples": { + "description": "The examples. Example input can be for text or discuss, but all examples in a set must be of the same type.", + "type": "array", + "items": { + "$ref": "#/components/schemas/TuningExample" + } } } }, - "Dataset": { - "description": "Dataset for training or validation.", + "ListCorporaResponse": { + "type": "object", + "description": "Response from `ListCorpora` containing a paginated list of `Corpora`. The results are sorted by ascending `corpus.create_time`.", "properties": { - "examples": { - "$ref": "#/components/schemas/TuningExamples", - "description": "Optional. Inline examples with simple input/output text." + "nextPageToken": { + "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", + "type": "string" + }, + "corpora": { + "description": "The returned corpora.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Corpus" + } } - }, - "type": "object" + } } } }