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 aaae0eb4..6b1d17b9 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 @@ -452,23 +452,23 @@ partial void ProcessBatchesUpdateEmbedContentBatchResponseContent( /// /// /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// /// /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. /// - /// - /// Required. The user-defined name of this batch. - /// - /// - /// Configures the input to the batch request. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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. /// - /// - /// Stats about the batch. + /// + /// Configures the input to the batch request. + /// + /// + /// Required. The user-defined name of this batch. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -476,23 +476,23 @@ partial void ProcessBatchesUpdateEmbedContentBatchResponseContent( public async global::System.Threading.Tasks.Task BatchesUpdateEmbedContentBatchAsync( string batchesId, string? updateMask = default, - global::Google.Gemini.EmbedContentBatchOutput? output = default, - string? displayName = default, - global::Google.Gemini.InputEmbedContentConfig? inputConfig = default, string? model = default, - string? priority = default, + global::Google.Gemini.EmbedContentBatchOutput? output = default, global::Google.Gemini.EmbedContentBatchStats? batchStats = default, + string? priority = default, + global::Google.Gemini.InputEmbedContentConfig? inputConfig = default, + string? displayName = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.EmbedContentBatch { - Output = output, - DisplayName = displayName, - InputConfig = inputConfig, Model = model, - Priority = priority, + Output = output, BatchStats = batchStats, + Priority = priority, + InputConfig = inputConfig, + DisplayName = displayName, }; return await BatchesUpdateEmbedContentBatchAsync( 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 1622abb3..b2f85021 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 @@ -452,23 +452,23 @@ partial void ProcessBatchesUpdateGenerateContentBatchResponseContent( /// /// /// - /// - /// Required. The user-defined name of this batch. - /// - /// - /// Configures the input to the batch request. + /// + /// 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}`. /// - /// - /// 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. /// /// /// 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. + /// + /// Configures the input to the batch request. + /// + /// + /// Required. The user-defined name of this batch. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -476,23 +476,23 @@ partial void ProcessBatchesUpdateGenerateContentBatchResponseContent( public async global::System.Threading.Tasks.Task BatchesUpdateGenerateContentBatchAsync( string batchesId, string? updateMask = default, - string? displayName = default, - global::Google.Gemini.InputConfig? inputConfig = default, - string? model = default, global::Google.Gemini.GenerateContentBatchOutput? output = default, - global::Google.Gemini.BatchStats? batchStats = default, + string? model = default, string? priority = default, + global::Google.Gemini.BatchStats? batchStats = default, + global::Google.Gemini.InputConfig? inputConfig = default, + string? displayName = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentBatch { - DisplayName = displayName, - InputConfig = inputConfig, - Model = model, Output = output, - BatchStats = batchStats, + Model = model, Priority = priority, + BatchStats = batchStats, + InputConfig = inputConfig, + DisplayName = displayName, }; 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 9532e205..e1935b66 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 @@ -429,14 +429,14 @@ partial void ProcessCachedContentsCreateResponseContent( /// /// Creates CachedContent resource. /// - /// - /// Input only. New TTL for this resource, input only. - /// /// /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. /// - /// - /// Optional. Input only. Immutable. The content to cache. + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` @@ -444,45 +444,45 @@ partial void ProcessCachedContentsCreateResponseContent( /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// 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 - /// /// /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// + /// + /// Input only. New TTL for this resource, input only. + /// /// 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? ttl = default, string? displayName = default, - global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, string? model = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - global::System.Collections.Generic.IList? tools = default, string? expireTime = default, + string? ttl = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.CachedContent { - Ttl = ttl, DisplayName = displayName, - Contents = contents, + Tools = tools, + ToolConfig = toolConfig, Model = model, SystemInstruction = systemInstruction, - ToolConfig = toolConfig, + Contents = contents, UsageMetadata = usageMetadata, - Tools = tools, ExpireTime = expireTime, + Ttl = ttl, }; 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 fb82474d..12ee4fce 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 @@ -452,14 +452,14 @@ partial void ProcessCachedContentsPatchResponseContent( /// /// /// - /// - /// Input only. New TTL for this resource, input only. - /// /// /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. /// - /// - /// Optional. Input only. Immutable. The content to cache. + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` @@ -467,47 +467,47 @@ partial void ProcessCachedContentsPatchResponseContent( /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// 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 - /// /// /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// + /// + /// Input only. New TTL for this resource, input only. + /// /// 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 CachedContentsPatchAsync( string cachedContentsId, string? updateMask = default, - string? ttl = default, string? displayName = default, - global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, string? model = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - global::System.Collections.Generic.IList? tools = default, string? expireTime = default, + string? ttl = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.CachedContent { - Ttl = ttl, DisplayName = displayName, - Contents = contents, + Tools = tools, + ToolConfig = toolConfig, Model = model, SystemInstruction = systemInstruction, - ToolConfig = toolConfig, + Contents = contents, UsageMetadata = usageMetadata, - Tools = tools, ExpireTime = expireTime, + Ttl = ttl, }; 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 ac23e3ab..88cb6bcd 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 @@ -439,66 +439,66 @@ 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. 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. - /// - /// - /// 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}` - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// 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. 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. + /// + /// Optional. The service tier of 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// 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. + /// + /// + /// 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. + /// /// 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 DynamicGenerateContentAsync( string dynamicId, - global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.GenerationConfig? generationConfig = default, string? model = default, + global::Google.Gemini.Content? systemInstruction = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + string? cachedContent = default, bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? tools = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Tools = tools, - CachedContent = cachedContent, - ToolConfig = toolConfig, - ServiceTier = serviceTier, - SystemInstruction = systemInstruction, - SafetySettings = safetySettings, - Contents = contents, GenerationConfig = generationConfig, Model = model, + SystemInstruction = systemInstruction, + ServiceTier = serviceTier, + Contents = contents, + CachedContent = cachedContent, Store = store, + SafetySettings = safetySettings, + ToolConfig = toolConfig, + Tools = tools, }; return await DynamicGenerateContentAsync( 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 94fd4142..1b71b9a1 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 @@ -439,66 +439,66 @@ 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. 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. - /// - /// - /// 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}` - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// 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. 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. + /// + /// Optional. The service tier of 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// 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. + /// + /// + /// 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. + /// /// 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 DynamicStreamGenerateContentAsync( string dynamicId, - global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.GenerationConfig? generationConfig = default, string? model = default, + global::Google.Gemini.Content? systemInstruction = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + string? cachedContent = default, bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? tools = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Tools = tools, - CachedContent = cachedContent, - ToolConfig = toolConfig, - ServiceTier = serviceTier, - SystemInstruction = systemInstruction, - SafetySettings = safetySettings, - Contents = contents, GenerationConfig = generationConfig, Model = model, + SystemInstruction = systemInstruction, + ServiceTier = serviceTier, + Contents = contents, + CachedContent = cachedContent, Store = store, + SafetySettings = safetySettings, + ToolConfig = toolConfig, + Tools = tools, }; return await DynamicStreamGenerateContentAsync( 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 8aa9d5f5..7a4efc64 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 @@ -379,66 +379,66 @@ 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. 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. - /// - /// - /// 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}` - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// 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. 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. + /// + /// Optional. The service tier of 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// 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. + /// + /// + /// 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. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Collections.Generic.IAsyncEnumerable DynamicStreamGenerateContentAsStreamAsync( string dynamicId, - global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.GenerationConfig? generationConfig = default, string? model = default, + global::Google.Gemini.Content? systemInstruction = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + string? cachedContent = default, bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? tools = 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 { - Tools = tools, - CachedContent = cachedContent, - ToolConfig = toolConfig, - ServiceTier = serviceTier, - SystemInstruction = systemInstruction, - SafetySettings = safetySettings, - Contents = contents, GenerationConfig = generationConfig, Model = model, + SystemInstruction = systemInstruction, + ServiceTier = serviceTier, + Contents = contents, + CachedContent = cachedContent, Store = store, + SafetySettings = safetySettings, + ToolConfig = toolConfig, + Tools = tools, }; var __enumerable = DynamicStreamGenerateContentAsStreamAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresCreate.g.cs index 22ea3ac6..65037548 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresCreate.g.cs @@ -429,25 +429,25 @@ partial void ProcessFileSearchStoresCreateResponseContent( /// /// Creates an empty `FileSearchStore`. /// - /// - /// 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" - /// /// /// Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used. /// + /// + /// 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" + /// /// 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 FileSearchStoresCreateAsync( - string? displayName = default, string? embeddingModel = default, + string? displayName = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.FileSearchStore { - DisplayName = displayName, EmbeddingModel = embeddingModel, + DisplayName = displayName, }; return await FileSearchStoresCreateAsync( 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 617bc5b6..30bb481f 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 @@ -442,28 +442,28 @@ partial void ProcessFileSearchStoresImportFileResponseContent( /// /// 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. /// + /// + /// Required. The name of the `File` to import. Example: `files/abc-123` + /// /// 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::Google.Gemini.ChunkingConfig? chunkingConfig = default, - string? fileName = default, global::System.Collections.Generic.IList? customMetadata = default, + string? fileName = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.ImportFileRequest { ChunkingConfig = chunkingConfig, - FileName = fileName, CustomMetadata = customMetadata, + FileName = fileName, }; 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 edbdefce..3e25ffb6 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 @@ -439,12 +439,12 @@ partial void ProcessMediaUploadToFileSearchStoreResponseContent( /// Uploads data to a FileSearchStore, preprocesses and chunks before storing it in a FileSearchStore Document. /// /// - /// - /// Optional. Display name of the created document. - /// /// /// Custom metadata to be associated with the data. /// + /// + /// 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 /// @@ -456,8 +456,8 @@ partial void ProcessMediaUploadToFileSearchStoreResponseContent( /// public async global::System.Threading.Tasks.Task MediaUploadToFileSearchStoreAsync( string fileSearchStoresId, - string? displayName = default, global::System.Collections.Generic.IList? customMetadata = default, + string? displayName = default, global::Google.Gemini.ChunkingConfig? chunkingConfig = default, string? mimeType = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, @@ -465,8 +465,8 @@ partial void ProcessMediaUploadToFileSearchStoreResponseContent( { var __request = new global::Google.Gemini.UploadToFileSearchStoreRequest { - DisplayName = displayName, CustomMetadata = customMetadata, + DisplayName = displayName, ChunkingConfig = chunkingConfig, MimeType = mimeType, }; 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 393af29e..d9ef85ef 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 @@ -444,28 +444,28 @@ partial void ProcessModelsEmbedContentResponseContent( /// /// 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 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}` - /// /// /// Configurations for the EmbedContent request. /// + /// + /// 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}` + /// /// 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 ModelsEmbedContentAsync( string modelsId, global::Google.Gemini.Content? content = default, - string? model = default, global::Google.Gemini.EmbedContentConfig? embedContentConfig = default, + string? model = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.EmbedContentRequest { Content = content, - Model = model, EmbedContentConfig = embedContentConfig, + Model = model, }; return await ModelsEmbedContentAsync( 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 d317ec31..b56c3ce1 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 @@ -439,66 +439,66 @@ 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. 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. - /// - /// - /// 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}` - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// 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. 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. + /// + /// Optional. The service tier of 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// 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. + /// + /// + /// 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. + /// /// 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 ModelsGenerateContentAsync( string modelsId, - global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.GenerationConfig? generationConfig = default, string? model = default, + global::Google.Gemini.Content? systemInstruction = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + string? cachedContent = default, bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? tools = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Tools = tools, - CachedContent = cachedContent, - ToolConfig = toolConfig, - ServiceTier = serviceTier, - SystemInstruction = systemInstruction, - SafetySettings = safetySettings, - Contents = contents, GenerationConfig = generationConfig, Model = model, + SystemInstruction = systemInstruction, + ServiceTier = serviceTier, + Contents = contents, + CachedContent = cachedContent, Store = store, + SafetySettings = safetySettings, + ToolConfig = toolConfig, + Tools = tools, }; return await ModelsGenerateContentAsync( 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 84b8cd08..f17deec7 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 @@ -439,66 +439,66 @@ 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. 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. - /// - /// - /// 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}` - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// 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. 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. + /// + /// Optional. The service tier of 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// 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. + /// + /// + /// 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. + /// /// 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 ModelsStreamGenerateContentAsync( string modelsId, - global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.GenerationConfig? generationConfig = default, string? model = default, + global::Google.Gemini.Content? systemInstruction = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + string? cachedContent = default, bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? tools = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Tools = tools, - CachedContent = cachedContent, - ToolConfig = toolConfig, - ServiceTier = serviceTier, - SystemInstruction = systemInstruction, - SafetySettings = safetySettings, - Contents = contents, GenerationConfig = generationConfig, Model = model, + SystemInstruction = systemInstruction, + ServiceTier = serviceTier, + Contents = contents, + CachedContent = cachedContent, Store = store, + SafetySettings = safetySettings, + ToolConfig = toolConfig, + Tools = tools, }; return await ModelsStreamGenerateContentAsync( 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 e8022028..102c727c 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 @@ -379,66 +379,66 @@ 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. 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. - /// - /// - /// 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}` - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// 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. 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. + /// + /// Optional. The service tier of 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// 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. + /// + /// + /// 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. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Collections.Generic.IAsyncEnumerable ModelsStreamGenerateContentAsStreamAsync( string modelsId, - global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.GenerationConfig? generationConfig = default, string? model = default, + global::Google.Gemini.Content? systemInstruction = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + string? cachedContent = default, bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? tools = 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 { - Tools = tools, - CachedContent = cachedContent, - ToolConfig = toolConfig, - ServiceTier = serviceTier, - SystemInstruction = systemInstruction, - SafetySettings = safetySettings, - Contents = contents, GenerationConfig = generationConfig, Model = model, + SystemInstruction = systemInstruction, + ServiceTier = serviceTier, + Contents = contents, + CachedContent = cachedContent, Store = store, + SafetySettings = safetySettings, + ToolConfig = toolConfig, + Tools = tools, }; var __enumerable = ModelsStreamGenerateContentAsStreamAsync( 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 f3e719c2..258810af 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 @@ -442,61 +442,61 @@ 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 /// /// + /// + /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// /// /// Tuned model as a source for training a new 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. A short description of this model. /// /// /// 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. 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. List of project numbers that have read access to the tuned model. /// - /// - /// Optional. A short description of this model. - /// - /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` - /// /// /// 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. + /// + /// + /// 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. + /// /// 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, + string? baseModel = default, global::Google.Gemini.TunedModelSource? tunedModelSource = default, - float? topP = default, - global::Google.Gemini.TuningTask? tuningTask = default, + string? description = default, int? topK = default, - float? temperature = default, global::System.Collections.Generic.IList? readerProjectNumbers = default, - string? description = default, - string? baseModel = default, string? displayName = default, + float? temperature = default, + float? topP = default, + global::Google.Gemini.TuningTask? tuningTask = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.TunedModel { + BaseModel = baseModel, TunedModelSource = tunedModelSource, - TopP = topP, - TuningTask = tuningTask, + Description = description, TopK = topK, - Temperature = temperature, ReaderProjectNumbers = readerProjectNumbers, - Description = description, - BaseModel = baseModel, DisplayName = displayName, + Temperature = temperature, + TopP = topP, + TuningTask = tuningTask, }; 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 8ae6da1b..15cd3ed3 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 @@ -439,66 +439,66 @@ 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. 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. - /// - /// - /// 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}` - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// 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. 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. + /// + /// Optional. The service tier of 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// 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. + /// + /// + /// 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. + /// /// 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 TunedModelsGenerateContentAsync( string tunedModelsId, - global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.GenerationConfig? generationConfig = default, string? model = default, + global::Google.Gemini.Content? systemInstruction = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + string? cachedContent = default, bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? tools = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Tools = tools, - CachedContent = cachedContent, - ToolConfig = toolConfig, - ServiceTier = serviceTier, - SystemInstruction = systemInstruction, - SafetySettings = safetySettings, - Contents = contents, GenerationConfig = generationConfig, Model = model, + SystemInstruction = systemInstruction, + ServiceTier = serviceTier, + Contents = contents, + CachedContent = cachedContent, Store = store, + SafetySettings = safetySettings, + ToolConfig = toolConfig, + Tools = tools, }; return await TunedModelsGenerateContentAsync( 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 9814a1d6..81873ee4 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 @@ -452,62 +452,62 @@ partial void ProcessTunedModelsPatchResponseContent( /// /// /// + /// + /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// /// /// Tuned model as a source for training a new 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. A short description of this model. /// /// /// 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. 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. List of project numbers that have read access to the tuned model. /// - /// - /// Optional. A short description of this model. - /// - /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` - /// /// /// 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. + /// + /// + /// 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. + /// /// 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 TunedModelsPatchAsync( string tunedModelsId, string? updateMask = default, + string? baseModel = default, global::Google.Gemini.TunedModelSource? tunedModelSource = default, - float? topP = default, - global::Google.Gemini.TuningTask? tuningTask = default, + string? description = default, int? topK = default, - float? temperature = default, global::System.Collections.Generic.IList? readerProjectNumbers = default, - string? description = default, - string? baseModel = default, string? displayName = default, + float? temperature = default, + float? topP = default, + global::Google.Gemini.TuningTask? tuningTask = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.TunedModel { + BaseModel = baseModel, TunedModelSource = tunedModelSource, - TopP = topP, - TuningTask = tuningTask, + Description = description, TopK = topK, - Temperature = temperature, ReaderProjectNumbers = readerProjectNumbers, - Description = description, - BaseModel = baseModel, DisplayName = displayName, + Temperature = temperature, + TopP = topP, + TuningTask = tuningTask, }; 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 15da48fa..8d166a17 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 @@ -439,66 +439,66 @@ 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. 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. - /// - /// - /// 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}` - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// 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. 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. + /// + /// Optional. The service tier of 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// 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. + /// + /// + /// 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. + /// /// 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 TunedModelsStreamGenerateContentAsync( string tunedModelsId, - global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.GenerationConfig? generationConfig = default, string? model = default, + global::Google.Gemini.Content? systemInstruction = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + string? cachedContent = default, bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? tools = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Tools = tools, - CachedContent = cachedContent, - ToolConfig = toolConfig, - ServiceTier = serviceTier, - SystemInstruction = systemInstruction, - SafetySettings = safetySettings, - Contents = contents, GenerationConfig = generationConfig, Model = model, + SystemInstruction = systemInstruction, + ServiceTier = serviceTier, + Contents = contents, + CachedContent = cachedContent, Store = store, + SafetySettings = safetySettings, + ToolConfig = toolConfig, + Tools = tools, }; return await TunedModelsStreamGenerateContentAsync( 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 d1291baf..05589609 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 @@ -379,66 +379,66 @@ 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. 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. - /// - /// - /// 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}` - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// 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. 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. + /// + /// Optional. The service tier of 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// 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. + /// + /// + /// 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. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Collections.Generic.IAsyncEnumerable TunedModelsStreamGenerateContentAsStreamAsync( string tunedModelsId, - global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.GenerationConfig? generationConfig = default, string? model = default, + global::Google.Gemini.Content? systemInstruction = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + string? cachedContent = default, bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? tools = 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 { - Tools = tools, - CachedContent = cachedContent, - ToolConfig = toolConfig, - ServiceTier = serviceTier, - SystemInstruction = systemInstruction, - SafetySettings = safetySettings, - Contents = contents, GenerationConfig = generationConfig, Model = model, + SystemInstruction = systemInstruction, + ServiceTier = serviceTier, + Contents = contents, + CachedContent = cachedContent, Store = store, + SafetySettings = safetySettings, + ToolConfig = toolConfig, + Tools = tools, }; var __enumerable = TunedModelsStreamGenerateContentAsStreamAsync( 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 63783338..007c62da 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 @@ -41,23 +41,23 @@ public partial interface IGeminiClient /// /// /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// /// /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. /// - /// - /// Required. The user-defined name of this batch. - /// - /// - /// Configures the input to the batch request. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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. /// - /// - /// Stats about the batch. + /// + /// Configures the input to the batch request. + /// + /// + /// Required. The user-defined name of this batch. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -65,12 +65,12 @@ public partial interface IGeminiClient global::System.Threading.Tasks.Task BatchesUpdateEmbedContentBatchAsync( string batchesId, string? updateMask = default, - global::Google.Gemini.EmbedContentBatchOutput? output = default, - string? displayName = default, - global::Google.Gemini.InputEmbedContentConfig? inputConfig = default, string? model = default, - string? priority = default, + global::Google.Gemini.EmbedContentBatchOutput? output = default, global::Google.Gemini.EmbedContentBatchStats? batchStats = default, + string? priority = default, + global::Google.Gemini.InputEmbedContentConfig? inputConfig = 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.BatchesUpdateGenerateContentBatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.BatchesUpdateGenerateContentBatch.g.cs index e411a741..f37e441e 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 @@ -41,23 +41,23 @@ public partial interface IGeminiClient /// /// /// - /// - /// Required. The user-defined name of this batch. - /// - /// - /// Configures the input to the batch request. + /// + /// 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}`. /// - /// - /// 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. /// /// /// 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. + /// + /// Configures the input to the batch request. + /// + /// + /// Required. The user-defined name of this batch. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -65,12 +65,12 @@ public partial interface IGeminiClient global::System.Threading.Tasks.Task BatchesUpdateGenerateContentBatchAsync( string batchesId, string? updateMask = default, - string? displayName = default, - global::Google.Gemini.InputConfig? inputConfig = default, - string? model = default, global::Google.Gemini.GenerateContentBatchOutput? output = default, - global::Google.Gemini.BatchStats? batchStats = default, + string? model = default, string? priority = default, + global::Google.Gemini.BatchStats? batchStats = default, + global::Google.Gemini.InputConfig? inputConfig = 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.CachedContentsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsCreate.g.cs index 33b40fc2..9b90c91f 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 @@ -31,14 +31,14 @@ public partial interface IGeminiClient /// /// Creates CachedContent resource. /// - /// - /// Input only. New TTL for this resource, input only. - /// /// /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. /// - /// - /// Optional. Input only. Immutable. The content to cache. + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` @@ -46,31 +46,31 @@ public partial interface IGeminiClient /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// 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 - /// /// /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// + /// + /// Input only. New TTL for this resource, input only. + /// /// 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? ttl = default, string? displayName = default, - global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, string? model = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - global::System.Collections.Generic.IList? tools = default, string? expireTime = default, + string? ttl = 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 26b1b6ad..da24dea4 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 @@ -41,14 +41,14 @@ public partial interface IGeminiClient /// /// /// - /// - /// Input only. New TTL for this resource, input only. - /// /// /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. /// - /// - /// Optional. Input only. Immutable. The content to cache. + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` @@ -56,33 +56,33 @@ public partial interface IGeminiClient /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// 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 - /// /// /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// + /// + /// Input only. New TTL for this resource, input only. + /// /// 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 CachedContentsPatchAsync( string cachedContentsId, string? updateMask = default, - string? ttl = default, string? displayName = default, - global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, string? model = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - global::System.Collections.Generic.IList? tools = default, string? expireTime = default, + string? ttl = 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 1d2243e7..4ab4f759 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 @@ -36,51 +36,51 @@ 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. 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. - /// - /// - /// 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}` - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// 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. 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. + /// + /// Optional. The service tier of 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// 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. + /// + /// + /// 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. + /// /// 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 DynamicGenerateContentAsync( string dynamicId, - global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.GenerationConfig? generationConfig = default, string? model = default, + global::Google.Gemini.Content? systemInstruction = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + string? cachedContent = default, bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? tools = 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 446cd8e0..7b7d2de3 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 @@ -36,51 +36,51 @@ 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. 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. - /// - /// - /// 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}` - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// 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. 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. + /// + /// Optional. The service tier of 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// 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. + /// + /// + /// 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. + /// /// 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 DynamicStreamGenerateContentAsync( string dynamicId, - global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.GenerationConfig? generationConfig = default, string? model = default, + global::Google.Gemini.Content? systemInstruction = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + string? cachedContent = default, bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? tools = 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 05f5e629..8b2a7126 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,51 +22,51 @@ 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. 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. - /// - /// - /// 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}` - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// 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. 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. + /// + /// Optional. The service tier of 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// 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. + /// + /// + /// 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. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Collections.Generic.IAsyncEnumerable DynamicStreamGenerateContentAsStreamAsync( string dynamicId, - global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.GenerationConfig? generationConfig = default, string? model = default, + global::Google.Gemini.Content? systemInstruction = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + string? cachedContent = default, bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? tools = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresCreate.g.cs index 9edab07f..456dc9c7 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresCreate.g.cs @@ -31,18 +31,18 @@ public partial interface IGeminiClient /// /// Creates an empty `FileSearchStore`. /// - /// - /// 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" - /// /// /// Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used. /// + /// + /// 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" + /// /// 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 FileSearchStoresCreateAsync( - string? displayName = default, string? embeddingModel = 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.FileSearchStoresImportFile.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresImportFile.g.cs index 44182be1..0b601d4b 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 @@ -39,20 +39,20 @@ public partial interface IGeminiClient /// /// 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. /// + /// + /// Required. The name of the `File` to import. Example: `files/abc-123` + /// /// 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::Google.Gemini.ChunkingConfig? chunkingConfig = default, - string? fileName = default, global::System.Collections.Generic.IList? customMetadata = default, + string? fileName = 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 490b5361..7056e937 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 @@ -36,12 +36,12 @@ public partial interface IGeminiClient /// Uploads data to a FileSearchStore, preprocesses and chunks before storing it in a FileSearchStore Document. /// /// - /// - /// Optional. Display name of the created document. - /// /// /// Custom metadata to be associated with the data. /// + /// + /// 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 /// @@ -53,8 +53,8 @@ public partial interface IGeminiClient /// global::System.Threading.Tasks.Task MediaUploadToFileSearchStoreAsync( string fileSearchStoresId, - string? displayName = default, global::System.Collections.Generic.IList? customMetadata = default, + string? displayName = default, global::Google.Gemini.ChunkingConfig? chunkingConfig = default, string? mimeType = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = 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 c9ec1671..a0ce1945 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 @@ -41,20 +41,20 @@ public partial interface IGeminiClient /// /// 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 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}` - /// /// /// Configurations for the EmbedContent request. /// + /// + /// 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}` + /// /// 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 ModelsEmbedContentAsync( string modelsId, global::Google.Gemini.Content? content = default, - string? model = default, global::Google.Gemini.EmbedContentConfig? embedContentConfig = default, + string? model = 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 7469c45e..8dc0eef0 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 @@ -36,51 +36,51 @@ 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. 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. - /// - /// - /// 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}` - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// 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. 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. + /// + /// Optional. The service tier of 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// 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. + /// + /// + /// 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. + /// /// 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 ModelsGenerateContentAsync( string modelsId, - global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.GenerationConfig? generationConfig = default, string? model = default, + global::Google.Gemini.Content? systemInstruction = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + string? cachedContent = default, bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? tools = 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 3771ae0c..3167b43d 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 @@ -36,51 +36,51 @@ 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. 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. - /// - /// - /// 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}` - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// 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. 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. + /// + /// Optional. The service tier of 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// 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. + /// + /// + /// 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. + /// /// 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 ModelsStreamGenerateContentAsync( string modelsId, - global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.GenerationConfig? generationConfig = default, string? model = default, + global::Google.Gemini.Content? systemInstruction = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + string? cachedContent = default, bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? tools = 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 28976af1..bfe194a1 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,51 +22,51 @@ 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. 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. - /// - /// - /// 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}` - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// 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. 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. + /// + /// Optional. The service tier of 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// 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. + /// + /// + /// 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. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Collections.Generic.IAsyncEnumerable ModelsStreamGenerateContentAsStreamAsync( string modelsId, - global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.GenerationConfig? generationConfig = default, string? model = default, + global::Google.Gemini.Content? systemInstruction = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + string? cachedContent = default, bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? tools = 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 5d2f382f..53575520 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 @@ -36,47 +36,47 @@ 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 /// /// + /// + /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// /// /// Tuned model as a source for training a new 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. A short description of this model. /// /// /// 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. 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. List of project numbers that have read access to the tuned model. /// - /// - /// Optional. A short description of this model. - /// - /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` - /// /// /// 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. + /// + /// + /// 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. + /// /// 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, + string? baseModel = default, global::Google.Gemini.TunedModelSource? tunedModelSource = default, - float? topP = default, - global::Google.Gemini.TuningTask? tuningTask = default, + string? description = default, int? topK = default, - float? temperature = default, global::System.Collections.Generic.IList? readerProjectNumbers = default, - string? description = default, - string? baseModel = default, string? displayName = default, + float? temperature = default, + float? topP = default, + global::Google.Gemini.TuningTask? tuningTask = 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 6fef079c..74960708 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 @@ -36,51 +36,51 @@ 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. 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. - /// - /// - /// 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}` - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// 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. 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. + /// + /// Optional. The service tier of 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// 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. + /// + /// + /// 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. + /// /// 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 TunedModelsGenerateContentAsync( string tunedModelsId, - global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.GenerationConfig? generationConfig = default, string? model = default, + global::Google.Gemini.Content? systemInstruction = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + string? cachedContent = default, bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? tools = 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 3635ea44..ae087bf7 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 @@ -41,48 +41,48 @@ public partial interface IGeminiClient /// /// /// + /// + /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// /// /// Tuned model as a source for training a new 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. A short description of this model. /// /// /// 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. 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. List of project numbers that have read access to the tuned model. /// - /// - /// Optional. A short description of this model. - /// - /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` - /// /// /// 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. + /// + /// + /// 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. + /// /// 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 TunedModelsPatchAsync( string tunedModelsId, string? updateMask = default, + string? baseModel = default, global::Google.Gemini.TunedModelSource? tunedModelSource = default, - float? topP = default, - global::Google.Gemini.TuningTask? tuningTask = default, + string? description = default, int? topK = default, - float? temperature = default, global::System.Collections.Generic.IList? readerProjectNumbers = default, - string? description = default, - string? baseModel = default, string? displayName = default, + float? temperature = default, + float? topP = default, + global::Google.Gemini.TuningTask? tuningTask = 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 93612960..878b114c 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 @@ -36,51 +36,51 @@ 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. 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. - /// - /// - /// 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}` - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// 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. 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. + /// + /// Optional. The service tier of 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// 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. + /// + /// + /// 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. + /// /// 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 TunedModelsStreamGenerateContentAsync( string tunedModelsId, - global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.GenerationConfig? generationConfig = default, string? model = default, + global::Google.Gemini.Content? systemInstruction = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + string? cachedContent = default, bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? tools = 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 d18f5faf..a09dbf6f 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,51 +22,51 @@ 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. 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. - /// - /// - /// 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}` - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// 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. 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. + /// + /// Optional. The service tier of 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// 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. + /// + /// + /// 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. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Collections.Generic.IAsyncEnumerable TunedModelsStreamGenerateContentAsStreamAsync( string tunedModelsId, - global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.GenerationConfig? generationConfig = default, string? model = default, + global::Google.Gemini.Content? systemInstruction = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + string? cachedContent = default, bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? tools = 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 2e97ec84..5b4763ce 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContext.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContext.g.cs @@ -13,430 +13,430 @@ namespace Google.Gemini DefaultIgnoreCondition = global::System.Text.Json.Serialization.JsonIgnoreCondition.WhenWritingNull, Converters = new global::System.Type[] { - typeof(global::Google.Gemini.JsonConverters.FileStateJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.FileStateNullableJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.FileSourceJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.FileSourceNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentJsonConverter), typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SchemaTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SchemaTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateJsonConverter), typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionRoleJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SchemaTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionRoleNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SchemaTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DocumentStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DocumentStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieJsonConverter), + typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileSourceJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileSourceNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DocumentStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DocumentStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.TunedModelStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelJsonConverter), - typeof(global::Google.Gemini.JsonConverters.TunedModelStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityJsonConverter), - typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorJsonConverter), + typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonJsonConverter), + typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingJsonConverter), - typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierJsonConverter), + typeof(global::Google.Gemini.JsonConverters.TunedModelStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.TunedModelStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PermissionRoleJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PermissionRoleNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeNullableJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeNullableJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityNullableJsonConverter), 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.WhiteSpaceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(int))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InputConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LogprobsResultCandidate))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(string))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedRequests))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.File))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(byte[]))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileState), TypeInfoPropertyName = "FileState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Status))] - [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::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(object))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(int))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(float))] + [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.ComputerUse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUseEnvironment), TypeInfoPropertyName = "ComputerUseEnvironment2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SearchTypes))] - [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.LogprobsResult))] - [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(float))] - [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.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.RetrievalMetadata))] - [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(global::Google.Gemini.InlinedRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentRequest))] - [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.Schema))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SchemaType), TypeInfoPropertyName = "SchemaType2")] - [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::System.Collections.Generic.Dictionary))] - [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.ListOperationsResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Operation))] - [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::Google.Gemini.TuningExample))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Empty))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUseEnvironment), TypeInfoPropertyName = "ComputerUseEnvironment2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Corpus))] + [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.EmbedContentBatchStats))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InputEmbedContentConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchState), TypeInfoPropertyName = "EmbedContentBatchState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CitationSource))] + [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.GoogleMaps))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlContext))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleSearchRetrieval))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecution))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleSearch))] + [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.GenerateContentBatch))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatchOutput))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchStats))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatchState), TypeInfoPropertyName = "GenerateContentBatchState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkStringList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InputConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VideoFileMetadata))] + [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.UploadToFileSearchStoreRequest))] + [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.ChunkingConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfig))] [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.Part))] - [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.ExecutableCode))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCodeLanguage), TypeInfoPropertyName = "ExecutableCodeLanguage2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileResponse))] - [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.Dataset))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Permission))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PermissionRole), TypeInfoPropertyName = "PermissionRole2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PermissionGranteeType), TypeInfoPropertyName = "PermissionGranteeType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponseToolType), TypeInfoPropertyName = "ToolResponseToolType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchOutput))] - [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.GeneratedFile))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GeneratedFileState), TypeInfoPropertyName = "GeneratedFileState2")] - [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.UrlMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievalConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCallingConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleMaps))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesResponse))] - [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.ContentEmbedding))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbeddingUsageMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AsyncBatchEmbedContentRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingPassageId))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipRequest))] - [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.CodeExecutionResult))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCall))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VideoMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Blob))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileData))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCall))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecution))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkCustomMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LatLng))] - [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.Web))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.McpServer))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListFilesResponse))] - [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.GenerationConfig))] - [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.ThinkingConfig))] - [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.Model))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CustomLongRunningOperation))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCallToolType), TypeInfoPropertyName = "ToolCallToolType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchGenerateContentRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport))] + [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(bool))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetySetting))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkStringList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CountTokensRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VoiceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PrebuiltVoiceConfig))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ContentEmbedding))] [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.RetrievedContext))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.WhiteSpaceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Web))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Schema))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(double))] + [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(object))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlMetadataUrlRetrievalStatus), TypeInfoPropertyName = "UrlMetadataUrlRetrievalStatus2")] + [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.RetrievalMetadata))] + [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.GoogleAiGenerativelanguageV1betaGroundingSupport))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Document))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DocumentState), TypeInfoPropertyName = "DocumentState2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Image))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCall))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionDeclarationBehavior), TypeInfoPropertyName = "FunctionDeclarationBehavior2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CustomLongRunningOperation))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Status))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Operation))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Blob))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(byte[]))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievalConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LatLng))] [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.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.ModalityTokenCount))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModalityTokenCountModality), TypeInfoPropertyName = "ModalityTokenCountModality2")] - [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.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.CustomMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.StringList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PlaceAnswerSources))] - [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.EmbedContentBatchState), TypeInfoPropertyName = "EmbedContentBatchState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Tool))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleSearchRetrieval))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleSearch))] - [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.FileSearch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlContext))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UploadToFileSearchStoreRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ChunkingConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DynamicRetrievalConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DynamicRetrievalConfigMode), TypeInfoPropertyName = "DynamicRetrievalConfigMode2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentRequestTaskType), TypeInfoPropertyName = "EmbedContentRequestTaskType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SearchEntryPoint))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileRequest))] - [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.FunctionCallingConfigMode), TypeInfoPropertyName = "FunctionCallingConfigMode2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DocumentState), TypeInfoPropertyName = "DocumentState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Interval))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModelSource))] - [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.CachedContentUsageMetadata))] - [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.TuningTask))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModelState), TypeInfoPropertyName = "TunedModelState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Hyperparameters))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingAttribution))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [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.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.SafetySetting))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Candidate))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingMetadata))] [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.SafetyRating))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingAttribution))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LogprobsResult))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CitationMetadata))] + [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::Google.Gemini.ReviewSnippet))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SearchEntryPoint))] + [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.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.TransferOwnershipRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VideoMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedRequest))] + [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.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::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedback))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSearchStore))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.File))] + [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.BatchEmbedContentsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbeddingUsageMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningSnapshot))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.WebSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningExample))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SpeechConfig))] + [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.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.GeneratedFile))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GeneratedFileState), TypeInfoPropertyName = "GeneratedFileState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImportFileRequest))] + [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.StringList))] + [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.SafetySettingCategory), TypeInfoPropertyName = "SafetySettingCategory2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetySettingThreshold), TypeInfoPropertyName = "SafetySettingThreshold2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionDeclarationBehavior), TypeInfoPropertyName = "FunctionDeclarationBehavior2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedback))] + [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.StreamableHttpTransport))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.Dictionary))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageSearch))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedbackBlockReason), TypeInfoPropertyName = "PromptFeedbackBlockReason2")] - [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.UrlMetadataUrlRetrievalStatus), TypeInfoPropertyName = "UrlMetadataUrlRetrievalStatus2")] - [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.ImportFileRequest))] - [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.InlinedRequests))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Interval))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ThinkingConfig))] + [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.ImageConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfigMediaResolution), TypeInfoPropertyName = "GenerationConfigMediaResolution2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Model))] + [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.Part))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCode))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResult))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileData))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCall))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SearchTypes))] + [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.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.ThinkingConfigThinkingLevel), TypeInfoPropertyName = "ThinkingConfigThinkingLevel2")] - [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.SafetyRatingCategory), TypeInfoPropertyName = "SafetyRatingCategory2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetyRatingProbability), TypeInfoPropertyName = "SafetyRatingProbability2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningTask))] + [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.SpeakerVoiceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CountTokensRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CountTokensResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Empty))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatusModelStage), TypeInfoPropertyName = "ModelStatusModelStage2")] + [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.TunedModelSource))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCodeLanguage), TypeInfoPropertyName = "ExecutableCodeLanguage2")] + [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.CodeExecutionResultOutcome), TypeInfoPropertyName = "CodeExecutionResultOutcome2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningSnapshot))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UsageMetadataServiceTier), TypeInfoPropertyName = "UsageMetadataServiceTier2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentConfig))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentConfigTaskType), TypeInfoPropertyName = "EmbedContentConfigTaskType2")] + [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.DynamicRetrievalConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DynamicRetrievalConfigMode), TypeInfoPropertyName = "DynamicRetrievalConfigMode2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileRequest))] + [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.ListFilesResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponseToolType), TypeInfoPropertyName = "ToolResponseToolType2")] + [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::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.UsageMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UsageMetadataServiceTier), TypeInfoPropertyName = "UsageMetadataServiceTier2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatus))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatusModelStage), TypeInfoPropertyName = "ModelStatusModelStage2")] - [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::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::Google.Gemini.TunedModelState), TypeInfoPropertyName = "TunedModelState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PermissionRole), TypeInfoPropertyName = "PermissionRole2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PermissionGranteeType), TypeInfoPropertyName = "PermissionGranteeType2")] + [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::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.TopCandidates))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [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.ToolCallToolType), TypeInfoPropertyName = "ToolCallToolType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentRequestTaskType), TypeInfoPropertyName = "EmbedContentRequestTaskType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModalityTokenCountModality), TypeInfoPropertyName = "ModalityTokenCountModality2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentResponse))] + [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::Google.Gemini.BatchGenerateContentRequest))] + [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::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 14fdd263..44ee2078 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContextTypes.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContextTypes.g.cs @@ -28,952 +28,952 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - public global::Google.Gemini.WhiteSpaceConfig? Type0 { get; set; } + public global::Google.Gemini.LogprobsResultCandidate? Type0 { get; set; } /// /// /// - public int? Type1 { get; set; } + public string? Type1 { get; set; } /// /// /// - public global::Google.Gemini.InputConfig? Type2 { get; set; } + public int? Type2 { get; set; } /// /// /// - public string? Type3 { get; set; } + public float? Type3 { get; set; } /// /// /// - public global::Google.Gemini.InlinedRequests? Type4 { get; set; } + public global::Google.Gemini.UrlContextMetadata? Type4 { get; set; } /// /// /// - public global::Google.Gemini.File? Type5 { get; set; } + public global::System.Collections.Generic.IList? Type5 { get; set; } /// /// /// - public byte[]? Type6 { get; set; } + public global::Google.Gemini.UrlMetadata? Type6 { get; set; } /// /// /// - public global::Google.Gemini.FileState? Type7 { get; set; } + public global::Google.Gemini.ComputerUse? Type7 { get; set; } /// /// /// - public global::Google.Gemini.Status? Type8 { get; set; } + public global::System.Collections.Generic.IList? Type8 { get; set; } /// /// /// - public global::Google.Gemini.VideoFileMetadata? Type9 { get; set; } + public global::Google.Gemini.ComputerUseEnvironment? Type9 { get; set; } /// /// /// - public global::Google.Gemini.FileSource? Type10 { get; set; } + public global::Google.Gemini.Corpus? Type10 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type11 { get; set; } + public global::Google.Gemini.EmbedContentBatch? Type11 { get; set; } /// /// /// - public object? Type12 { get; set; } + public global::Google.Gemini.EmbedContentBatchOutput? Type12 { get; set; } /// /// /// - public global::Google.Gemini.ComputerUse? Type13 { get; set; } + public global::Google.Gemini.EmbedContentBatchStats? Type13 { get; set; } /// /// /// - public global::Google.Gemini.ComputerUseEnvironment? Type14 { get; set; } + public global::Google.Gemini.InputEmbedContentConfig? Type14 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type15 { get; set; } + public global::Google.Gemini.EmbedContentBatchState? Type15 { get; set; } /// /// /// - public global::Google.Gemini.SearchTypes? Type16 { get; set; } + public global::Google.Gemini.CitationSource? Type16 { get; set; } /// /// /// - public global::Google.Gemini.WebSearch? Type17 { get; set; } + public global::Google.Gemini.Tool? Type17 { get; set; } /// /// /// - public global::Google.Gemini.ImageSearch? Type18 { get; set; } + public global::System.Collections.Generic.IList? Type18 { get; set; } /// /// /// - public global::Google.Gemini.LogprobsResult? Type19 { get; set; } + public global::Google.Gemini.FunctionDeclaration? Type19 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type20 { get; set; } + public global::Google.Gemini.GoogleMaps? Type20 { get; set; } /// /// /// - public global::Google.Gemini.LogprobsResultCandidate? Type21 { get; set; } + public global::Google.Gemini.FileSearch? Type21 { get; set; } /// /// /// - public float? Type22 { get; set; } + public global::Google.Gemini.UrlContext? Type22 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type23 { get; set; } + public global::Google.Gemini.GoogleSearchRetrieval? Type23 { get; set; } /// /// /// - public global::Google.Gemini.TopCandidates? Type24 { get; set; } + public global::Google.Gemini.CodeExecution? Type24 { get; set; } /// /// /// - public global::Google.Gemini.SpeechConfig? Type25 { get; set; } + public global::Google.Gemini.GoogleSearch? Type25 { get; set; } /// /// /// - public global::Google.Gemini.VoiceConfig? Type26 { get; set; } + public global::System.Collections.Generic.IList? Type26 { get; set; } /// /// /// - public global::Google.Gemini.MultiSpeakerVoiceConfig? Type27 { get; set; } + public global::Google.Gemini.McpServer? Type27 { get; set; } /// /// /// - public global::Google.Gemini.RetrievalMetadata? Type28 { get; set; } + public global::Google.Gemini.GenerateContentBatch? Type28 { get; set; } /// /// /// - public global::Google.Gemini.StreamableHttpTransport? Type29 { get; set; } + public global::Google.Gemini.GenerateContentBatchOutput? Type29 { get; set; } /// /// /// - public bool? Type30 { get; set; } + public global::Google.Gemini.BatchStats? Type30 { get; set; } /// /// /// - public global::System.Collections.Generic.Dictionary? Type31 { get; set; } + public global::Google.Gemini.GenerateContentBatchState? Type31 { get; set; } /// /// /// - public global::Google.Gemini.InlinedRequest? Type32 { get; set; } + public global::Google.Gemini.InputConfig? Type32 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentRequest? Type33 { get; set; } + public global::Google.Gemini.VideoFileMetadata? Type33 { get; set; } /// /// /// - public global::Google.Gemini.ListFileSearchStoresResponse? Type34 { get; set; } + public global::Google.Gemini.ListTunedModelsResponse? Type34 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type35 { get; set; } + public global::System.Collections.Generic.IList? Type35 { get; set; } /// /// /// - public global::Google.Gemini.FileSearchStore? Type36 { get; set; } + public global::Google.Gemini.TunedModel? Type36 { get; set; } /// /// /// - public global::Google.Gemini.Schema? Type37 { get; set; } + public global::Google.Gemini.UploadToFileSearchStoreRequest? Type37 { get; set; } /// /// /// - public global::Google.Gemini.SchemaType? Type38 { get; set; } + public global::System.Collections.Generic.IList? Type38 { get; set; } /// /// /// - public double? Type39 { get; set; } + public global::Google.Gemini.CustomMetadata? Type39 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type40 { get; set; } + public global::Google.Gemini.ChunkingConfig? Type40 { get; set; } /// /// /// - public global::System.Collections.Generic.Dictionary? Type41 { get; set; } + public global::Google.Gemini.GenerateContentRequest? Type41 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponsePart? Type42 { get; set; } + public global::Google.Gemini.GenerationConfig? Type42 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponseBlob? Type43 { get; set; } + public global::Google.Gemini.Content? Type43 { get; set; } /// /// /// - public global::Google.Gemini.ListOperationsResponse? Type44 { get; set; } + public global::Google.Gemini.GenerateContentRequestServiceTier? Type44 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type45 { get; set; } + public global::System.Collections.Generic.IList? Type45 { get; set; } /// /// /// - public global::Google.Gemini.Operation? Type46 { get; set; } + public bool? Type46 { get; set; } /// /// /// - public global::Google.Gemini.TuningExamples? Type47 { get; set; } + public global::System.Collections.Generic.IList? Type47 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type48 { get; set; } + public global::Google.Gemini.SafetySetting? Type48 { get; set; } /// /// /// - public global::Google.Gemini.TuningExample? Type49 { get; set; } + public global::Google.Gemini.ToolConfig? Type49 { get; set; } /// /// /// - public global::Google.Gemini.Empty? Type50 { get; set; } + public global::System.Collections.Generic.IList? Type50 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentBatch? Type51 { get; set; } + public global::Google.Gemini.GroundingChunkStringList? Type51 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentBatchOutput? Type52 { get; set; } + public global::Google.Gemini.CountTokensRequest? Type52 { get; set; } /// /// /// - public global::Google.Gemini.BatchStats? Type53 { get; set; } + public global::Google.Gemini.VoiceConfig? Type53 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentBatchState? Type54 { get; set; } + public global::Google.Gemini.PrebuiltVoiceConfig? Type54 { get; set; } /// /// /// - public global::Google.Gemini.GroundingChunkStringList? Type55 { get; set; } + public global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? Type55 { get; set; } /// /// /// - public global::Google.Gemini.Content? Type56 { get; set; } + public global::Google.Gemini.ContentEmbedding? Type56 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type57 { get; set; } + public global::System.Collections.Generic.IList? Type57 { get; set; } /// /// /// - public global::Google.Gemini.Part? Type58 { get; set; } + public global::System.Collections.Generic.IList? Type58 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentResponses? Type59 { get; set; } + public global::Google.Gemini.WhiteSpaceConfig? Type59 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type60 { get; set; } + public global::Google.Gemini.Web? Type60 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentResponse? Type61 { get; set; } + public global::Google.Gemini.Schema? Type61 { get; set; } /// /// /// - public global::Google.Gemini.ExecutableCode? Type62 { get; set; } + public double? Type62 { get; set; } /// /// /// - public global::Google.Gemini.ExecutableCodeLanguage? Type63 { get; set; } + public global::Google.Gemini.SchemaType? Type63 { get; set; } /// /// /// - public global::Google.Gemini.CreateFileResponse? Type64 { get; set; } + public global::System.Collections.Generic.Dictionary? Type64 { get; set; } /// /// /// - public global::Google.Gemini.ListCorporaResponse? Type65 { get; set; } + public object? Type65 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type66 { get; set; } + public global::System.Collections.Generic.IList? Type66 { get; set; } /// /// /// - public global::Google.Gemini.Corpus? Type67 { get; set; } + public global::Google.Gemini.UrlMetadataUrlRetrievalStatus? Type67 { get; set; } /// /// /// - public global::Google.Gemini.Dataset? Type68 { get; set; } + public global::Google.Gemini.ListCorporaResponse? Type68 { get; set; } /// /// /// - public global::Google.Gemini.Permission? Type69 { get; set; } + public global::System.Collections.Generic.IList? Type69 { get; set; } /// /// /// - public global::Google.Gemini.PermissionRole? Type70 { get; set; } + public global::Google.Gemini.RetrievalMetadata? Type70 { get; set; } /// /// /// - public global::Google.Gemini.PermissionGranteeType? Type71 { get; set; } + public global::Google.Gemini.FunctionCallingConfig? Type71 { get; set; } /// /// /// - public global::Google.Gemini.ToolResponse? Type72 { get; set; } + public global::Google.Gemini.FunctionCallingConfigMode? Type72 { get; set; } /// /// /// - public global::Google.Gemini.ToolResponseToolType? Type73 { get; set; } + public global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport? Type73 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatchOutput? Type74 { get; set; } + public global::Google.Gemini.Document? Type74 { get; set; } /// /// /// - public global::Google.Gemini.BatchEmbedContentsRequest? Type75 { get; set; } + public global::Google.Gemini.DocumentState? Type75 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type76 { get; set; } + public global::Google.Gemini.Image? Type76 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentRequest? Type77 { get; set; } + public global::Google.Gemini.FunctionCall? Type77 { get; set; } /// /// /// - public global::Google.Gemini.GeneratedFile? Type78 { get; set; } + public global::Google.Gemini.FunctionDeclarationBehavior? Type78 { get; set; } /// /// /// - public global::Google.Gemini.GeneratedFileState? Type79 { get; set; } + public global::Google.Gemini.CustomLongRunningOperation? Type79 { get; set; } /// /// /// - public global::Google.Gemini.PrebuiltVoiceConfig? Type80 { get; set; } + public global::Google.Gemini.Status? Type80 { get; set; } /// /// /// - public global::Google.Gemini.UrlContextMetadata? Type81 { get; set; } + public global::Google.Gemini.Operation? Type81 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type82 { get; set; } + public global::Google.Gemini.Blob? Type82 { get; set; } /// /// /// - public global::Google.Gemini.UrlMetadata? Type83 { get; set; } + public byte[]? Type83 { get; set; } /// /// /// - public global::Google.Gemini.ToolConfig? Type84 { get; set; } + public global::Google.Gemini.RetrievalConfig? Type84 { get; set; } /// /// /// - public global::Google.Gemini.RetrievalConfig? Type85 { get; set; } + public global::Google.Gemini.LatLng? Type85 { get; set; } /// /// /// - public global::Google.Gemini.FunctionCallingConfig? Type86 { get; set; } + public global::Google.Gemini.Maps? Type86 { get; set; } /// /// /// - public global::Google.Gemini.GoogleMaps? Type87 { get; set; } + public global::Google.Gemini.PlaceAnswerSources? Type87 { get; set; } /// /// /// - public global::Google.Gemini.RegisterFilesResponse? Type88 { get; set; } + public global::Google.Gemini.AttributionSourceId? Type88 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type89 { get; set; } + public global::Google.Gemini.GroundingPassageId? Type89 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentResponse? Type90 { get; set; } + public global::Google.Gemini.SemanticRetrieverChunk? Type90 { get; set; } /// /// /// - public global::Google.Gemini.ContentEmbedding? Type91 { get; set; } + public global::Google.Gemini.Candidate? Type91 { get; set; } /// /// /// - public global::Google.Gemini.EmbeddingUsageMetadata? Type92 { get; set; } + public global::Google.Gemini.GroundingMetadata? Type92 { get; set; } /// /// /// - public global::Google.Gemini.TransferOwnershipResponse? Type93 { get; set; } + public global::Google.Gemini.CandidateFinishReason? Type93 { get; set; } /// /// /// - public global::Google.Gemini.AsyncBatchEmbedContentRequest? Type94 { get; set; } + public global::System.Collections.Generic.IList? Type94 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatch? Type95 { get; set; } + public global::Google.Gemini.SafetyRating? Type95 { get; set; } /// /// /// - public global::Google.Gemini.GroundingPassageId? Type96 { get; set; } + public global::System.Collections.Generic.IList? Type96 { get; set; } /// /// /// - public global::Google.Gemini.TransferOwnershipRequest? Type97 { get; set; } + public global::Google.Gemini.GroundingAttribution? Type97 { get; set; } /// /// /// - public global::Google.Gemini.ListCachedContentsResponse? Type98 { get; set; } + public global::Google.Gemini.LogprobsResult? Type98 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type99 { get; set; } + public global::Google.Gemini.CitationMetadata? Type99 { get; set; } /// /// /// - public global::Google.Gemini.CachedContent? Type100 { get; set; } + public global::Google.Gemini.Dataset? Type100 { get; set; } /// /// /// - public global::Google.Gemini.CodeExecutionResult? Type101 { get; set; } + public global::Google.Gemini.TuningExamples? Type101 { get; set; } /// /// /// - public global::Google.Gemini.ToolCall? Type102 { get; set; } + public global::Google.Gemini.ReviewSnippet? Type102 { get; set; } /// /// /// - public global::Google.Gemini.VideoMetadata? Type103 { get; set; } + public global::Google.Gemini.SearchEntryPoint? Type103 { get; set; } /// /// /// - public global::Google.Gemini.Blob? Type104 { get; set; } + public global::System.Collections.Generic.IList? Type104 { get; set; } /// /// /// - public global::Google.Gemini.FileData? Type105 { get; set; } + public global::System.Collections.Generic.IList? Type105 { get; set; } /// /// /// - public global::Google.Gemini.FunctionCall? Type106 { get; set; } + public global::Google.Gemini.GroundingChunk? Type106 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponse? Type107 { get; set; } + public global::Google.Gemini.InlinedResponses? Type107 { get; set; } /// /// /// - public global::Google.Gemini.CodeExecution? Type108 { get; set; } + public global::System.Collections.Generic.IList? Type108 { get; set; } /// /// /// - public global::Google.Gemini.GroundingChunkCustomMetadata? Type109 { get; set; } + public global::Google.Gemini.InlinedResponse? Type109 { get; set; } /// /// /// - public global::Google.Gemini.LatLng? Type110 { get; set; } + public global::Google.Gemini.TransferOwnershipRequest? Type110 { get; set; } /// /// /// - public global::Google.Gemini.ListDocumentsResponse? Type111 { get; set; } + public global::Google.Gemini.InlinedEmbedContentRequest? Type111 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type112 { get; set; } + public global::Google.Gemini.EmbedContentRequest? Type112 { get; set; } /// /// /// - public global::Google.Gemini.Document? Type113 { get; set; } + public global::Google.Gemini.VideoMetadata? Type113 { get; set; } /// /// /// - public global::Google.Gemini.Web? Type114 { get; set; } + public global::Google.Gemini.InlinedRequest? Type114 { get; set; } /// /// /// - public global::Google.Gemini.McpServer? Type115 { get; set; } + public global::Google.Gemini.BatchEmbedContentsRequest? Type115 { get; set; } /// /// /// - public global::Google.Gemini.ImageConfig? Type116 { get; set; } + public global::System.Collections.Generic.IList? Type116 { get; set; } /// /// /// - public global::Google.Gemini.ListFilesResponse? Type117 { get; set; } + public global::Google.Gemini.GenerateContentResponse? Type117 { get; set; } /// /// /// - public global::Google.Gemini.CitationMetadata? Type118 { get; set; } + public global::Google.Gemini.UsageMetadata? Type118 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type119 { get; set; } + public global::Google.Gemini.ModelStatus? Type119 { get; set; } /// /// /// - public global::Google.Gemini.CitationSource? Type120 { get; set; } + public global::System.Collections.Generic.IList? Type120 { get; set; } /// /// /// - public global::Google.Gemini.GenerationConfig? Type121 { get; set; } + public global::Google.Gemini.PromptFeedback? Type121 { get; set; } /// /// /// - public global::Google.Gemini.GenerationConfigMediaResolution? Type122 { get; set; } + public global::Google.Gemini.FileSearchStore? Type122 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type123 { get; set; } + public global::Google.Gemini.File? Type123 { get; set; } /// /// /// - public global::Google.Gemini.GenerationConfigResponseModalitie? Type124 { get; set; } + public global::Google.Gemini.FileSource? Type124 { get; set; } /// /// /// - public global::Google.Gemini.ThinkingConfig? Type125 { get; set; } + public global::Google.Gemini.FileState? Type125 { get; set; } /// /// /// - public global::Google.Gemini.ListModelsResponse? Type126 { get; set; } + public global::Google.Gemini.BatchEmbedContentsResponse? Type126 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type127 { get; set; } + public global::System.Collections.Generic.IList? Type127 { get; set; } /// /// /// - public global::Google.Gemini.Model? Type128 { get; set; } + public global::Google.Gemini.EmbeddingUsageMetadata? Type128 { get; set; } /// /// /// - public global::Google.Gemini.CustomLongRunningOperation? Type129 { get; set; } + public global::Google.Gemini.TuningSnapshot? Type129 { get; set; } /// /// /// - public global::Google.Gemini.ToolCallToolType? Type130 { get; set; } + public global::Google.Gemini.WebSearch? Type130 { get; set; } /// /// /// - public global::Google.Gemini.BatchGenerateContentRequest? Type131 { get; set; } + public global::Google.Gemini.TuningExample? Type131 { get; set; } /// /// /// - public global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport? Type132 { get; set; } + public global::Google.Gemini.SpeechConfig? Type132 { get; set; } /// /// /// - public global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? Type133 { get; set; } + public global::Google.Gemini.MultiSpeakerVoiceConfig? Type133 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type134 { get; set; } + public global::System.Collections.Generic.IList? Type134 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type135 { get; set; } + public global::Google.Gemini.CountTokensResponse? Type135 { get; set; } /// /// /// - public global::Google.Gemini.GroundingChunk? Type136 { get; set; } + public global::System.Collections.Generic.IList? Type136 { get; set; } /// /// /// - public global::Google.Gemini.RetrievedContext? Type137 { get; set; } + public global::Google.Gemini.ModalityTokenCount? Type137 { get; set; } /// /// /// - public global::Google.Gemini.Image? Type138 { get; set; } + public global::Google.Gemini.GeneratedFile? Type138 { get; set; } /// /// /// - public global::Google.Gemini.Maps? Type139 { get; set; } + public global::Google.Gemini.GeneratedFileState? Type139 { get; set; } /// /// /// - public global::Google.Gemini.AttributionSourceId? Type140 { get; set; } + public global::Google.Gemini.ImportFileRequest? Type140 { get; set; } /// /// /// - public global::Google.Gemini.SemanticRetrieverChunk? Type141 { get; set; } + public global::Google.Gemini.RetrievedContext? Type141 { get; set; } /// /// /// - public global::Google.Gemini.ModalityTokenCount? Type142 { get; set; } + public global::System.Collections.Generic.IList? Type142 { get; set; } /// /// /// - public global::Google.Gemini.ModalityTokenCountModality? Type143 { get; set; } + public global::Google.Gemini.GroundingChunkCustomMetadata? Type143 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type144 { get; set; } + public global::Google.Gemini.StringList? Type144 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponseScheduling? Type145 { get; set; } + public global::Google.Gemini.FunctionResponsePart? Type145 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentRequests? Type146 { get; set; } + public global::Google.Gemini.FunctionResponseBlob? Type146 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type147 { get; set; } + public global::Google.Gemini.SafetySettingCategory? Type147 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentRequest? Type148 { get; set; } + public global::Google.Gemini.SafetySettingThreshold? Type148 { get; set; } /// /// /// - public global::Google.Gemini.CustomMetadata? Type149 { get; set; } + public global::Google.Gemini.ListFileSearchStoresResponse? Type149 { get; set; } /// /// /// - public global::Google.Gemini.StringList? Type150 { get; set; } + public global::System.Collections.Generic.IList? Type150 { get; set; } /// /// /// - public global::Google.Gemini.PlaceAnswerSources? Type151 { get; set; } + public global::Google.Gemini.StreamableHttpTransport? Type151 { get; set; } /// /// /// - public global::Google.Gemini.InputEmbedContentConfig? Type152 { get; set; } + public global::System.Collections.Generic.Dictionary? Type152 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatchStats? Type153 { get; set; } + public global::Google.Gemini.ImageSearch? Type153 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatchState? Type154 { get; set; } + public global::Google.Gemini.PromptFeedbackBlockReason? Type154 { get; set; } /// /// /// - public global::Google.Gemini.Tool? Type155 { get; set; } + public global::Google.Gemini.InlinedRequests? Type155 { get; set; } /// /// /// - public global::Google.Gemini.GoogleSearchRetrieval? Type156 { get; set; } + public global::Google.Gemini.Interval? Type156 { get; set; } /// /// /// - public global::Google.Gemini.GoogleSearch? Type157 { get; set; } + public global::Google.Gemini.ThinkingConfig? Type157 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type158 { get; set; } + public global::System.Collections.Generic.IList? Type158 { get; set; } /// /// /// - public global::Google.Gemini.FunctionDeclaration? Type159 { get; set; } + public global::Google.Gemini.GenerationConfigResponseModalitie? Type159 { get; set; } /// /// /// - public global::Google.Gemini.FileSearch? Type160 { get; set; } + public global::Google.Gemini.ImageConfig? Type160 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type161 { get; set; } + public global::Google.Gemini.GenerationConfigMediaResolution? Type161 { get; set; } /// /// /// - public global::Google.Gemini.UrlContext? Type162 { get; set; } + public global::Google.Gemini.TransferOwnershipResponse? Type162 { get; set; } /// /// /// - public global::Google.Gemini.InlinedResponse? Type163 { get; set; } + public global::Google.Gemini.Model? Type163 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentResponse? Type164 { get; set; } + public global::Google.Gemini.ListModelsResponse? Type164 { get; set; } /// /// /// - public global::Google.Gemini.UploadToFileSearchStoreRequest? Type165 { get; set; } + public global::System.Collections.Generic.IList? Type165 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type166 { get; set; } + public global::Google.Gemini.Part? Type166 { get; set; } /// /// /// - public global::Google.Gemini.ChunkingConfig? Type167 { get; set; } + public global::Google.Gemini.ExecutableCode? Type167 { get; set; } /// /// /// - public global::Google.Gemini.DynamicRetrievalConfig? Type168 { get; set; } + public global::Google.Gemini.CodeExecutionResult? Type168 { get; set; } /// /// /// - public global::Google.Gemini.DynamicRetrievalConfigMode? Type169 { get; set; } + public global::Google.Gemini.FunctionResponse? Type169 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentConfig? Type170 { get; set; } + public global::Google.Gemini.FileData? Type170 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentRequestTaskType? Type171 { get; set; } + public global::Google.Gemini.ToolCall? Type171 { get; set; } /// /// /// - public global::Google.Gemini.SearchEntryPoint? Type172 { get; set; } + public global::Google.Gemini.ToolResponse? Type172 { get; set; } /// /// /// - public global::Google.Gemini.CreateFileRequest? Type173 { get; set; } + public global::Google.Gemini.SearchTypes? Type173 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type174 { get; set; } + public global::Google.Gemini.ListDocumentsResponse? Type174 { get; set; } /// /// /// - public global::Google.Gemini.ReviewSnippet? Type175 { get; set; } + public global::System.Collections.Generic.IList? Type175 { get; set; } /// /// /// - public global::Google.Gemini.FunctionCallingConfigMode? Type176 { get; set; } + public global::Google.Gemini.InlinedEmbedContentResponses? Type176 { get; set; } /// /// /// - public global::Google.Gemini.DocumentState? Type177 { get; set; } + public global::System.Collections.Generic.IList? Type177 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type178 { get; set; } + public global::Google.Gemini.InlinedEmbedContentResponse? Type178 { get; set; } /// /// /// - public global::Google.Gemini.Interval? Type179 { get; set; } + public global::Google.Gemini.ThinkingConfigThinkingLevel? Type179 { get; set; } /// /// /// - public global::Google.Gemini.TunedModelSource? Type180 { get; set; } + public global::Google.Gemini.CreateFileResponse? Type180 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type181 { get; set; } + public global::Google.Gemini.SafetyRatingCategory? Type181 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type182 { get; set; } + public global::Google.Gemini.SafetyRatingProbability? Type182 { get; set; } /// /// /// - public global::Google.Gemini.CachedContentUsageMetadata? Type183 { get; set; } + public global::Google.Gemini.TuningTask? Type183 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type184 { get; set; } + public global::Google.Gemini.Hyperparameters? Type184 { get; set; } /// /// /// - public global::Google.Gemini.TunedModel? Type185 { get; set; } + public global::System.Collections.Generic.IList? Type185 { get; set; } /// /// /// - public global::Google.Gemini.TuningTask? Type186 { get; set; } + public global::Google.Gemini.SpeakerVoiceConfig? Type186 { get; set; } /// /// /// - public global::Google.Gemini.TunedModelState? Type187 { get; set; } + public global::Google.Gemini.RegisterFilesResponse? Type187 { get; set; } /// /// /// - public global::Google.Gemini.Hyperparameters? Type188 { get; set; } + public global::System.Collections.Generic.IList? Type188 { get; set; } /// /// /// - public global::Google.Gemini.RegisterFilesRequest? Type189 { get; set; } + public global::Google.Gemini.Empty? Type189 { get; set; } /// /// /// - public global::Google.Gemini.GroundingAttribution? Type190 { get; set; } + public global::Google.Gemini.RegisterFilesRequest? Type190 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type191 { get; set; } + public global::Google.Gemini.ModelStatusModelStage? Type191 { get; set; } /// /// /// - public global::Google.Gemini.BatchEmbedContentsResponse? Type192 { get; set; } + public global::Google.Gemini.ListPermissionsResponse? Type192 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type193 { get; set; } + public global::System.Collections.Generic.IList? Type193 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentRequestServiceTier? Type194 { get; set; } + public global::Google.Gemini.Permission? Type194 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type195 { get; set; } + public global::Google.Gemini.TunedModelSource? Type195 { get; set; } /// /// /// - public global::Google.Gemini.SafetySetting? Type196 { get; set; } + public global::Google.Gemini.ExecutableCodeLanguage? Type196 { get; set; } /// /// /// - public global::Google.Gemini.Candidate? Type197 { get; set; } + public global::Google.Gemini.ListCachedContentsResponse? Type197 { get; set; } /// /// /// - public global::Google.Gemini.GroundingMetadata? Type198 { get; set; } + public global::System.Collections.Generic.IList? Type198 { get; set; } /// /// /// - public global::Google.Gemini.CandidateFinishReason? Type199 { get; set; } + public global::Google.Gemini.CachedContent? Type199 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type200 { get; set; } + public global::Google.Gemini.CodeExecutionResultOutcome? Type200 { get; set; } /// /// /// - public global::Google.Gemini.SafetyRating? Type201 { get; set; } + public global::Google.Gemini.UsageMetadataServiceTier? Type201 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type202 { get; set; } + public global::Google.Gemini.EmbedContentConfig? Type202 { get; set; } /// /// /// - public global::Google.Gemini.SafetySettingCategory? Type203 { get; set; } + public global::Google.Gemini.EmbedContentConfigTaskType? Type203 { get; set; } /// /// /// - public global::Google.Gemini.SafetySettingThreshold? Type204 { get; set; } + public global::System.Collections.Generic.IList? Type204 { get; set; } /// /// /// - public global::Google.Gemini.FunctionDeclarationBehavior? Type205 { get; set; } + public global::System.Collections.Generic.IList? Type205 { get; set; } /// /// /// - public global::Google.Gemini.PromptFeedback? Type206 { get; set; } + public global::Google.Gemini.DynamicRetrievalConfig? Type206 { get; set; } /// /// /// - public global::Google.Gemini.PromptFeedbackBlockReason? Type207 { get; set; } + public global::Google.Gemini.DynamicRetrievalConfigMode? Type207 { get; set; } /// /// /// - public global::Google.Gemini.ListPermissionsResponse? Type208 { get; set; } + public global::Google.Gemini.CreateFileRequest? Type208 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type209 { get; set; } + public global::System.Collections.Generic.IList? Type209 { get; set; } /// /// /// - public global::Google.Gemini.UrlMetadataUrlRetrievalStatus? Type210 { get; set; } + public global::Google.Gemini.FunctionResponseScheduling? Type210 { get; set; } /// /// /// - public global::Google.Gemini.ListTunedModelsResponse? Type211 { get; set; } + public global::Google.Gemini.ListFilesResponse? Type211 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type212 { get; set; } + public global::Google.Gemini.ToolResponseToolType? Type212 { get; set; } /// /// /// - public global::Google.Gemini.ImportFileRequest? Type213 { get; set; } + public global::System.Collections.Generic.IList? Type213 { get; set; } /// /// /// - public global::Google.Gemini.InlinedResponses? Type214 { get; set; } + public global::Google.Gemini.ListGeneratedFilesResponse? Type214 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type215 { get; set; } + public global::System.Collections.Generic.IList? Type215 { get; set; } /// /// /// - public global::Google.Gemini.ThinkingConfigThinkingLevel? Type216 { get; set; } + public global::Google.Gemini.TunedModelState? Type216 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type217 { get; set; } + public global::Google.Gemini.PermissionRole? Type217 { get; set; } /// /// /// - public global::Google.Gemini.SpeakerVoiceConfig? Type218 { get; set; } + public global::Google.Gemini.PermissionGranteeType? Type218 { get; set; } /// /// /// - public global::Google.Gemini.CountTokensRequest? Type219 { get; set; } + public global::Google.Gemini.InlinedEmbedContentRequests? Type219 { get; set; } /// /// /// - public global::Google.Gemini.CountTokensResponse? Type220 { get; set; } + public global::System.Collections.Generic.IList? Type220 { get; set; } /// /// /// - public global::Google.Gemini.CodeExecutionResultOutcome? Type221 { get; set; } + public global::System.Collections.Generic.IList? Type221 { get; set; } /// /// /// - public global::Google.Gemini.TuningSnapshot? Type222 { get; set; } + public global::System.Collections.Generic.IList? Type222 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentConfigTaskType? Type223 { get; set; } + public global::Google.Gemini.TopCandidates? Type223 { get; set; } /// /// /// - public global::Google.Gemini.ListGeneratedFilesResponse? Type224 { get; set; } + public global::System.Collections.Generic.IList? Type224 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type225 { get; set; } + public global::Google.Gemini.AsyncBatchEmbedContentRequest? Type225 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type226 { get; set; } + public global::System.Collections.Generic.IList? Type226 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type227 { get; set; } + public global::Google.Gemini.ToolCallToolType? Type227 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type228 { get; set; } + public global::Google.Gemini.EmbedContentRequestTaskType? Type228 { get; set; } /// /// /// - public global::Google.Gemini.UsageMetadata? Type229 { get; set; } + public global::Google.Gemini.ModalityTokenCountModality? Type229 { get; set; } /// /// /// - public global::Google.Gemini.UsageMetadataServiceTier? Type230 { get; set; } + public global::Google.Gemini.EmbedContentResponse? Type230 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type231 { get; set; } + public global::System.Collections.Generic.IList? Type231 { get; set; } /// /// /// - public global::Google.Gemini.ModelStatus? Type232 { get; set; } + public global::Google.Gemini.CachedContentUsageMetadata? Type232 { get; set; } /// /// /// - public global::Google.Gemini.ModelStatusModelStage? Type233 { get; set; } + public global::Google.Gemini.BatchGenerateContentRequest? Type233 { get; set; } /// /// /// - public global::Google.Gemini.SafetyRatingProbability? Type234 { get; set; } + public global::Google.Gemini.ListOperationsResponse? Type234 { get; set; } /// /// /// - public global::Google.Gemini.SafetyRatingCategory? Type235 { get; set; } + public global::System.Collections.Generic.IList? Type235 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType0 { get; set; } + public global::System.Collections.Generic.List? ListType0 { get; set; } /// /// /// @@ -981,151 +981,151 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - 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; } /// /// /// - public global::System.Collections.Generic.List? ListType31 { get; set; } + public global::System.Collections.Generic.List? ListType31 { get; set; } /// /// /// - 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; } /// /// /// @@ -1133,22 +1133,22 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - 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.BatchStats.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchStats.g.cs index 72da3cc5..2c8d807d 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 were successfully processed.
+ /// Included only in responses + ///
+ [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 @@ -29,13 +36,6 @@ public sealed partial class BatchStats [global::System.Text.Json.Serialization.JsonPropertyName("pendingRequestCount")] public string? PendingRequestCount { get; set; } - /// - /// Output only. The number of requests that were successfully processed.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("successfulRequestCount")] - public string? SuccessfulRequestCount { 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 were successfully processed.
+ /// Included only in responses + /// /// /// Output only. The number of requests that failed to be processed.
/// Included only in responses @@ -57,23 +61,19 @@ public sealed partial class BatchStats /// Output only. The number of requests that are still pending processing.
/// Included only in responses /// - /// - /// Output only. The number of requests that were successfully processed.
- /// Included only in responses - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public BatchStats( string? requestCount, + string? successfulRequestCount, string? failedRequestCount, - string? pendingRequestCount, - string? successfulRequestCount) + string? pendingRequestCount) { this.RequestCount = requestCount; + this.SuccessfulRequestCount = successfulRequestCount; this.FailedRequestCount = failedRequestCount; this.PendingRequestCount = pendingRequestCount; - this.SuccessfulRequestCount = successfulRequestCount; } /// 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 5ee5bdca..ba3e4060 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 @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class CachedContent { - /// - /// Input only. New TTL for this resource, input only. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("ttl")] - public string? Ttl { get; set; } - /// /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. /// @@ -21,23 +15,22 @@ public sealed partial class CachedContent public string? DisplayName { get; set; } /// - /// Optional. Input only. Immutable. The content to cache. + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response /// - [global::System.Text.Json.Serialization.JsonPropertyName("contents")] - public global::System.Collections.Generic.IList? Contents { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("tools")] + public global::System.Collections.Generic.IList? Tools { get; set; } /// - /// Required. Immutable. The name of the `Model` to use for cached content 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; } /// - /// Output only. When the cache entry was last updated in UTC time.
- /// Included only in responses + /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("model")] + public string? Model { 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,17 +39,24 @@ public sealed partial class CachedContent public global::Google.Gemini.Content? SystemInstruction { get; set; } /// - /// Output only. Creation time of the cache entry.
+ /// Optional. Input only. Immutable. The content to cache. + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("contents")] + public global::System.Collections.Generic.IList? Contents { get; set; } + + /// + /// Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`
/// 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; } /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// Output only. Creation time of the cache entry.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("toolConfig")] - public global::Google.Gemini.ToolConfig? ToolConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } /// /// Metadata on the usage of the cached content. @@ -65,23 +65,23 @@ 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 + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// - [global::System.Text.Json.Serialization.JsonPropertyName("tools")] - public global::System.Collections.Generic.IList? Tools { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("expireTime")] + public string? ExpireTime { get; set; } /// - /// Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`
- /// Included only in responses + /// Input only. New TTL for this resource, input only. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("ttl")] + public string? Ttl { get; set; } /// - /// 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 ///
- [global::System.Text.Json.Serialization.JsonPropertyName("expireTime")] - public string? ExpireTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -92,74 +92,74 @@ public sealed partial class CachedContent /// /// Initializes a new instance of the class. /// - /// - /// Input only. New TTL for this resource, input only. - /// /// /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. /// - /// - /// Optional. Input only. Immutable. The content to cache. + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` /// - /// - /// Output only. When the cache entry was last updated in UTC time.
- /// 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. + /// + /// + /// Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`
+ /// Included only in responses + /// /// /// Output only. Creation time of the cache entry.
/// Included only in responses /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// /// 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 - /// /// /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// + /// + /// 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 + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CachedContent( - string? ttl, string? displayName, - global::System.Collections.Generic.IList? contents, + global::System.Collections.Generic.IList? tools, + global::Google.Gemini.ToolConfig? toolConfig, string? model, - string? updateTime, global::Google.Gemini.Content? systemInstruction, + global::System.Collections.Generic.IList? contents, + string? name, string? createTime, - global::Google.Gemini.ToolConfig? toolConfig, global::Google.Gemini.CachedContentUsageMetadata? usageMetadata, - global::System.Collections.Generic.IList? tools, - string? name, - string? expireTime) + string? expireTime, + string? ttl, + string? updateTime) { - this.Ttl = ttl; this.DisplayName = displayName; - this.Contents = contents; + this.Tools = tools; + this.ToolConfig = toolConfig; this.Model = model; - this.UpdateTime = updateTime; this.SystemInstruction = systemInstruction; + this.Contents = contents; + this.Name = name; this.CreateTime = createTime; - this.ToolConfig = toolConfig; this.UsageMetadata = usageMetadata; - this.Tools = tools; - this.Name = name; this.ExpireTime = expireTime; + this.Ttl = ttl; + this.UpdateTime = updateTime; } /// 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 45fd4d9b..cda6771f 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,39 +9,44 @@ namespace Google.Gemini public sealed partial class Candidate { /// - /// Metadata returned to client when grounding is enabled. + /// Output only. Average log probability score of the candidate.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("groundingMetadata")] - public global::Google.Gemini.GroundingMetadata? GroundingMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("avgLogprobs")] + public double? AvgLogprobs { get; 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 + /// 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("finishReason")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonJsonConverter))] - public global::Google.Gemini.CandidateFinishReason? FinishReason { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("content")] + public global::Google.Gemini.Content? Content { get; set; } /// - /// Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.
+ /// Output only. Token count for this candidate.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("finishMessage")] - public string? FinishMessage { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("tokenCount")] + public int? TokenCount { get; set; } /// - /// Output only. Average log probability score of the candidate.
- /// Included only in responses + /// Metadata returned to client when grounding is enabled. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("avgLogprobs")] - public double? AvgLogprobs { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("groundingMetadata")] + public global::Google.Gemini.GroundingMetadata? GroundingMetadata { get; set; } /// - /// Output only. Index of the candidate in the list of response candidates.
+ /// 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("index")] - public int? Index { 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; } + + /// + /// Metadata related to url context retrieval tool. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("urlContextMetadata")] + public global::Google.Gemini.UrlContextMetadata? UrlContextMetadata { get; set; } /// /// List of ratings for the safety of a response candidate. There is at most one rating per category. @@ -57,23 +62,24 @@ public sealed partial class Candidate public global::System.Collections.Generic.IList? GroundingAttributions { 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. + /// Logprobs Result /// - [global::System.Text.Json.Serialization.JsonPropertyName("content")] - public global::Google.Gemini.Content? Content { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("logprobsResult")] + public global::Google.Gemini.LogprobsResult? LogprobsResult { 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; } /// - /// Output only. Token count for this candidate.
+ /// 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("tokenCount")] - public int? TokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("finishMessage")] + public string? FinishMessage { get; set; } /// /// A collection of source attributions for a piece of content. @@ -81,12 +87,6 @@ public sealed partial class Candidate [global::System.Text.Json.Serialization.JsonPropertyName("citationMetadata")] public global::Google.Gemini.CitationMetadata? CitationMetadata { get; set; } - /// - /// Logprobs Result - /// - [global::System.Text.Json.Serialization.JsonPropertyName("logprobsResult")] - public global::Google.Gemini.LogprobsResult? LogprobsResult { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -96,6 +96,17 @@ public sealed partial class Candidate /// /// Initializes a new instance of the class. /// + /// + /// Output only. Average log probability score of the candidate.
+ /// 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. + /// + /// + /// Output only. Token count for this candidate.
+ /// Included only in responses + /// /// /// Metadata returned to client when grounding is enabled. /// @@ -103,17 +114,8 @@ public sealed partial class Candidate /// Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.
/// Included only in responses /// - /// - /// 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. Average log probability score of the candidate.
- /// Included only in responses - /// - /// - /// Output only. Index of the candidate in the list of response candidates.
- /// Included only in responses + /// + /// Metadata related to url context retrieval tool. /// /// /// List of ratings for the safety of a response candidate. There is at most one rating per category. @@ -122,51 +124,49 @@ public sealed partial class Candidate /// Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.
/// 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. + /// + /// Logprobs Result /// - /// - /// Metadata related to url context retrieval tool. + /// + /// Output only. Index of the candidate in the list of response candidates.
+ /// Included only in responses /// - /// - /// Output only. Token count for this candidate.
+ /// + /// 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 /// /// /// A collection of source attributions for a piece of content. /// - /// - /// Logprobs Result - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Candidate( + double? avgLogprobs, + global::Google.Gemini.Content? content, + int? tokenCount, global::Google.Gemini.GroundingMetadata? groundingMetadata, global::Google.Gemini.CandidateFinishReason? finishReason, - string? finishMessage, - double? avgLogprobs, - int? index, + global::Google.Gemini.UrlContextMetadata? urlContextMetadata, global::System.Collections.Generic.IList? safetyRatings, global::System.Collections.Generic.IList? groundingAttributions, - global::Google.Gemini.Content? content, - global::Google.Gemini.UrlContextMetadata? urlContextMetadata, - int? tokenCount, - global::Google.Gemini.CitationMetadata? citationMetadata, - global::Google.Gemini.LogprobsResult? logprobsResult) + global::Google.Gemini.LogprobsResult? logprobsResult, + int? index, + string? finishMessage, + global::Google.Gemini.CitationMetadata? citationMetadata) { + this.AvgLogprobs = avgLogprobs; + this.Content = content; + this.TokenCount = tokenCount; this.GroundingMetadata = groundingMetadata; this.FinishReason = finishReason; - this.FinishMessage = finishMessage; - this.AvgLogprobs = avgLogprobs; - this.Index = index; + this.UrlContextMetadata = urlContextMetadata; this.SafetyRatings = safetyRatings; this.GroundingAttributions = groundingAttributions; - this.Content = content; - this.UrlContextMetadata = urlContextMetadata; - this.TokenCount = tokenCount; - this.CitationMetadata = citationMetadata; this.LogprobsResult = logprobsResult; + this.Index = index; + this.FinishMessage = finishMessage; + this.CitationMetadata = citationMetadata; } /// 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 30964d8f..f32f66c4 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 @@ -9,10 +9,10 @@ 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. + /// Optional. End of the attributed segment, exclusive. /// - [global::System.Text.Json.Serialization.JsonPropertyName("startIndex")] - public int? StartIndex { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("endIndex")] + public int? EndIndex { get; set; } /// /// Optional. URI that is attributed as a source for a portion of the text. @@ -20,18 +20,18 @@ public sealed partial class CitationSource [global::System.Text.Json.Serialization.JsonPropertyName("uri")] public string? Uri { get; set; } - /// - /// Optional. End of the attributed segment, exclusive. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("endIndex")] - public int? EndIndex { get; set; } - /// /// Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations. /// [global::System.Text.Json.Serialization.JsonPropertyName("license")] public string? License { 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; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -41,31 +41,31 @@ 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. End of the attributed segment, exclusive. - /// /// /// Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations. /// + /// + /// Optional. Start of segment of the response that is attributed to this source. Index indicates the start of the segment, measured in bytes. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CitationSource( - int? startIndex, - string? uri, int? endIndex, - string? license) + string? uri, + string? license, + int? startIndex) { - this.StartIndex = startIndex; - this.Uri = uri; this.EndIndex = endIndex; + this.Uri = uri; this.License = license; + this.StartIndex = startIndex; } /// 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 c36154c6..a0040721 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,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class CodeExecutionResult { - /// - /// Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("id")] - public string? Id { get; set; } - /// /// Required. Outcome of the code execution. /// @@ -21,6 +15,12 @@ public sealed partial class CodeExecutionResult [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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("id")] + public string? Id { get; set; } + /// /// Optional. Contains stdout when code execution is successful, stderr or other description otherwise. /// @@ -36,12 +36,12 @@ public sealed partial class CodeExecutionResult /// /// Initializes a new instance of the class. /// - /// - /// Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id. - /// /// /// 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. /// @@ -49,12 +49,12 @@ public sealed partial class CodeExecutionResult [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CodeExecutionResult( - string? id, global::Google.Gemini.CodeExecutionResultOutcome? outcome, + string? id, string? output) { - this.Id = id; this.Outcome = outcome; + this.Id = id; this.Output = output; } 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 ee375068..391e4a13 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.Corpus.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Corpus.g.cs index 060694ad..80d0cd23 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 @@ -16,18 +16,18 @@ public sealed partial class Corpus public string? Name { 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. The Timestamp of when the `Corpus` was last updated.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { 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" @@ -48,14 +48,14 @@ 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 /// - /// - /// 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 /// + /// + /// Output only. The Timestamp of when the `Corpus` was last updated.
+ /// 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" /// @@ -64,13 +64,13 @@ public sealed partial class Corpus #endif public Corpus( string? name, - string? updateTime, string? createTime, + string? updateTime, string? displayName) { this.Name = name; - this.UpdateTime = updateTime; this.CreateTime = createTime; + this.UpdateTime = updateTime; this.DisplayName = displayName; } 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 af9906bc..8dd49349 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,19 +8,6 @@ namespace Google.Gemini ///
public sealed partial class CountTokensResponse { - /// - /// Number of tokens in the cached part of the prompt (the cached content). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("cachedContentTokenCount")] - public int? CachedContentTokenCount { get; set; } - - /// - /// Output only. List of modalities that were processed in the cached content.
- /// Included only in responses - ///
- [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. /// @@ -34,6 +21,19 @@ public sealed partial class CountTokensResponse [global::System.Text.Json.Serialization.JsonPropertyName("promptTokensDetails")] public global::System.Collections.Generic.IList? PromptTokensDetails { get; set; } + /// + /// Output only. List of modalities that were processed in the cached content.
+ /// Included only in responses + ///
+ [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). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("cachedContentTokenCount")] + public int? CachedContentTokenCount { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -43,13 +43,6 @@ public sealed partial class CountTokensResponse /// /// Initializes a new instance of the class. /// - /// - /// Number of tokens in the cached part of the prompt (the cached content). - /// - /// - /// 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. /// @@ -57,19 +50,26 @@ public sealed partial class CountTokensResponse /// Output only. List of modalities that were processed in the request input.
/// Included only in responses /// + /// + /// Output only. List of modalities that were processed in the cached content.
+ /// Included only in responses + /// + /// + /// Number of tokens in the cached part of the prompt (the cached content). + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CountTokensResponse( - int? cachedContentTokenCount, - global::System.Collections.Generic.IList? cacheTokensDetails, int? totalTokens, - global::System.Collections.Generic.IList? promptTokensDetails) + global::System.Collections.Generic.IList? promptTokensDetails, + global::System.Collections.Generic.IList? cacheTokensDetails, + int? cachedContentTokenCount) { - this.CachedContentTokenCount = cachedContentTokenCount; - this.CacheTokensDetails = cacheTokensDetails; this.TotalTokens = totalTokens; this.PromptTokensDetails = promptTokensDetails; + this.CacheTokensDetails = cacheTokensDetails; + this.CachedContentTokenCount = cachedContentTokenCount; } /// 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 a3c5567e..aaed5123 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 @@ -15,10 +15,10 @@ public sealed partial class CustomLongRunningOperation 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). + /// 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`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("error")] - public global::Google.Gemini.Status? Error { get; set; } + [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}`. @@ -27,16 +27,16 @@ public sealed partial class CustomLongRunningOperation public string? Name { 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. + /// 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("done")] - public bool? Done { get; set; } + [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`. + /// 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("response")] - public object? Response { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("done")] + public bool? Done { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -50,33 +50,33 @@ public sealed partial class CustomLongRunningOperation /// /// 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). + /// + /// 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}`. /// + /// + /// 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. /// - /// - /// 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`. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CustomLongRunningOperation( object? metadata, - global::Google.Gemini.Status? error, + object? response, string? name, - bool? done, - object? response) + global::Google.Gemini.Status? error, + bool? done) { this.Metadata = metadata; - this.Error = error; + this.Response = response; this.Name = name; + this.Error = error; this.Done = done; - this.Response = response; } /// 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 2ed62151..006baaac 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 @@ -15,10 +15,10 @@ public sealed partial class CustomMetadata public global::Google.Gemini.StringList? StringListValue { get; set; } /// - /// The numeric value of the metadata to store. + /// Required. The key of the metadata to store. /// - [global::System.Text.Json.Serialization.JsonPropertyName("numericValue")] - public float? NumericValue { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("key")] + public string? Key { get; set; } /// /// The string value of the metadata to store. @@ -27,10 +27,10 @@ public sealed partial class CustomMetadata public string? StringValue { get; set; } /// - /// Required. The key of the metadata to store. + /// The numeric value of the metadata to store. /// - [global::System.Text.Json.Serialization.JsonPropertyName("key")] - public string? Key { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("numericValue")] + public float? NumericValue { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -44,28 +44,28 @@ public sealed partial class CustomMetadata /// /// User provided string values assigned to a single metadata key. /// - /// - /// The numeric value of the metadata to store. + /// + /// Required. The key of the metadata to store. /// /// /// The string value of the metadata to store. /// - /// - /// Required. The key of the metadata to store. + /// + /// The numeric value of the metadata to store. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CustomMetadata( global::Google.Gemini.StringList? stringListValue, - float? numericValue, + string? key, string? stringValue, - string? key) + float? numericValue) { this.StringListValue = stringListValue; - this.NumericValue = numericValue; - this.StringValue = stringValue; this.Key = key; + this.StringValue = stringValue; + this.NumericValue = numericValue; } /// 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 7eebdd37..868d02e3 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,10 +9,17 @@ namespace Google.Gemini public sealed partial class Document { /// - /// 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" + /// 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("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } + + /// + /// Output only. The Timestamp of when the `Document` was created.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } /// /// Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`. @@ -29,38 +36,31 @@ public sealed partial class Document public global::Google.Gemini.DocumentState? State { get; set; } /// - /// Output only. The size of raw bytes ingested into the Document.
+ /// Output only. The Timestamp of when the `Document` was last updated.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] - public string? SizeBytes { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } /// - /// Output only. The mime type of the Document.
+ /// Output only. The size of raw bytes ingested into the Document.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] - public string? MimeType { 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` - /// - [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] + public string? SizeBytes { get; set; } /// - /// 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" ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// - /// Output only. The Timestamp of when the `Document` was created.
+ /// Output only. The mime type of the Document.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] + public string? MimeType { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -71,8 +71,12 @@ public sealed partial class Document /// /// Initializes a new instance of the class. /// - /// - /// 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" + /// + /// 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 created.
+ /// 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`. @@ -81,46 +85,42 @@ public sealed partial class Document /// Output only. Current state of the `Document`.
/// Included only in responses /// + /// + /// Output only. The Timestamp of when the `Document` was last updated.
+ /// Included only in responses + /// /// /// Output only. The size of raw bytes ingested into the Document.
/// 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. The mime type 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 - /// - /// - /// Output only. The Timestamp of when the `Document` was created.
- /// Included only in responses - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Document( - string? displayName, + string? name, + string? createTime, global::System.Collections.Generic.IList? customMetadata, global::Google.Gemini.DocumentState? state, - string? sizeBytes, - string? mimeType, - string? name, string? updateTime, - string? createTime) + string? sizeBytes, + string? displayName, + string? mimeType) { - this.DisplayName = displayName; + this.Name = name; + this.CreateTime = createTime; this.CustomMetadata = customMetadata; this.State = state; + this.UpdateTime = updateTime; this.SizeBytes = sizeBytes; + this.DisplayName = displayName; this.MimeType = mimeType; - this.Name = name; - this.UpdateTime = updateTime; - this.CreateTime = createTime; } /// 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 e3f1f7d4..62913635 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,49 +9,50 @@ namespace Google.Gemini public sealed partial class EmbedContentBatch { /// - /// 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}`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("output")] - public global::Google.Gemini.EmbedContentBatchOutput? Output { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("model")] + public string? Model { get; set; } /// - /// Output only. The time at which the batch was last updated.
+ /// Output only. The time at which the batch processing completed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] + public string? EndTime { get; set; } /// - /// Output only. The time at which the batch was created.
+ /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
/// 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; } /// - /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("output")] + public global::Google.Gemini.EmbedContentBatchOutput? Output { get; set; } /// - /// Configures the input to the batch request. + /// Output only. The time at which the batch was created.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("inputConfig")] - public global::Google.Gemini.InputEmbedContentConfig? InputConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } /// - /// Output only. The time at which the batch processing completed.
- /// Included only in responses + /// Stats about the batch. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] - public string? EndTime { get; set; } + [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}`. + /// Output only. The time at which the batch was last updated.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("model")] - public string? Model { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { 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. @@ -60,17 +61,16 @@ public sealed partial class EmbedContentBatch public string? Priority { 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.InputEmbedContentConfig? InputConfig { get; set; } /// - /// Stats about the batch. + /// Required. The user-defined name of this batch. /// - [global::System.Text.Json.Serialization.JsonPropertyName("batchStats")] - public global::Google.Gemini.EmbedContentBatchStats? BatchStats { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// /// Output only. The state of the batch.
@@ -89,39 +89,39 @@ public sealed partial class EmbedContentBatch /// /// Initializes a new instance of the class. /// - /// - /// 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}`. /// - /// - /// Output only. The time at which the batch was last updated.
+ /// + /// Output only. The time at which the batch processing completed.
+ /// Included only in responses + /// + /// + /// 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. + /// /// /// Output only. The time at which the batch was created.
/// Included only in responses /// - /// - /// Required. The user-defined name of this batch. - /// - /// - /// Configures the input to the batch request. + /// + /// Stats about the batch. /// - /// - /// Output only. The time at which the batch processing completed.
+ /// + /// Output only. The time at which the batch was last updated.
/// Included only in responses /// - /// - /// 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. /// - /// - /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
- /// Included only in responses + /// + /// Configures the input to the batch request. /// - /// - /// Stats about the batch. + /// + /// Required. The user-defined name of this batch. /// /// /// Output only. The state of the batch.
@@ -131,28 +131,28 @@ public sealed partial class EmbedContentBatch [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentBatch( - global::Google.Gemini.EmbedContentBatchOutput? output, - string? updateTime, - string? createTime, - string? displayName, - global::Google.Gemini.InputEmbedContentConfig? inputConfig, - string? endTime, string? model, - string? priority, + string? endTime, string? name, + global::Google.Gemini.EmbedContentBatchOutput? output, + string? createTime, global::Google.Gemini.EmbedContentBatchStats? batchStats, + string? updateTime, + string? priority, + global::Google.Gemini.InputEmbedContentConfig? inputConfig, + string? displayName, global::Google.Gemini.EmbedContentBatchState? state) { - this.Output = output; - this.UpdateTime = updateTime; - this.CreateTime = createTime; - this.DisplayName = displayName; - this.InputConfig = inputConfig; - this.EndTime = endTime; this.Model = model; - this.Priority = priority; + this.EndTime = endTime; this.Name = name; + this.Output = output; + this.CreateTime = createTime; this.BatchStats = batchStats; + this.UpdateTime = updateTime; + this.Priority = priority; + this.InputConfig = inputConfig; + this.DisplayName = displayName; this.State = state; } 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 66e4698b..d69ec48e 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,32 +9,32 @@ namespace Google.Gemini public sealed partial class EmbedContentBatchStats { /// - /// Output only. The number of requests that failed to be processed.
+ /// Output only. The number of requests in the batch.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("failedRequestCount")] - public string? FailedRequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("requestCount")] + public string? RequestCount { get; set; } /// - /// Output only. The number of requests that are still pending processing.
+ /// Output only. The number of requests that were successfully processed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("pendingRequestCount")] - public string? PendingRequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("successfulRequestCount")] + public string? SuccessfulRequestCount { get; set; } /// - /// Output only. The number of requests that were successfully processed.
+ /// Output only. The number of requests that failed to be processed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("successfulRequestCount")] - public string? SuccessfulRequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("failedRequestCount")] + public string? FailedRequestCount { get; set; } /// - /// Output only. The number of requests in the batch.
+ /// Output only. The number of requests that are still pending processing.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("requestCount")] - public string? RequestCount { 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 failed to be processed.
- /// Included only in responses - /// - /// - /// Output only. The number of requests that are still pending processing.
+ /// + /// Output only. The number of requests in the batch.
/// Included only in responses /// /// /// Output only. The number of requests that were successfully processed.
/// Included only in responses /// - /// - /// Output only. The number of requests in the batch.
+ /// + /// 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 /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentBatchStats( - string? failedRequestCount, - string? pendingRequestCount, + string? requestCount, string? successfulRequestCount, - string? requestCount) + string? failedRequestCount, + string? pendingRequestCount) { + this.RequestCount = requestCount; + this.SuccessfulRequestCount = successfulRequestCount; this.FailedRequestCount = failedRequestCount; this.PendingRequestCount = pendingRequestCount; - this.SuccessfulRequestCount = successfulRequestCount; - this.RequestCount = requestCount; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentConfig.g.cs index 3555edea..49537e65 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentConfig.g.cs @@ -8,18 +8,6 @@ namespace Google.Gemini /// public sealed partial class EmbedContentConfig { - /// - /// Optional. Reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("outputDimensionality")] - public int? OutputDimensionality { get; set; } - - /// - /// Optional. Whether to enable OCR for document content. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("documentOcr")] - public bool? DocumentOcr { get; set; } - /// /// Optional. The task type of the embedding. /// @@ -28,10 +16,10 @@ public sealed partial class EmbedContentConfig public global::Google.Gemini.EmbedContentConfigTaskType? TaskType { get; set; } /// - /// Optional. The title for the text. + /// Optional. Whether to enable OCR for document content. /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - public string? Title { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("documentOcr")] + public bool? DocumentOcr { get; set; } /// /// Optional. Whether to extract audio from video content. @@ -45,6 +33,18 @@ public sealed partial class EmbedContentConfig [global::System.Text.Json.Serialization.JsonPropertyName("autoTruncate")] public bool? AutoTruncate { get; set; } + /// + /// Optional. The title for the text. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("title")] + public string? Title { get; set; } + + /// + /// Optional. Reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("outputDimensionality")] + public int? OutputDimensionality { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -54,17 +54,11 @@ public sealed partial class EmbedContentConfig /// /// Initializes a new instance of the class. /// - /// - /// Optional. Reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. - /// - /// - /// Optional. Whether to enable OCR for document content. - /// /// /// Optional. The task type of the embedding. /// - /// - /// Optional. The title for the text. + /// + /// Optional. Whether to enable OCR for document content. /// /// /// Optional. Whether to extract audio from video content. @@ -72,23 +66,29 @@ public sealed partial class EmbedContentConfig /// /// Optional. Whether to silently truncate the input content if it's longer than the maximum sequence length. /// + /// + /// Optional. The title for the text. + /// + /// + /// Optional. Reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentConfig( - int? outputDimensionality, - bool? documentOcr, global::Google.Gemini.EmbedContentConfigTaskType? taskType, - string? title, + bool? documentOcr, bool? audioTrackExtraction, - bool? autoTruncate) + bool? autoTruncate, + string? title, + int? outputDimensionality) { - this.OutputDimensionality = outputDimensionality; - this.DocumentOcr = documentOcr; this.TaskType = taskType; - this.Title = title; + this.DocumentOcr = documentOcr; this.AudioTrackExtraction = audioTrackExtraction; this.AutoTruncate = autoTruncate; + this.Title = title; + this.OutputDimensionality = outputDimensionality; } /// 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 b4430987..2fb50d30 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 @@ -10,13 +10,6 @@ namespace Google.Gemini /// public sealed partial class EmbedContentRequest { - /// - /// Optional. Deprecated: Please use EmbedContentConfig.title instead. 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. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - [global::System.Obsolete("This property marked as deprecated.")] - public string? Title { 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. /// @@ -24,23 +17,24 @@ public sealed partial class EmbedContentRequest public global::Google.Gemini.Content? Content { get; set; } /// - /// 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}` + /// Configurations for the EmbedContent request. /// - [global::System.Text.Json.Serialization.JsonPropertyName("model")] - public string? Model { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("embedContentConfig")] + public global::Google.Gemini.EmbedContentConfig? EmbedContentConfig { get; set; } /// - /// Optional. Deprecated: Please use EmbedContentConfig.output_dimensionality instead. 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`). + /// Optional. Deprecated: Please use EmbedContentConfig.title instead. 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("outputDimensionality")] + [global::System.Text.Json.Serialization.JsonPropertyName("title")] [global::System.Obsolete("This property marked as deprecated.")] - public int? OutputDimensionality { get; set; } + public string? Title { get; set; } /// - /// Configurations for the EmbedContent request. + /// Optional. Deprecated: Please use EmbedContentConfig.output_dimensionality instead. 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("embedContentConfig")] - public global::Google.Gemini.EmbedContentConfig? EmbedContentConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("outputDimensionality")] + [global::System.Obsolete("This property marked as deprecated.")] + public int? OutputDimensionality { get; set; } /// /// Optional. Deprecated: Please use EmbedContentConfig.task_type instead. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`). @@ -50,6 +44,12 @@ public sealed partial class EmbedContentRequest [global::System.Obsolete("This property marked as deprecated.")] public global::Google.Gemini.EmbedContentRequestTaskType? TaskType { get; set; } + /// + /// 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}` + /// + [global::System.Text.Json.Serialization.JsonPropertyName("model")] + public string? Model { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -62,23 +62,23 @@ public sealed partial class EmbedContentRequest /// /// 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 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}` - /// /// /// Configurations for the EmbedContent request. /// + /// + /// 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}` + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentRequest( global::Google.Gemini.Content? content, - string? model, - global::Google.Gemini.EmbedContentConfig? embedContentConfig) + global::Google.Gemini.EmbedContentConfig? embedContentConfig, + string? model) { this.Content = content; - this.Model = model; this.EmbedContentConfig = embedContentConfig; + this.Model = model; } /// 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 1de5992f..f9f4e11f 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 985815c4..95b96482 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,38 +9,31 @@ namespace Google.Gemini public sealed partial class File { /// - /// Output only. SHA-256 hash of the uploaded bytes.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("sha256Hash")] - public byte[]? Sha256Hash { get; set; } - - /// - /// Output only. Processing state 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("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("expirationTime")] + public string? ExpirationTime { get; set; } /// - /// Output only. The uri of the `File`.
+ /// Output only. The timestamp of when the `File` was last updated.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("uri")] - public string? Uri { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { 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). + /// Source of the File. /// - [global::System.Text.Json.Serialization.JsonPropertyName("error")] - public global::Google.Gemini.Status? Error { 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`. + /// 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` /// - [global::System.Text.Json.Serialization.JsonPropertyName("videoMetadata")] - public global::Google.Gemini.VideoFileMetadata? VideoMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// /// Output only. MIME type of the file.
@@ -50,31 +43,37 @@ public sealed partial class File public string? MimeType { get; set; } /// - /// Output only. The timestamp of when the `File` was created.
+ /// Output only. Size of the file in bytes.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] + public string? SizeBytes { get; set; } /// - /// Source of the File. + /// Output only. SHA-256 hash of the uploaded bytes.
+ /// Included only in responses ///
- [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("sha256Hash")] + public byte[]? Sha256Hash { get; set; } /// - /// Output only. Size of the file in bytes.
- /// Included only in responses + /// Metadata for a video `File`. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] - public string? SizeBytes { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("videoMetadata")] + public global::Google.Gemini.VideoFileMetadata? VideoMetadata { 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` + /// 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("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("error")] + public global::Google.Gemini.Status? Error { get; set; } + + /// + /// Output only. The uri of the `File`.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("uri")] + public string? Uri { get; set; } /// /// Output only. The download uri of the `File`.
@@ -84,24 +83,25 @@ public sealed partial class File 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" + /// Output only. The timestamp of when the `File` 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 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.
- /// Included only in responses + /// 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("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -112,90 +112,90 @@ public sealed partial class File /// /// Initializes a new instance of the class. /// - /// - /// Output only. SHA-256 hash of the uploaded bytes.
- /// Included only in responses - /// - /// - /// Output only. Processing state 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 /// - /// - /// Output only. The uri of the `File`.
+ /// + /// Output only. The timestamp of when the `File` was last updated.
/// 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). + /// + /// Source of the File. /// - /// - /// Metadata for a video `File`. + /// + /// 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. MIME type of the file.
/// Included only in responses /// - /// - /// Output only. The timestamp of when the `File` was created.
- /// Included only in responses - /// - /// - /// Source of the File. - /// /// /// Output only. Size of the file in bytes.
/// Included only in responses /// - /// - /// 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. SHA-256 hash of the uploaded bytes.
+ /// Included only in responses + /// + /// + /// Metadata for a video `File`. + /// + /// + /// 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. The uri of the `File`.
+ /// Included only in responses /// /// /// Output only. The download uri of the `File`.
/// Included only in responses /// - /// - /// 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. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.
+ /// + /// Output only. The timestamp of when the `File` was created.
/// Included only in responses /// - /// - /// Output only. The timestamp of when the `File` was last updated.
+ /// + /// Output only. Processing state of the File.
/// Included only in responses /// + /// + /// 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" + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public File( - byte[]? sha256Hash, - global::Google.Gemini.FileState? state, - string? uri, - global::Google.Gemini.Status? error, - global::Google.Gemini.VideoFileMetadata? videoMetadata, - string? mimeType, - string? createTime, + string? expirationTime, + string? updateTime, global::Google.Gemini.FileSource? source, - string? sizeBytes, string? name, + string? mimeType, + string? sizeBytes, + byte[]? sha256Hash, + global::Google.Gemini.VideoFileMetadata? videoMetadata, + global::Google.Gemini.Status? error, + string? uri, string? downloadUri, - string? displayName, - string? expirationTime, - string? updateTime) + string? createTime, + global::Google.Gemini.FileState? state, + string? displayName) { - this.Sha256Hash = sha256Hash; - this.State = state; - this.Uri = uri; - this.Error = error; - this.VideoMetadata = videoMetadata; - this.MimeType = mimeType; - this.CreateTime = createTime; + this.ExpirationTime = expirationTime; + this.UpdateTime = updateTime; this.Source = source; - this.SizeBytes = sizeBytes; this.Name = name; + this.MimeType = mimeType; + this.SizeBytes = sizeBytes; + this.Sha256Hash = sha256Hash; + this.VideoMetadata = videoMetadata; + this.Error = error; + this.Uri = uri; this.DownloadUri = downloadUri; + this.CreateTime = createTime; + this.State = state; this.DisplayName = displayName; - this.ExpirationTime = expirationTime; - this.UpdateTime = updateTime; } /// 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 d30e17d7..01fd3e3c 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 @@ -8,6 +8,13 @@ namespace Google.Gemini /// public sealed partial class FileSearchStore { + /// + /// 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("name")] + public string? Name { get; set; } + /// /// Output only. The Timestamp of when the `FileSearchStore` was created.
/// Included only in responses @@ -16,30 +23,32 @@ public sealed partial class FileSearchStore public string? CreateTime { 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; } /// - /// 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 last updated.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } /// - /// Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used. + /// 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 ///
- [global::System.Text.Json.Serialization.JsonPropertyName("embeddingModel")] - public string? EmbeddingModel { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] + public string? SizeBytes { 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.
+ /// Output only. The number of documents in the `FileSearchStore` that have failed processing.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [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.
@@ -49,25 +58,16 @@ public sealed partial class FileSearchStore public string? ActiveDocumentsCount { get; set; } /// - /// Output only. The number of documents in the `FileSearchStore` that are being processed.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("pendingDocumentsCount")] - public string? PendingDocumentsCount { get; set; } - - /// - /// Output only. The number of documents in the `FileSearchStore` that have failed processing.
- /// Included only in responses + /// Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("failedDocumentsCount")] - public string? FailedDocumentsCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("embeddingModel")] + public string? EmbeddingModel { 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`.
- /// 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" ///
- [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] - public string? SizeBytes { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -78,63 +78,63 @@ public sealed partial class FileSearchStore /// /// Initializes a new instance of the class. /// + /// + /// 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 created.
/// Included only in responses /// + /// + /// Output only. The number of documents in the `FileSearchStore` that are being processed.
+ /// Included only in responses + /// /// /// Output only. The Timestamp of when the `FileSearchStore` was last updated.
/// 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" - /// - /// - /// Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used. + /// + /// 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. 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 /// /// /// Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.
/// Included only in responses /// - /// - /// Output only. The number of documents in the `FileSearchStore` that are being processed.
- /// Included only in responses - /// - /// - /// Output only. The number of documents in the `FileSearchStore` that have failed processing.
- /// Included only in responses + /// + /// Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used. /// - /// - /// 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 + /// + /// 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" /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FileSearchStore( - string? createTime, - string? updateTime, - string? displayName, - string? embeddingModel, string? name, - string? activeDocumentsCount, + string? createTime, string? pendingDocumentsCount, + string? updateTime, + string? sizeBytes, string? failedDocumentsCount, - string? sizeBytes) + string? activeDocumentsCount, + string? embeddingModel, + string? displayName) { - this.CreateTime = createTime; - this.UpdateTime = updateTime; - this.DisplayName = displayName; - this.EmbeddingModel = embeddingModel; this.Name = name; - this.ActiveDocumentsCount = activeDocumentsCount; + this.CreateTime = createTime; this.PendingDocumentsCount = pendingDocumentsCount; - this.FailedDocumentsCount = failedDocumentsCount; + this.UpdateTime = updateTime; this.SizeBytes = sizeBytes; + this.FailedDocumentsCount = failedDocumentsCount; + this.ActiveDocumentsCount = activeDocumentsCount; + this.EmbeddingModel = embeddingModel; + this.DisplayName = displayName; } /// 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 461b1947..fb31f04a 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; } - /// /// Optional. The function parameters and values in JSON object format. /// [global::System.Text.Json.Serialization.JsonPropertyName("args")] public object? Args { 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; } + /// /// 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. /// @@ -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`. - /// /// /// Optional. The function parameters and values in JSON object format. /// + /// + /// 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. /// @@ -48,12 +48,12 @@ public sealed partial class FunctionCall [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionCall( - string? id, object? args, + string? id, string? name) { - this.Id = id; this.Args = args; + this.Id = id; this.Name = name; } 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 ea38a151..6d0c862a 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,16 +9,17 @@ namespace Google.Gemini public sealed partial class FunctionDeclaration { /// - /// 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 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("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseJsonSchema")] + public object? ResponseJsonSchema { get; set; } /// - /// 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. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method. /// - [global::System.Text.Json.Serialization.JsonPropertyName("parametersJsonSchema")] - public object? ParametersJsonSchema { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("behavior")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorJsonConverter))] + public global::Google.Gemini.FunctionDeclarationBehavior? Behavior { 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). @@ -26,12 +27,6 @@ public sealed partial class FunctionDeclaration [global::System.Text.Json.Serialization.JsonPropertyName("parameters")] public global::Google.Gemini.Schema? Parameters { get; set; } - /// - /// Required. A brief description of the function. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("description")] - public string? Description { 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). /// @@ -39,17 +34,22 @@ public sealed partial class FunctionDeclaration public global::Google.Gemini.Schema? Response { 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`. + /// Required. A brief description of the function. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseJsonSchema")] - public object? ResponseJsonSchema { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("description")] + public string? Description { get; set; } /// - /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("behavior")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorJsonConverter))] - public global::Google.Gemini.FunctionDeclarationBehavior? Behavior { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } + + /// + /// 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("parametersJsonSchema")] + public object? ParametersJsonSchema { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -60,46 +60,46 @@ public sealed partial class FunctionDeclaration /// /// Initializes a new instance of the class. /// - /// - /// 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 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`. + /// + /// Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method. /// /// /// 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. A brief description of the function. - /// /// /// 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. A brief description of the function. /// - /// - /// 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. + /// + /// + /// 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`. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionDeclaration( - string? name, - object? parametersJsonSchema, + object? responseJsonSchema, + global::Google.Gemini.FunctionDeclarationBehavior? behavior, global::Google.Gemini.Schema? parameters, - string? description, global::Google.Gemini.Schema? response, - object? responseJsonSchema, - global::Google.Gemini.FunctionDeclarationBehavior? behavior) + string? description, + string? name, + object? parametersJsonSchema) { - this.Name = name; - this.ParametersJsonSchema = parametersJsonSchema; - this.Parameters = parameters; - this.Description = description; - this.Response = response; this.ResponseJsonSchema = responseJsonSchema; this.Behavior = behavior; + this.Parameters = parameters; + this.Response = response; + this.Description = description; + this.Name = name; + this.ParametersJsonSchema = parametersJsonSchema; } /// 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 304c906d..16e8c7f9 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 @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class FunctionResponse { + /// + /// 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; } + /// /// 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. /// @@ -26,12 +32,6 @@ public sealed partial class FunctionResponse [global::System.Text.Json.Serialization.JsonPropertyName("parts")] public global::System.Collections.Generic.IList? Parts { 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. 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`. /// @@ -54,6 +54,9 @@ public sealed partial class FunctionResponse /// /// Initializes a new instance of the class. /// + /// + /// 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. + /// /// /// 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. /// @@ -63,9 +66,6 @@ public sealed partial class FunctionResponse /// /// Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types. /// - /// - /// 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. 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`. /// @@ -76,17 +76,17 @@ public sealed partial class FunctionResponse [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionResponse( + string? name, object? response, string? id, global::System.Collections.Generic.IList? parts, - string? name, bool? willContinue, global::Google.Gemini.FunctionResponseScheduling? scheduling) { + this.Name = name; this.Response = response; this.Id = id; this.Parts = parts; - this.Name = name; this.WillContinue = willContinue; this.Scheduling = scheduling; } 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 daa1f40c..d6e2966e 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 @@ -9,23 +9,24 @@ namespace Google.Gemini public sealed partial class GenerateContentBatch { /// - /// Required. The user-defined name of this batch. + /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// - /// Configures the input to the batch request. + /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. /// - [global::System.Text.Json.Serialization.JsonPropertyName("inputConfig")] - public global::Google.Gemini.InputConfig? InputConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("output")] + public global::Google.Gemini.GenerateContentBatchOutput? Output { 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; } /// /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. @@ -34,17 +35,11 @@ public sealed partial class GenerateContentBatch public string? Model { get; set; } /// - /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("output")] - public global::Google.Gemini.GenerateContentBatchOutput? Output { get; set; } - - /// - /// Output only. The time at which the batch was created.
+ /// Output only. The time at which the batch processing completed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] + public string? EndTime { get; set; } /// /// Output only. The time at which the batch was last updated.
@@ -53,6 +48,12 @@ public sealed partial class GenerateContentBatch [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] public string? UpdateTime { 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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("priority")] + public string? Priority { get; set; } + /// /// Stats about the batch. /// @@ -68,17 +69,16 @@ public sealed partial class GenerateContentBatch public global::Google.Gemini.GenerateContentBatchState? State { 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. + /// Configures the input to the batch request. /// - [global::System.Text.Json.Serialization.JsonPropertyName("priority")] - public string? Priority { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("inputConfig")] + public global::Google.Gemini.InputConfig? InputConfig { get; set; } /// - /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
- /// Included only in responses + /// Required. The user-defined name of this batch. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -89,19 +89,10 @@ public sealed partial class GenerateContentBatch /// /// Initializes a new instance of the class. /// - /// - /// Required. The user-defined name of this batch. - /// - /// - /// Configures the input to the batch request. - /// - /// - /// Output only. The time at which the batch processing completed.
+ /// + /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
/// Included only in responses /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// /// /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. /// @@ -109,10 +100,20 @@ public sealed partial class GenerateContentBatch /// Output only. The time at which the batch was created.
/// 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 processing completed.
+ /// Included only in responses + /// /// /// Output only. The time at which the batch was last updated.
/// 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. + /// /// /// Stats about the batch. /// @@ -120,40 +121,39 @@ public sealed partial class GenerateContentBatch /// Output only. The state of the batch.
/// 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. + /// + /// Configures the input to the batch request. /// - /// - /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
- /// Included only in responses + /// + /// Required. The user-defined name of this batch. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerateContentBatch( - string? displayName, - global::Google.Gemini.InputConfig? inputConfig, - string? endTime, - string? model, + string? name, global::Google.Gemini.GenerateContentBatchOutput? output, string? createTime, + string? model, + string? endTime, string? updateTime, + string? priority, global::Google.Gemini.BatchStats? batchStats, global::Google.Gemini.GenerateContentBatchState? state, - string? priority, - string? name) + global::Google.Gemini.InputConfig? inputConfig, + string? displayName) { - this.DisplayName = displayName; - this.InputConfig = inputConfig; - this.EndTime = endTime; - this.Model = model; + this.Name = name; this.Output = output; this.CreateTime = createTime; + this.Model = model; + this.EndTime = endTime; this.UpdateTime = updateTime; + this.Priority = priority; this.BatchStats = batchStats; this.State = state; - this.Priority = priority; - this.Name = name; + this.InputConfig = inputConfig; + this.DisplayName = displayName; } /// 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 bae6a2c7..d1181b62 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 @@ -9,22 +9,22 @@ namespace Google.Gemini public sealed partial class GenerateContentRequest { /// - /// 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. + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("tools")] - public global::System.Collections.Generic.IList? Tools { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("generationConfig")] + public global::Google.Gemini.GenerationConfig? GenerationConfig { 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}` + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("cachedContent")] - public string? CachedContent { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("model")] + public string? Model { get; set; } /// - /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("toolConfig")] - public global::Google.Gemini.ToolConfig? ToolConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("systemInstruction")] + public global::Google.Gemini.Content? SystemInstruction { get; set; } /// /// Optional. The service tier of the request. @@ -34,40 +34,40 @@ public sealed partial class GenerateContentRequest public global::Google.Gemini.GenerateContentRequestServiceTier? ServiceTier { 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. + /// 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("systemInstruction")] - public global::Google.Gemini.Content? SystemInstruction { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("contents")] + public global::System.Collections.Generic.IList? Contents { 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. + /// 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}` /// - [global::System.Text.Json.Serialization.JsonPropertyName("safetySettings")] - public global::System.Collections.Generic.IList? SafetySettings { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("cachedContent")] + public string? CachedContent { 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. + /// 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("contents")] - public global::System.Collections.Generic.IList? Contents { get; set; } + [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. + /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("generationConfig")] - public global::Google.Gemini.GenerationConfig? GenerationConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("safetySettings")] + public global::System.Collections.Generic.IList? SafetySettings { 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. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// 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("store")] - public bool? Store { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("tools")] + public global::System.Collections.Generic.IList? Tools { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -78,61 +78,61 @@ public sealed partial class GenerateContentRequest /// /// Initializes a new instance of the class. /// - /// - /// 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. - /// - /// - /// 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}` - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// 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. 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. + /// + /// Optional. The service tier of 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// 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. + /// + /// + /// 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. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerateContentRequest( - global::System.Collections.Generic.IList? tools, - string? cachedContent, - global::Google.Gemini.ToolConfig? toolConfig, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier, - global::Google.Gemini.Content? systemInstruction, - global::System.Collections.Generic.IList? safetySettings, - global::System.Collections.Generic.IList? contents, global::Google.Gemini.GenerationConfig? generationConfig, string? model, - bool? store) + global::Google.Gemini.Content? systemInstruction, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier, + global::System.Collections.Generic.IList? contents, + string? cachedContent, + bool? store, + global::System.Collections.Generic.IList? safetySettings, + global::Google.Gemini.ToolConfig? toolConfig, + global::System.Collections.Generic.IList? tools) { - this.Tools = tools; - this.CachedContent = cachedContent; - this.ToolConfig = toolConfig; - this.ServiceTier = serviceTier; - this.SystemInstruction = systemInstruction; - this.SafetySettings = safetySettings; - this.Contents = contents; this.GenerationConfig = generationConfig; this.Model = model; + this.SystemInstruction = systemInstruction; + this.ServiceTier = serviceTier; + this.Contents = contents; + this.CachedContent = cachedContent; this.Store = store; + this.SafetySettings = safetySettings; + this.ToolConfig = toolConfig; + this.Tools = tools; } /// 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 ba81241f..f637c2d1 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 @@ -9,10 +9,17 @@ namespace Google.Gemini public sealed partial class GenerateContentResponse { /// - /// Candidate responses from the model. + /// Metadata on the generation request's token usage. /// - [global::System.Text.Json.Serialization.JsonPropertyName("candidates")] - public global::System.Collections.Generic.IList? Candidates { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] + public global::Google.Gemini.UsageMetadata? UsageMetadata { get; set; } + + /// + /// Output only. response_id is used to identify each response.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("responseId")] + public string? ResponseId { 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. @@ -28,23 +35,16 @@ public sealed partial class GenerateContentResponse public string? ModelVersion { get; set; } /// - /// A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("promptFeedback")] - public global::Google.Gemini.PromptFeedback? PromptFeedback { get; set; } - - /// - /// Metadata on the generation request's token usage. + /// Candidate responses from the model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] - public global::Google.Gemini.UsageMetadata? UsageMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("candidates")] + public global::System.Collections.Generic.IList? Candidates { get; set; } /// - /// Output only. response_id is used to identify each response.
- /// Included only in responses + /// A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("responseId")] - public string? ResponseId { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("promptFeedback")] + public global::Google.Gemini.PromptFeedback? PromptFeedback { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -55,8 +55,12 @@ public sealed partial class GenerateContentResponse /// /// Initializes a new instance of the class. /// - /// - /// Candidate responses from the model. + /// + /// Metadata on the generation request's token usage. + /// + /// + /// Output only. response_id is used to identify each response.
+ /// Included only in responses /// /// /// The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable. @@ -65,33 +69,29 @@ public sealed partial class GenerateContentResponse /// 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`. /// - /// - /// Metadata on the generation request's token usage. - /// - /// - /// Output only. response_id is used to identify each response.
- /// Included only in responses - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerateContentResponse( - global::System.Collections.Generic.IList? candidates, + global::Google.Gemini.UsageMetadata? usageMetadata, + string? responseId, global::Google.Gemini.ModelStatus? modelStatus, string? modelVersion, - global::Google.Gemini.PromptFeedback? promptFeedback, - global::Google.Gemini.UsageMetadata? usageMetadata, - string? responseId) + global::System.Collections.Generic.IList? candidates, + global::Google.Gemini.PromptFeedback? promptFeedback) { - this.Candidates = candidates; + this.UsageMetadata = usageMetadata; + this.ResponseId = responseId; this.ModelStatus = modelStatus; this.ModelVersion = modelVersion; + this.Candidates = candidates; this.PromptFeedback = promptFeedback; - this.UsageMetadata = usageMetadata; - this.ResponseId = responseId; } /// 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 d205e333..6ccb535e 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,12 +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; } - /// /// Identifier. The name of the generated file. Example: `generatedFiles/abc-123` /// @@ -28,6 +22,12 @@ public sealed partial class GeneratedFile [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateJsonConverter))] public global::Google.Gemini.GeneratedFileState? State { 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; } + /// /// MIME type of the generatedFile. /// @@ -43,9 +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). - /// /// /// Identifier. The name of the generated file. Example: `generatedFiles/abc-123` /// @@ -53,6 +50,9 @@ public sealed partial class GeneratedFile /// Output only. The state of the GeneratedFile.
/// 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). + /// /// /// MIME type of the generatedFile. /// @@ -60,14 +60,14 @@ public sealed partial class GeneratedFile [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GeneratedFile( - global::Google.Gemini.Status? error, string? name, global::Google.Gemini.GeneratedFileState? state, + global::Google.Gemini.Status? error, string? mimeType) { - this.Error = error; this.Name = name; this.State = state; + this.Error = error; this.MimeType = mimeType; } 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 38348946..7eaab810 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 @@ -9,83 +9,70 @@ namespace Google.Gemini public sealed partial class GenerationConfig { /// - /// 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. 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("temperature")] - public float? Temperature { 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) + /// 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("candidateCount")] - public int? CandidateCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topK")] + public int? TopK { 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. + /// 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("maxOutputTokens")] - public int? MaxOutputTokens { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("stopSequences")] + public global::System.Collections.Generic.IList? StopSequences { get; set; } /// - /// Optional. Seed used in decoding. If not set, the request uses a randomly generated seed. + /// 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("seed")] - public int? Seed { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] + public float? Temperature { get; set; } /// - /// Optional. An internal detail. Use `responseJsonSchema` rather than this field. + /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseJsonSchema")] - public object? ResponseJsonSchema { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topP")] + public float? TopP { get; set; } /// - /// Optional. If specified, the media resolution specified will be used. + /// 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("mediaResolution")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionJsonConverter))] - public global::Google.Gemini.GenerationConfigMediaResolution? MediaResolution { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseSchema")] + public global::Google.Gemini.Schema? ResponseSchema { get; set; } /// - /// Optional. If true, export the logprobs results in response. + /// Config for speech generation and transcription. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseLogprobs")] - public bool? ResponseLogprobs { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("speechConfig")] + public global::Google.Gemini.SpeechConfig? SpeechConfig { 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. + /// Config for thinking features. /// - [global::System.Text.Json.Serialization.JsonPropertyName("stopSequences")] - public global::System.Collections.Generic.IList? StopSequences { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("thinkingConfig")] + public global::Google.Gemini.ThinkingConfig? ThinkingConfig { get; set; } /// - /// Config for speech generation and transcription. + /// 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("speechConfig")] - public global::Google.Gemini.SpeechConfig? SpeechConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseMimeType")] + public string? ResponseMimeType { 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. + /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("topP")] - public float? TopP { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxOutputTokens")] + public int? MaxOutputTokens { get; set; } /// - /// Optional. Enables enhanced civic answers. It may not be available for all models. + /// Optional. An internal detail. Use `responseJsonSchema` rather than this field. /// - [global::System.Text.Json.Serialization.JsonPropertyName("enableEnhancedCivicAnswers")] - public bool? EnableEnhancedCivicAnswers { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseJsonSchema")] + public object? ResponseJsonSchema { 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. + /// Optional. If true, export the logprobs results in response. /// - [global::System.Text.Json.Serialization.JsonPropertyName("presencePenalty")] - public float? PresencePenalty { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseLogprobs")] + public bool? ResponseLogprobs { get; set; } /// /// 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. @@ -94,16 +81,22 @@ public sealed partial class GenerationConfig public global::System.Collections.Generic.IList? ResponseModalities { 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. 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("topK")] - public int? TopK { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("frequencyPenalty")] + public float? FrequencyPenalty { get; set; } /// - /// Config for thinking features. + /// 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("thinkingConfig")] - public global::Google.Gemini.ThinkingConfig? ThinkingConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("logprobs")] + public int? Logprobs { get; set; } + + /// + /// Optional. Enables enhanced civic answers. It may not be available for all models. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("enableEnhancedCivicAnswers")] + public bool? EnableEnhancedCivicAnswers { get; set; } /// /// Config for image generation features. @@ -112,22 +105,29 @@ public sealed partial class GenerationConfig public global::Google.Gemini.ImageConfig? ImageConfig { 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). + /// Optional. If specified, the media resolution specified will be used. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseSchema")] - public global::Google.Gemini.Schema? ResponseSchema { get; set; } + [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. + /// Optional. Seed used in decoding. If not set, the request uses a randomly generated seed. /// - [global::System.Text.Json.Serialization.JsonPropertyName("frequencyPenalty")] - public float? FrequencyPenalty { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("seed")] + public int? Seed { 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. 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) /// - [global::System.Text.Json.Serialization.JsonPropertyName("logprobs")] - public int? Logprobs { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("candidateCount")] + public int? CandidateCount { 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; } /// /// Additional properties that are not explicitly defined in the schema @@ -138,111 +138,111 @@ public sealed partial class GenerationConfig /// /// Initializes a new instance of the class. /// - /// - /// 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. 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 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. 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. 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. + /// + /// + /// 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). + /// + /// + /// Config for speech generation and transcription. + /// + /// + /// Config for thinking features. + /// + /// + /// 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. 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. /// - /// - /// Optional. Seed used in decoding. If not set, the request uses a randomly generated seed. - /// /// /// Optional. An internal detail. Use `responseJsonSchema` rather than this field. /// - /// - /// Optional. If specified, the media resolution specified will be used. - /// /// /// Optional. If true, export the logprobs results in response. /// - /// - /// 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. 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. /// - /// - /// Config for speech generation and transcription. + /// + /// 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. 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. Enables enhanced civic answers. It may not be available for all models. /// - /// - /// 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. 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. 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 thinking features. - /// /// /// Config for image generation features. /// - /// - /// 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. Seed used in decoding. If not set, the request uses a randomly generated seed. /// - /// - /// 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. 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. 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. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerationConfig( - string? responseMimeType, + int? topK, + global::System.Collections.Generic.IList? stopSequences, float? temperature, - int? candidateCount, + float? topP, + global::Google.Gemini.Schema? responseSchema, + global::Google.Gemini.SpeechConfig? speechConfig, + global::Google.Gemini.ThinkingConfig? thinkingConfig, + string? responseMimeType, int? maxOutputTokens, - int? seed, object? responseJsonSchema, - global::Google.Gemini.GenerationConfigMediaResolution? mediaResolution, bool? responseLogprobs, - global::System.Collections.Generic.IList? stopSequences, - global::Google.Gemini.SpeechConfig? speechConfig, - float? topP, - bool? enableEnhancedCivicAnswers, - float? presencePenalty, global::System.Collections.Generic.IList? responseModalities, - int? topK, - global::Google.Gemini.ThinkingConfig? thinkingConfig, - global::Google.Gemini.ImageConfig? imageConfig, - global::Google.Gemini.Schema? responseSchema, float? frequencyPenalty, - int? logprobs) + int? logprobs, + bool? enableEnhancedCivicAnswers, + global::Google.Gemini.ImageConfig? imageConfig, + global::Google.Gemini.GenerationConfigMediaResolution? mediaResolution, + int? seed, + int? candidateCount, + float? presencePenalty) { - this.ResponseMimeType = responseMimeType; + this.TopK = topK; + this.StopSequences = stopSequences; this.Temperature = temperature; - this.CandidateCount = candidateCount; + this.TopP = topP; + this.ResponseSchema = responseSchema; + this.SpeechConfig = speechConfig; + this.ThinkingConfig = thinkingConfig; + this.ResponseMimeType = responseMimeType; this.MaxOutputTokens = maxOutputTokens; - this.Seed = seed; this.ResponseJsonSchema = responseJsonSchema; - this.MediaResolution = mediaResolution; this.ResponseLogprobs = responseLogprobs; - this.StopSequences = stopSequences; - this.SpeechConfig = speechConfig; - this.TopP = topP; - this.EnableEnhancedCivicAnswers = enableEnhancedCivicAnswers; - this.PresencePenalty = presencePenalty; this.ResponseModalities = responseModalities; - this.TopK = topK; - this.ThinkingConfig = thinkingConfig; - this.ImageConfig = imageConfig; - this.ResponseSchema = responseSchema; this.FrequencyPenalty = frequencyPenalty; this.Logprobs = logprobs; + this.EnableEnhancedCivicAnswers = enableEnhancedCivicAnswers; + this.ImageConfig = imageConfig; + this.MediaResolution = mediaResolution; + this.Seed = seed; + this.CandidateCount = candidateCount; + this.PresencePenalty = presencePenalty; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleSearch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleSearch.g.cs index bcc9b423..36454462 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleSearch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleSearch.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class GoogleSearch { - /// - /// 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. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("timeRangeFilter")] - public global::Google.Gemini.Interval? TimeRangeFilter { get; set; } - /// /// Different types of search that can be enabled on the GoogleSearch tool. /// [global::System.Text.Json.Serialization.JsonPropertyName("searchTypes")] public global::Google.Gemini.SearchTypes? SearchTypes { get; set; } + /// + /// 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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("timeRangeFilter")] + public global::Google.Gemini.Interval? TimeRangeFilter { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class GoogleSearch /// /// Initializes a new instance of the class. /// - /// - /// 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. - /// /// /// Different types of search that can be enabled on the GoogleSearch tool. /// + /// + /// 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. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GoogleSearch( - global::Google.Gemini.Interval? timeRangeFilter, - global::Google.Gemini.SearchTypes? searchTypes) + global::Google.Gemini.SearchTypes? searchTypes, + global::Google.Gemini.Interval? timeRangeFilter) { - this.TimeRangeFilter = timeRangeFilter; this.SearchTypes = searchTypes; + this.TimeRangeFilter = timeRangeFilter; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingAttribution.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingAttribution.g.cs index 26223c8f..fadfe83a 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingAttribution.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingAttribution.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class GroundingAttribution { - /// - /// Identifier for the source contributing to this attribution. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("sourceId")] - public global::Google.Gemini.AttributionSourceId? SourceId { 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; } + /// + /// Identifier for the source contributing to this attribution. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("sourceId")] + public global::Google.Gemini.AttributionSourceId? SourceId { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class GroundingAttribution /// /// Initializes a new instance of the class. /// - /// - /// Identifier for the source contributing to this attribution. - /// /// /// 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. /// + /// + /// Identifier for the source contributing to this attribution. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingAttribution( - global::Google.Gemini.AttributionSourceId? sourceId, - global::Google.Gemini.Content? content) + global::Google.Gemini.Content? content, + global::Google.Gemini.AttributionSourceId? sourceId) { - this.SourceId = sourceId; this.Content = content; + this.SourceId = sourceId; } /// 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 ac519a57..9f8b9a43 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 @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class GroundingChunk { /// - /// Chunk from the web. + /// Chunk from image search. /// - [global::System.Text.Json.Serialization.JsonPropertyName("web")] - public global::Google.Gemini.Web? Web { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("image")] + public global::Google.Gemini.Image? Image { get; set; } /// /// Chunk from context retrieved by the file search tool. @@ -21,10 +21,10 @@ public sealed partial class GroundingChunk public global::Google.Gemini.RetrievedContext? RetrievedContext { get; set; } /// - /// Chunk from image search. + /// Chunk from the web. /// - [global::System.Text.Json.Serialization.JsonPropertyName("image")] - public global::Google.Gemini.Image? Image { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("web")] + public global::Google.Gemini.Web? Web { get; set; } /// /// A grounding chunk from Google Maps. A Maps chunk corresponds to a single place. @@ -41,14 +41,14 @@ public sealed partial class GroundingChunk /// /// Initializes a new instance of the class. /// - /// - /// Chunk from the web. + /// + /// Chunk from image search. /// /// /// Chunk from context retrieved by the file search tool. /// - /// - /// Chunk from image search. + /// + /// Chunk from the web. /// /// /// A grounding chunk from Google Maps. A Maps chunk corresponds to a single place. @@ -57,14 +57,14 @@ public sealed partial class GroundingChunk [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingChunk( - global::Google.Gemini.Web? web, - global::Google.Gemini.RetrievedContext? retrievedContext, global::Google.Gemini.Image? image, + global::Google.Gemini.RetrievedContext? retrievedContext, + global::Google.Gemini.Web? web, global::Google.Gemini.Maps? maps) { - this.Web = web; - this.RetrievedContext = retrievedContext; this.Image = image; + this.RetrievedContext = retrievedContext; + this.Web = web; this.Maps = maps; } 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 cc267c58..8ad989c9 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 @@ -8,30 +8,30 @@ namespace Google.Gemini /// public sealed partial class GroundingChunkCustomMetadata { - /// - /// Optional. The string value of the metadata. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("stringValue")] - public string? StringValue { get; set; } - - /// - /// A list of string values. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("stringListValue")] - public global::Google.Gemini.GroundingChunkStringList? StringListValue { get; set; } - /// /// Optional. The numeric value of the metadata. The expected range for this value depends on the specific `key` used. /// [global::System.Text.Json.Serialization.JsonPropertyName("numericValue")] public float? NumericValue { get; set; } + /// + /// Optional. The string value of the metadata. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("stringValue")] + public string? StringValue { get; set; } + /// /// The key of the metadata. /// [global::System.Text.Json.Serialization.JsonPropertyName("key")] public string? Key { get; set; } + /// + /// A list of string values. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("stringListValue")] + public global::Google.Gemini.GroundingChunkStringList? StringListValue { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -41,31 +41,31 @@ public sealed partial class GroundingChunkCustomMetadata /// /// Initializes a new instance of the class. /// - /// - /// Optional. The string value of the metadata. - /// - /// - /// A list of string values. - /// /// /// Optional. The numeric value of the metadata. The expected range for this value depends on the specific `key` used. /// + /// + /// Optional. The string value of the metadata. + /// /// /// The key of the metadata. /// + /// + /// A list of string values. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingChunkCustomMetadata( - string? stringValue, - global::Google.Gemini.GroundingChunkStringList? stringListValue, float? numericValue, - string? key) + string? stringValue, + string? key, + global::Google.Gemini.GroundingChunkStringList? stringListValue) { - this.StringValue = stringValue; - this.StringListValue = stringListValue; this.NumericValue = numericValue; + this.StringValue = stringValue; this.Key = key; + this.StringListValue = stringListValue; } /// 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 7478b629..64664899 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,6 +8,12 @@ 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; } + /// /// 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. /// @@ -21,16 +27,10 @@ public sealed partial class GroundingMetadata public global::Google.Gemini.SearchEntryPoint? SearchEntryPoint { get; set; } /// - /// 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; } - - /// - /// Metadata related to retrieval in the grounding flow. + /// Image search queries used for grounding. /// - [global::System.Text.Json.Serialization.JsonPropertyName("retrievalMetadata")] - public global::Google.Gemini.RetrievalMetadata? RetrievalMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("imageSearchQueries")] + public global::System.Collections.Generic.IList? ImageSearchQueries { get; set; } /// /// List of grounding support. @@ -38,18 +38,18 @@ public sealed partial class GroundingMetadata [global::System.Text.Json.Serialization.JsonPropertyName("groundingSupports")] public global::System.Collections.Generic.IList? GroundingSupports { 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. /// [global::System.Text.Json.Serialization.JsonPropertyName("groundingChunks")] public global::System.Collections.Generic.IList? GroundingChunks { get; set; } + /// + /// Metadata related to retrieval in the grounding flow. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("retrievalMetadata")] + public global::Google.Gemini.RetrievalMetadata? RetrievalMetadata { 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. + /// /// /// 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. /// /// /// Google search entry point. /// - /// - /// Web search queries for the following-up web search. - /// - /// - /// Metadata related to retrieval in the grounding flow. + /// + /// Image search queries used for grounding. /// /// /// List of grounding support. /// - /// - /// 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. /// + /// + /// 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, string? googleMapsWidgetContextToken, global::Google.Gemini.SearchEntryPoint? searchEntryPoint, - global::System.Collections.Generic.IList? webSearchQueries, - global::Google.Gemini.RetrievalMetadata? retrievalMetadata, - global::System.Collections.Generic.IList? groundingSupports, global::System.Collections.Generic.IList? imageSearchQueries, - global::System.Collections.Generic.IList? groundingChunks) + global::System.Collections.Generic.IList? groundingSupports, + global::System.Collections.Generic.IList? groundingChunks, + global::Google.Gemini.RetrievalMetadata? retrievalMetadata) { + this.WebSearchQueries = webSearchQueries; this.GoogleMapsWidgetContextToken = googleMapsWidgetContextToken; this.SearchEntryPoint = searchEntryPoint; - this.WebSearchQueries = webSearchQueries; - this.RetrievalMetadata = retrievalMetadata; - this.GroundingSupports = groundingSupports; this.ImageSearchQueries = imageSearchQueries; + this.GroundingSupports = groundingSupports; this.GroundingChunks = groundingChunks; + 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 29ecf6d1..6d7ea670 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. 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; } /// - /// 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; } /// /// 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. 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 /// + /// + /// Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`.
+ /// Included only in responses + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingPassageId( - string? passageId, - int? partIndex) + int? partIndex, + string? passageId) { - this.PassageId = passageId; this.PartIndex = partIndex; + this.PassageId = passageId; } /// 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 09b5305e..79a931ef 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,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class Hyperparameters { - /// - /// 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. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("learningRateMultiplier")] - public float? LearningRateMultiplier { 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. /// @@ -21,10 +15,10 @@ public sealed partial class Hyperparameters 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. + /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("learningRate")] - public float? LearningRate { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("learningRateMultiplier")] + public float? LearningRateMultiplier { get; set; } /// /// 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. @@ -32,6 +26,12 @@ public sealed partial class Hyperparameters [global::System.Text.Json.Serialization.JsonPropertyName("epochCount")] public int? EpochCount { 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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("learningRate")] + public float? LearningRate { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -41,31 +41,31 @@ public sealed partial class Hyperparameters /// /// Initializes a new instance of the class. /// - /// - /// 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. - /// /// /// 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. + /// + /// 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. /// /// /// 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. /// + /// + /// 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. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Hyperparameters( - float? learningRateMultiplier, int? batchSize, - float? learningRate, - int? epochCount) + float? learningRateMultiplier, + int? epochCount, + float? learningRate) { - this.LearningRateMultiplier = learningRateMultiplier; this.BatchSize = batchSize; - this.LearningRate = learningRate; + this.LearningRateMultiplier = learningRateMultiplier; this.EpochCount = epochCount; + this.LearningRate = learningRate; } /// 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 d4d85b78..8146d2a0 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 @@ -9,16 +9,10 @@ namespace Google.Gemini public sealed partial class Image { /// - /// The web page URI for attribution. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("sourceUri")] - public string? SourceUri { get; set; } - - /// - /// The image asset URL. + /// The root domain of the web page that the image is from, e.g. "example.com". /// - [global::System.Text.Json.Serialization.JsonPropertyName("imageUri")] - public string? ImageUri { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("domain")] + public string? Domain { get; set; } /// /// The title of the web page that the image is from. @@ -27,10 +21,16 @@ public sealed partial class Image public string? Title { get; set; } /// - /// The root domain of the web page that the image is from, e.g. "example.com". + /// The web page URI for attribution. /// - [global::System.Text.Json.Serialization.JsonPropertyName("domain")] - public string? Domain { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sourceUri")] + public string? SourceUri { get; set; } + + /// + /// The image asset URL. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("imageUri")] + public string? ImageUri { 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 root domain of the web page that the image is from, e.g. "example.com". + /// + /// + /// The title of the web page that the image is from. + /// /// /// The web page URI for attribution. /// /// /// The image asset URL. /// - /// - /// The title of the web page that the image is from. - /// - /// - /// The root domain of the web page that the image is from, e.g. "example.com". - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Image( - string? sourceUri, - string? imageUri, + string? domain, string? title, - string? domain) + string? sourceUri, + string? imageUri) { + this.Domain = domain; + this.Title = title; this.SourceUri = sourceUri; this.ImageUri = imageUri; - this.Title = title; - this.Domain = domain; } /// 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 5ed82a68..84e2562f 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. 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; } + /// + /// 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; } + /// /// 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. 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. /// + /// + /// Optional. Specifies the size of generated images. Supported values are `512`, `1K`, `2K`, `4K`. If not specified, the model will use default value `1K`. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ImageConfig( - string? imageSize, - string? aspectRatio) + string? aspectRatio, + string? imageSize) { - this.ImageSize = imageSize; this.AspectRatio = aspectRatio; + this.ImageSize = imageSize; } /// 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 2f4a44ca..16ecdeeb 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 @@ -14,18 +14,18 @@ public sealed partial class ImportFileRequest [global::System.Text.Json.Serialization.JsonPropertyName("chunkingConfig")] public global::Google.Gemini.ChunkingConfig? ChunkingConfig { get; set; } - /// - /// Required. The name of the `File` to import. Example: `files/abc-123` - /// - [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; } + /// + /// Required. The name of the `File` to import. Example: `files/abc-123` + /// + [global::System.Text.Json.Serialization.JsonPropertyName("fileName")] + public string? FileName { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -38,23 +38,23 @@ public sealed partial class ImportFileRequest /// /// 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. /// + /// + /// Required. The name of the `File` to import. Example: `files/abc-123` + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ImportFileRequest( global::Google.Gemini.ChunkingConfig? chunkingConfig, - string? fileName, - global::System.Collections.Generic.IList? customMetadata) + global::System.Collections.Generic.IList? customMetadata, + string? fileName) { this.ChunkingConfig = chunkingConfig; - this.FileName = fileName; this.CustomMetadata = customMetadata; + this.FileName = fileName; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentRequest.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentRequest.g.cs index c70f6aa2..a3b4bba3 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentRequest.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentRequest.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class InlinedEmbedContentRequest { - /// - /// Request containing the `Content` for the model to embed. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("request")] - public global::Google.Gemini.EmbedContentRequest? Request { get; set; } - /// /// Optional. The metadata to be associated with the request. /// [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] public object? Metadata { get; set; } + /// + /// Request containing the `Content` for the model to embed. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("request")] + public global::Google.Gemini.EmbedContentRequest? Request { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class InlinedEmbedContentRequest /// /// Initializes a new instance of the class. /// - /// - /// Request containing the `Content` for the model to embed. - /// /// /// Optional. The metadata to be associated with the request. /// + /// + /// Request containing the `Content` for the model to embed. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public InlinedEmbedContentRequest( - global::Google.Gemini.EmbedContentRequest? request, - object? metadata) + object? metadata, + global::Google.Gemini.EmbedContentRequest? request) { - this.Request = request; this.Metadata = metadata; + this.Request = request; } /// 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 d705a978..5849d8d1 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,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class InlinedEmbedContentResponse { - /// - /// 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 response to an `EmbedContentRequest`. /// [global::System.Text.Json.Serialization.JsonPropertyName("response")] public global::Google.Gemini.EmbedContentResponse? Response { 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; } + /// /// Output only. The metadata associated with the request.
/// Included only in responses @@ -36,12 +36,12 @@ public sealed partial class InlinedEmbedContentResponse /// /// 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). - /// /// /// The response to an `EmbedContentRequest`. /// + /// + /// 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. The metadata associated with the request.
/// Included only in responses @@ -50,12 +50,12 @@ public sealed partial class InlinedEmbedContentResponse [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public InlinedEmbedContentResponse( - global::Google.Gemini.Status? error, global::Google.Gemini.EmbedContentResponse? response, + global::Google.Gemini.Status? error, object? metadata) { - this.Error = error; this.Response = response; + this.Error = error; this.Metadata = metadata; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedRequest.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedRequest.g.cs index 3815f3fd..9a6afbda 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedRequest.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedRequest.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini ///
public sealed partial class InlinedRequest { - /// - /// Request to generate a completion from the model. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("request")] - public global::Google.Gemini.GenerateContentRequest? Request { get; set; } - /// /// Optional. The metadata to be associated with the request. /// [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] public object? Metadata { get; set; } + /// + /// Request to generate a completion from the model. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("request")] + public global::Google.Gemini.GenerateContentRequest? Request { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class InlinedRequest /// /// Initializes a new instance of the class. /// - /// - /// Request to generate a completion from the model. - /// /// /// Optional. The metadata to be associated with the request. /// + /// + /// Request to generate a completion from the model. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public InlinedRequest( - global::Google.Gemini.GenerateContentRequest? request, - object? metadata) + object? metadata, + global::Google.Gemini.GenerateContentRequest? request) { - this.Request = request; this.Metadata = metadata; + this.Request = request; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedResponse.g.cs index 4edfdb2b..22ff99f8 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedResponse.g.cs @@ -14,12 +14,6 @@ public sealed partial class InlinedResponse [global::System.Text.Json.Serialization.JsonPropertyName("error")] public global::Google.Gemini.Status? Error { get; set; } - /// - /// 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`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("response")] - public global::Google.Gemini.GenerateContentResponse? Response { get; set; } - /// /// Output only. The metadata associated with the request.
/// Included only in responses @@ -27,6 +21,12 @@ public sealed partial class InlinedResponse [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] public object? Metadata { get; set; } + /// + /// 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`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("response")] + public global::Google.Gemini.GenerateContentResponse? Response { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -39,24 +39,24 @@ public sealed partial class InlinedResponse /// /// 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). /// - /// - /// 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`. - /// /// /// Output only. The metadata associated with the request.
/// Included only in responses /// + /// + /// 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`. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public InlinedResponse( global::Google.Gemini.Status? error, - global::Google.Gemini.GenerateContentResponse? response, - object? metadata) + object? metadata, + global::Google.Gemini.GenerateContentResponse? response) { this.Error = error; - this.Response = response; this.Metadata = metadata; + this.Response = response; } /// 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 01a06fc3..c37f2158 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 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; } + /// + /// The name of the `File` containing the input requests. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("fileName")] + public string? FileName { 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 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. /// + /// + /// The name of the `File` containing the input requests. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public InputConfig( - string? fileName, - global::Google.Gemini.InlinedRequests? requests) + global::Google.Gemini.InlinedRequests? requests, + string? fileName) { - this.FileName = fileName; this.Requests = requests; + this.FileName = fileName; } /// 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 d91125c9..acc98cfe 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 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; } + /// + /// The name of the `File` containing the input requests. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("fileName")] + public string? FileName { 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 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. /// + /// + /// The name of the `File` containing the input requests. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public InputEmbedContentConfig( - string? fileName, - global::Google.Gemini.InlinedEmbedContentRequests? requests) + global::Google.Gemini.InlinedEmbedContentRequests? requests, + string? fileName) { - this.FileName = fileName; this.Requests = requests; + this.FileName = fileName; } /// 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 d8960e0a..6b112b84 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 { - /// - /// 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; } + /// + /// List of cached contents. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("cachedContents")] + public global::System.Collections.Generic.IList? CachedContents { 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. /// - /// - /// 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. /// + /// + /// List of cached contents. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListCachedContentsResponse( - global::System.Collections.Generic.IList? cachedContents, - string? nextPageToken) + string? nextPageToken, + global::System.Collections.Generic.IList? cachedContents) { - this.CachedContents = cachedContents; this.NextPageToken = nextPageToken; + this.CachedContents = cachedContents; } /// 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 f5cb7585..53b78dd6 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 841ed885..b64b02eb 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 { - /// - /// 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; } + /// + /// The returned rag_stores. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("fileSearchStores")] + public global::System.Collections.Generic.IList? FileSearchStores { 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. /// - /// - /// 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. /// + /// + /// The returned rag_stores. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListFileSearchStoresResponse( - global::System.Collections.Generic.IList? fileSearchStores, - string? nextPageToken) + string? nextPageToken, + global::System.Collections.Generic.IList? fileSearchStores) { - this.FileSearchStores = fileSearchStores; this.NextPageToken = nextPageToken; + this.FileSearchStores = fileSearchStores; } /// 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 7b51e54b..00f5c2a1 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 040a93da..1c374808 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.ListPermissionsResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListPermissionsResponse.g.cs index a07e2cf3..d4ed378b 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListPermissionsResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListPermissionsResponse.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ListPermissionsResponse { - /// - /// 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; } - /// /// Returned permissions. /// [global::System.Text.Json.Serialization.JsonPropertyName("permissions")] public global::System.Collections.Generic.IList? Permissions { 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 ListPermissionsResponse /// /// 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. - /// /// /// Returned permissions. /// + /// + /// 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 ListPermissionsResponse( - string? nextPageToken, - global::System.Collections.Generic.IList? permissions) + global::System.Collections.Generic.IList? permissions, + string? nextPageToken) { - this.NextPageToken = nextPageToken; this.Permissions = permissions; + this.NextPageToken = nextPageToken; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResult.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResult.g.cs index 296ff44e..7778671c 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResult.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResult.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class LogprobsResult { - /// - /// Length = total number of decoding steps. The chosen candidates may or may not be in top_candidates. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("chosenCandidates")] - public global::System.Collections.Generic.IList? ChosenCandidates { get; set; } - /// /// Sum of log probabilities for all tokens. /// @@ -26,6 +20,12 @@ public sealed partial class LogprobsResult [global::System.Text.Json.Serialization.JsonPropertyName("topCandidates")] public global::System.Collections.Generic.IList? TopCandidates { get; set; } + /// + /// Length = total number of decoding steps. The chosen candidates may or may not be in top_candidates. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("chosenCandidates")] + public global::System.Collections.Generic.IList? ChosenCandidates { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class LogprobsResult /// /// Initializes a new instance of the class. /// - /// - /// Length = total number of decoding steps. The chosen candidates may or may not be in top_candidates. - /// /// /// Sum of log probabilities for all tokens. /// /// /// Length = total number of decoding steps. /// + /// + /// Length = total number of decoding steps. The chosen candidates may or may not be in top_candidates. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public LogprobsResult( - global::System.Collections.Generic.IList? chosenCandidates, float? logProbabilitySum, - global::System.Collections.Generic.IList? topCandidates) + global::System.Collections.Generic.IList? topCandidates, + global::System.Collections.Generic.IList? chosenCandidates) { - this.ChosenCandidates = chosenCandidates; this.LogProbabilitySum = logProbabilitySum; this.TopCandidates = topCandidates; + this.ChosenCandidates = chosenCandidates; } /// 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 f1918eaa..1c4558c4 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 @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class LogprobsResultCandidate { - /// - /// The candidate’s token id value. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("tokenId")] - public int? TokenId { get; set; } - /// /// The candidate’s token string value. /// [global::System.Text.Json.Serialization.JsonPropertyName("token")] public string? Token { get; set; } + /// + /// The candidate’s token id value. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("tokenId")] + public int? TokenId { get; set; } + /// /// The candidate's log probability. /// @@ -35,12 +35,12 @@ public sealed partial class LogprobsResultCandidate /// /// Initializes a new instance of the class. /// - /// - /// The candidate’s token id value. - /// /// /// The candidate’s token string value. /// + /// + /// The candidate’s token id value. + /// /// /// The candidate's log probability. /// @@ -48,12 +48,12 @@ public sealed partial class LogprobsResultCandidate [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public LogprobsResultCandidate( - int? tokenId, string? token, + int? tokenId, float? logProbability) { - this.TokenId = tokenId; this.Token = token; + this.TokenId = tokenId; this.LogProbability = logProbability; } 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 881019c2..1b4be69b 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,34 +9,34 @@ 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. + /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("placeId")] - public string? PlaceId { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("placeAnswerSources")] + public global::Google.Gemini.PlaceAnswerSources? PlaceAnswerSources { get; set; } /// - /// URI reference of the place. + /// Title of the place. /// - [global::System.Text.Json.Serialization.JsonPropertyName("uri")] - public string? Uri { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("title")] + public string? Title { get; set; } /// - /// Text description of the place answer. + /// URI reference of the place. /// - [global::System.Text.Json.Serialization.JsonPropertyName("text")] - public string? Text { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("uri")] + public string? Uri { get; set; } /// - /// Title 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("title")] - public string? Title { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("placeId")] + public string? PlaceId { 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. + /// Text description of the place answer. /// - [global::System.Text.Json.Serialization.JsonPropertyName("placeAnswerSources")] - public global::Google.Gemini.PlaceAnswerSources? PlaceAnswerSources { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("text")] + public string? Text { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -47,36 +47,36 @@ public sealed partial class Maps /// /// Initializes a new instance of the class. /// - /// - /// The ID of the place, in `places/{place_id}` format. A user can use this ID to look up that 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. + /// + /// + /// Title of the place. /// /// /// 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. + /// /// /// Text description of the place answer. /// - /// - /// Title 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. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Maps( - string? placeId, - string? uri, - string? text, + global::Google.Gemini.PlaceAnswerSources? placeAnswerSources, string? title, - global::Google.Gemini.PlaceAnswerSources? placeAnswerSources) + string? uri, + string? placeId, + string? text) { - this.PlaceId = placeId; + this.PlaceAnswerSources = placeAnswerSources; + this.Title = title; this.Uri = uri; + this.PlaceId = placeId; this.Text = text; - this.Title = title; - this.PlaceAnswerSources = placeAnswerSources; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.McpServer.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.McpServer.g.cs index d1c47b48..ab8cc328 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.McpServer.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.McpServer.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class McpServer { - /// - /// A transport that can stream HTTP requests and responses. Next ID: 6 - /// - [global::System.Text.Json.Serialization.JsonPropertyName("streamableHttpTransport")] - public global::Google.Gemini.StreamableHttpTransport? StreamableHttpTransport { get; set; } - /// /// The name of the MCPServer. /// [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } + /// + /// A transport that can stream HTTP requests and responses. Next ID: 6 + /// + [global::System.Text.Json.Serialization.JsonPropertyName("streamableHttpTransport")] + public global::Google.Gemini.StreamableHttpTransport? StreamableHttpTransport { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class McpServer /// /// Initializes a new instance of the class. /// - /// - /// A transport that can stream HTTP requests and responses. Next ID: 6 - /// /// /// The name of the MCPServer. /// + /// + /// A transport that can stream HTTP requests and responses. Next ID: 6 + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public McpServer( - global::Google.Gemini.StreamableHttpTransport? streamableHttpTransport, - string? name) + string? name, + global::Google.Gemini.StreamableHttpTransport? streamableHttpTransport) { - this.StreamableHttpTransport = streamableHttpTransport; this.Name = name; + this.StreamableHttpTransport = streamableHttpTransport; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ModalityTokenCount.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ModalityTokenCount.g.cs index b9c043c1..f9e614fa 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ModalityTokenCount.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ModalityTokenCount.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class ModalityTokenCount { + /// + /// Number of tokens. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("tokenCount")] + public int? TokenCount { get; set; } + /// /// The modality associated with this token count. /// @@ -15,12 +21,6 @@ public sealed partial class ModalityTokenCount [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityJsonConverter))] public global::Google.Gemini.ModalityTokenCountModality? Modality { get; set; } - /// - /// Number of tokens. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("tokenCount")] - public int? TokenCount { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,21 +30,21 @@ public sealed partial class ModalityTokenCount /// /// Initializes a new instance of the class. /// - /// - /// The modality associated with this token count. - /// /// /// Number of tokens. /// + /// + /// The modality associated with this token count. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ModalityTokenCount( - global::Google.Gemini.ModalityTokenCountModality? modality, - int? tokenCount) + int? tokenCount, + global::Google.Gemini.ModalityTokenCountModality? modality) { - this.Modality = modality; this.TokenCount = tokenCount; + this.Modality = modality; } /// 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 e49083ae..31924079 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 @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class 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("name")] + public string? Name { get; set; } + /// /// Maximum number of input tokens allowed for this model. /// @@ -15,22 +21,22 @@ public sealed partial class Model public int? InputTokenLimit { get; set; } /// - /// Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` + /// Maximum number of output tokens available for this model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("baseModelId")] - public string? BaseModelId { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("outputTokenLimit")] + public int? OutputTokenLimit { 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. + /// A short description of the model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("topP")] - public float? TopP { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("description")] + public string? Description { get; set; } /// - /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) + /// The maximum temperature this model can use. /// - [global::System.Text.Json.Serialization.JsonPropertyName("version")] - public string? Version { 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`. @@ -39,22 +45,22 @@ public sealed partial class Model public global::System.Collections.Generic.IList? SupportedGenerationMethods { 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. + /// Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` /// - [global::System.Text.Json.Serialization.JsonPropertyName("topK")] - public int? TopK { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("baseModelId")] + public string? BaseModelId { get; set; } /// - /// A short description of the model. + /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) /// - [global::System.Text.Json.Serialization.JsonPropertyName("description")] - public string? Description { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("version")] + public string? Version { get; set; } /// - /// The maximum temperature this model can use. + /// 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("maxTemperature")] - public float? MaxTemperature { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topK")] + public int? TopK { 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. @@ -62,30 +68,24 @@ public sealed partial class Model [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] public string? DisplayName { get; set; } - /// - /// Maximum number of output tokens available for this model. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("outputTokenLimit")] - public int? OutputTokenLimit { 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. /// [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] public float? Temperature { 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` - /// - [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } - /// /// Whether the model supports thinking. /// [global::System.Text.Json.Serialization.JsonPropertyName("thinking")] public bool? Thinking { 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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("topP")] + public float? TopP { 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. /// + /// + /// 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` + /// /// /// 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` + /// + /// Maximum number of output tokens available for this model. /// - /// - /// 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. /// - /// - /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) + /// + /// The maximum temperature this model can use. /// /// /// The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`. /// - /// - /// 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. + /// + /// Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` /// - /// - /// A short description of the model. + /// + /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) /// - /// - /// The maximum temperature this model can use. + /// + /// 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. /// /// /// 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. /// - /// - /// 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` - /// /// /// Whether the model supports thinking. /// + /// + /// 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. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Model( + string? name, int? inputTokenLimit, + int? outputTokenLimit, + string? description, + float? maxTemperature, + global::System.Collections.Generic.IList? supportedGenerationMethods, string? baseModelId, - float? topP, string? version, - global::System.Collections.Generic.IList? supportedGenerationMethods, int? topK, - string? description, - float? maxTemperature, string? displayName, - int? outputTokenLimit, float? temperature, - string? name, - bool? thinking) + bool? thinking, + float? topP) { + this.Name = name; this.InputTokenLimit = inputTokenLimit; + this.OutputTokenLimit = outputTokenLimit; + this.Description = description; + this.MaxTemperature = maxTemperature; + this.SupportedGenerationMethods = supportedGenerationMethods; this.BaseModelId = baseModelId; - this.TopP = topP; this.Version = version; - this.SupportedGenerationMethods = supportedGenerationMethods; this.TopK = topK; - this.Description = description; - this.MaxTemperature = maxTemperature; this.DisplayName = displayName; - this.OutputTokenLimit = outputTokenLimit; this.Temperature = temperature; - this.Name = name; this.Thinking = thinking; + this.TopP = topP; } /// 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 aef7ed2d..ef7ddd48 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 @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class Operation { /// - /// 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. + /// 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("metadata")] - public object? Metadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("done")] + public bool? Done { 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). @@ -21,22 +21,22 @@ public sealed partial class Operation public global::Google.Gemini.Status? Error { 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}`. + /// 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`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("response")] + public object? Response { 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. + /// 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 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}`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("response")] - public object? Response { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -47,36 +47,36 @@ public sealed partial class Operation /// /// Initializes a new instance of the class. /// - /// - /// 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. + /// + /// 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 `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 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}`. - /// - /// - /// 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 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 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}`. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Operation( - object? metadata, - global::Google.Gemini.Status? error, - string? name, bool? done, - object? response) + global::Google.Gemini.Status? error, + object? response, + object? metadata, + string? name) { - this.Metadata = metadata; - this.Error = error; - this.Name = name; this.Done = done; + this.Error = error; this.Response = response; + this.Metadata = metadata; + this.Name = name; } /// 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 5ecff78c..8aa8dc0f 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 @@ -11,10 +11,16 @@ namespace Google.Gemini public sealed partial class Part { /// - /// 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`. + /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("toolResponse")] - public global::Google.Gemini.ToolResponse? ToolResponse { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("executableCode")] + 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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("partMetadata")] + public object? PartMetadata { get; set; } /// /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. @@ -23,35 +29,34 @@ public sealed partial class Part public global::Google.Gemini.CodeExecutionResult? CodeExecutionResult { 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`. + /// Raw media bytes. Text should not be sent as raw bytes, use the 'text' field. /// - [global::System.Text.Json.Serialization.JsonPropertyName("toolCall")] - public global::Google.Gemini.ToolCall? ToolCall { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("inlineData")] + public global::Google.Gemini.Blob? InlineData { get; set; } /// - /// Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content. + /// Inline text. /// - [global::System.Text.Json.Serialization.JsonPropertyName("videoMetadata")] - [global::System.Obsolete("This property marked as deprecated.")] - public global::Google.Gemini.VideoMetadata? VideoMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("text")] + public string? Text { get; set; } /// - /// Raw media bytes. Text should not be sent as raw bytes, use the 'text' field. + /// Optional. An opaque signature for the thought so it can be reused in subsequent requests. /// - [global::System.Text.Json.Serialization.JsonPropertyName("inlineData")] - public global::Google.Gemini.Blob? InlineData { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("thoughtSignature")] + public byte[]? ThoughtSignature { 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. + /// 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("executableCode")] - public global::Google.Gemini.ExecutableCode? ExecutableCode { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("functionCall")] + public global::Google.Gemini.FunctionCall? FunctionCall { get; set; } /// - /// Inline text. + /// 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("text")] - public string? Text { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("functionResponse")] + public global::Google.Gemini.FunctionResponse? FunctionResponse { get; set; } /// /// URI based data. @@ -60,34 +65,29 @@ public sealed partial class Part public global::Google.Gemini.FileData? FileData { 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. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("partMetadata")] - public object? PartMetadata { get; set; } - - /// - /// 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`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("thought")] - public bool? Thought { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("toolCall")] + public global::Google.Gemini.ToolCall? ToolCall { 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; } /// - /// 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. + /// Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content. /// - [global::System.Text.Json.Serialization.JsonPropertyName("functionResponse")] - public global::Google.Gemini.FunctionResponse? FunctionResponse { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("videoMetadata")] + [global::System.Obsolete("This property marked as deprecated.")] + public global::Google.Gemini.VideoMetadata? VideoMetadata { get; set; } /// - /// Optional. An opaque signature for the thought so it can be reused in subsequent requests. + /// Optional. Indicates if the part is thought from the model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("thoughtSignature")] - public byte[]? ThoughtSignature { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("thought")] + public bool? Thought { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -98,32 +98,23 @@ public sealed partial class Part /// /// Initializes a new instance of the class. /// - /// - /// 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`. + /// + /// 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. /// /// /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. /// - /// - /// 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`. - /// /// /// Raw media bytes. Text should not be sent as raw bytes, use the 'text' field. /// - /// - /// 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. - /// /// /// Inline text. /// - /// - /// 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. - /// - /// - /// 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. /// /// /// A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values. @@ -131,38 +122,47 @@ public sealed partial class Part /// /// 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. + /// + /// URI based data. + /// + /// + /// 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`. + /// + /// + /// 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. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Part( - global::Google.Gemini.ToolResponse? toolResponse, + global::Google.Gemini.ExecutableCode? executableCode, + object? partMetadata, global::Google.Gemini.CodeExecutionResult? codeExecutionResult, - global::Google.Gemini.ToolCall? toolCall, global::Google.Gemini.Blob? inlineData, - global::Google.Gemini.ExecutableCode? executableCode, string? text, - global::Google.Gemini.FileData? fileData, - object? partMetadata, - bool? thought, + byte[]? thoughtSignature, global::Google.Gemini.FunctionCall? functionCall, global::Google.Gemini.FunctionResponse? functionResponse, - byte[]? thoughtSignature) + global::Google.Gemini.FileData? fileData, + global::Google.Gemini.ToolCall? toolCall, + global::Google.Gemini.ToolResponse? toolResponse, + bool? thought) { - this.ToolResponse = toolResponse; + this.ExecutableCode = executableCode; + this.PartMetadata = partMetadata; this.CodeExecutionResult = codeExecutionResult; - this.ToolCall = toolCall; this.InlineData = inlineData; - this.ExecutableCode = executableCode; this.Text = text; - this.FileData = fileData; - this.PartMetadata = partMetadata; - this.Thought = thought; + this.ThoughtSignature = thoughtSignature; this.FunctionCall = functionCall; this.FunctionResponse = functionResponse; - this.ThoughtSignature = thoughtSignature; + this.FileData = fileData; + this.ToolCall = toolCall; + this.ToolResponse = toolResponse; + this.Thought = thought; } /// 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 6ba64193..f59e362d 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 @@ -14,13 +14,6 @@ public sealed partial class Permission [global::System.Text.Json.Serialization.JsonPropertyName("emailAddress")] public string? EmailAddress { get; set; } - /// - /// Required. The role granted by this permission. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("role")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.PermissionRoleJsonConverter))] - public global::Google.Gemini.PermissionRole? Role { 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 @@ -28,6 +21,13 @@ public sealed partial class Permission [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } + /// + /// Required. The role granted by this permission. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("role")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.PermissionRoleJsonConverter))] + public global::Google.Gemini.PermissionRole? Role { get; set; } + /// /// Optional. Immutable. The type of the grantee. /// @@ -47,13 +47,13 @@ public sealed partial class Permission /// /// 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. - /// /// /// 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 /// + /// + /// Required. The role granted by this permission. + /// /// /// Optional. Immutable. The type of the grantee. /// @@ -62,13 +62,13 @@ public sealed partial class Permission #endif public Permission( string? emailAddress, - global::Google.Gemini.PermissionRole? role, string? name, + global::Google.Gemini.PermissionRole? role, global::Google.Gemini.PermissionGranteeType? granteeType) { this.EmailAddress = emailAddress; - this.Role = role; this.Name = name; + this.Role = role; this.GranteeType = granteeType; } 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 f7e526d8..458cc7a7 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 21f57ce0..ebce8f5a 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 @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class RetrievedContext { /// - /// Optional. User-provided metadata about the retrieved context. + /// Optional. Title of the document. /// - [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] - public global::System.Collections.Generic.IList? CustomMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("title")] + public string? Title { get; set; } /// /// Optional. Page number of the retrieved context, if applicable. @@ -20,12 +20,6 @@ public sealed partial class RetrievedContext [global::System.Text.Json.Serialization.JsonPropertyName("pageNumber")] public int? PageNumber { get; set; } - /// - /// Optional. The media blob resource name for multimodal file search results. Format: fileSearchStores/{file_search_store_id}/media/{blob_id} - /// - [global::System.Text.Json.Serialization.JsonPropertyName("mediaId")] - public string? MediaId { get; set; } - /// /// Optional. URI reference of the semantic retrieval document. /// @@ -45,10 +39,16 @@ public sealed partial class RetrievedContext public string? Text { get; set; } /// - /// Optional. Title of the document. + /// Optional. The media blob resource name for multimodal file search results. Format: fileSearchStores/{file_search_store_id}/media/{blob_id} /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - public string? Title { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("mediaId")] + public string? MediaId { get; set; } + + /// + /// Optional. User-provided metadata about the retrieved context. + /// + [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 @@ -59,15 +59,12 @@ public sealed partial class RetrievedContext /// /// Initializes a new instance of the class. /// - /// - /// Optional. User-provided metadata about the retrieved context. + /// + /// Optional. Title of the document. /// /// /// Optional. Page number of the retrieved context, if applicable. /// - /// - /// Optional. The media blob resource name for multimodal file search results. Format: fileSearchStores/{file_search_store_id}/media/{blob_id} - /// /// /// Optional. URI reference of the semantic retrieval document. /// @@ -77,28 +74,31 @@ public sealed partial class RetrievedContext /// /// Optional. Text of the chunk. /// - /// - /// Optional. Title of the document. + /// + /// Optional. The media blob resource name for multimodal file search results. Format: fileSearchStores/{file_search_store_id}/media/{blob_id} + /// + /// + /// Optional. User-provided metadata about the retrieved context. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public RetrievedContext( - global::System.Collections.Generic.IList? customMetadata, + string? title, int? pageNumber, - string? mediaId, string? uri, string? fileSearchStore, string? text, - string? title) + string? mediaId, + global::System.Collections.Generic.IList? customMetadata) { - this.CustomMetadata = customMetadata; + this.Title = title; this.PageNumber = pageNumber; - this.MediaId = mediaId; this.Uri = uri; this.FileSearchStore = fileSearchStore; this.Text = text; - this.Title = title; + this.MediaId = mediaId; + this.CustomMetadata = customMetadata; } /// 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 a5901673..db35d025 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 @@ -14,18 +14,18 @@ public sealed partial class ReviewSnippet [global::System.Text.Json.Serialization.JsonPropertyName("googleMapsUri")] public string? GoogleMapsUri { get; set; } - /// - /// Title of the review. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - public string? Title { get; set; } - /// /// The ID of the review snippet. /// [global::System.Text.Json.Serialization.JsonPropertyName("reviewId")] public string? ReviewId { get; set; } + /// + /// Title of the review. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("title")] + public string? Title { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -38,23 +38,23 @@ public sealed partial class ReviewSnippet /// /// A link that corresponds to the user review on Google Maps. /// - /// - /// Title of the review. - /// /// /// The ID of the review snippet. /// + /// + /// Title of the review. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ReviewSnippet( string? googleMapsUri, - string? title, - string? reviewId) + string? reviewId, + string? title) { this.GoogleMapsUri = googleMapsUri; - this.Title = title; this.ReviewId = reviewId; + this.Title = title; } /// 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 4d10712f..5b9fe839 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 @@ -9,11 +9,11 @@ namespace Google.Gemini public sealed partial class SafetyRating { /// - /// Required. The probability of harm for this content. + /// Required. The category for this rating. /// - [global::System.Text.Json.Serialization.JsonPropertyName("probability")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityJsonConverter))] - public global::Google.Gemini.SafetyRatingProbability? Probability { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("category")] + [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? @@ -22,11 +22,11 @@ public sealed partial class SafetyRating public bool? Blocked { get; set; } /// - /// Required. The category for this rating. + /// Required. The probability of harm for this content. /// - [global::System.Text.Json.Serialization.JsonPropertyName("category")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryJsonConverter))] - public global::Google.Gemini.SafetyRatingCategory? Category { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("probability")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityJsonConverter))] + public global::Google.Gemini.SafetyRatingProbability? Probability { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -37,26 +37,26 @@ public sealed partial class SafetyRating /// /// Initializes a new instance of the class. /// - /// - /// 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. + /// + /// Required. The probability of harm for this content. /// #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, - global::Google.Gemini.SafetyRatingCategory? category) + global::Google.Gemini.SafetyRatingProbability? probability) { - this.Probability = probability; - this.Blocked = blocked; this.Category = category; + this.Blocked = blocked; + this.Probability = probability; } /// 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 de5ad5e2..692f64a2 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,137 +9,137 @@ namespace Google.Gemini public sealed partial class Schema { /// - /// Optional. Indicates if the value may be null. + /// Optional. Maximum value of the Type.INTEGER and Type.NUMBER /// - [global::System.Text.Json.Serialization.JsonPropertyName("nullable")] - public bool? Nullable { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maximum")] + public double? Maximum { get; set; } /// - /// Optional. Maximum number of the properties for Type.OBJECT. + /// Required. Data type. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxProperties")] - public string? MaxProperties { 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. Maximum length of the Type.STRING + /// Optional. Properties of Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxLength")] - public string? MaxLength { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("properties")] + public global::System.Collections.Generic.Dictionary? Properties { get; set; } /// - /// Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown. + /// 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("description")] - public string? Description { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("default")] + public object? Default { get; set; } /// - /// Optional. Pattern of the Type.STRING to restrict a string to a regular expression. + /// Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality. /// - [global::System.Text.Json.Serialization.JsonPropertyName("pattern")] - public string? Pattern { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("format")] + public string? Format { 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. Indicates if the value may be null. /// - [global::System.Text.Json.Serialization.JsonPropertyName("propertyOrdering")] - public global::System.Collections.Generic.IList? PropertyOrdering { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("nullable")] + public bool? Nullable { get; set; } /// - /// Optional. Required properties of Type.OBJECT. + /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING /// - [global::System.Text.Json.Serialization.JsonPropertyName("required")] - public global::System.Collections.Generic.IList? Required { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minLength")] + public string? MinLength { get; set; } /// - /// Required. Data type. + /// Optional. Pattern of the Type.STRING to restrict a string to a regular expression. /// - [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("pattern")] + public string? Pattern { get; set; } /// - /// Optional. Maximum 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("maxItems")] - public string? MaxItems { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("enum")] + public global::System.Collections.Generic.IList? Enum { get; set; } /// - /// Optional. Example of the object. Will only populated when the object is the root. + /// Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER /// - [global::System.Text.Json.Serialization.JsonPropertyName("example")] - public object? Example { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minimum")] + public double? Minimum { get; set; } /// - /// Optional. Minimum number of the properties for 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("minProperties")] - public string? MinProperties { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("propertyOrdering")] + public global::System.Collections.Generic.IList? PropertyOrdering { get; set; } /// - /// Optional. Minimum number of the elements for Type.ARRAY. + /// 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("minItems")] - public string? MinItems { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("items")] + public global::Google.Gemini.Schema? Items { get; set; } /// - /// Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER + /// Optional. Maximum number of the properties for Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("minimum")] - public double? Minimum { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxProperties")] + public string? MaxProperties { get; set; } /// - /// Optional. The value should be validated against any (one or more) of the subschemas in the list. + /// Optional. The title of the schema. /// - [global::System.Text.Json.Serialization.JsonPropertyName("anyOf")] - public global::System.Collections.Generic.IList? AnyOf { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("title")] + public string? Title { get; set; } /// - /// Optional. Maximum value of the Type.INTEGER and Type.NUMBER + /// Optional. Minimum number of the properties for Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maximum")] - public double? Maximum { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minProperties")] + public string? MinProperties { get; set; } /// - /// Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality. + /// Optional. Example of the object. Will only populated when the object is the root. /// - [global::System.Text.Json.Serialization.JsonPropertyName("format")] - public string? Format { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("example")] + public object? Example { 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. Properties of Type.OBJECT. + /// Optional. Maximum number of the elements for Type.ARRAY. /// - [global::System.Text.Json.Serialization.JsonPropertyName("properties")] - public global::System.Collections.Generic.Dictionary? Properties { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxItems")] + public string? MaxItems { 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). + /// Optional. Minimum number of the elements for Type.ARRAY. /// - [global::System.Text.Json.Serialization.JsonPropertyName("items")] - public global::Google.Gemini.Schema? Items { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minItems")] + public string? MinItems { get; set; } /// - /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum 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("minLength")] - public string? MinLength { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("description")] + public string? Description { 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. Maximum length of the Type.STRING /// - [global::System.Text.Json.Serialization.JsonPropertyName("default")] - public object? Default { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxLength")] + public string? MaxLength { 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 value should be validated against any (one or more) of the subschemas in the list. /// - [global::System.Text.Json.Serialization.JsonPropertyName("enum")] - public global::System.Collections.Generic.IList? Enum { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("anyOf")] + public global::System.Collections.Generic.IList? AnyOf { 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. Maximum value of the Type.INTEGER and Type.NUMBER /// - /// - /// Optional. Maximum number of the properties for Type.OBJECT. + /// + /// Required. Data type. /// - /// - /// Optional. Maximum length of the Type.STRING + /// + /// Optional. Properties of Type.OBJECT. /// - /// - /// Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown. + /// + /// 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 format of the data. Any value is allowed, but most do not trigger any special functionality. + /// + /// + /// Optional. Indicates if the value may be null. + /// + /// + /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING /// /// /// Optional. Pattern of the Type.STRING to restrict a string to a regular expression. /// + /// + /// 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. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER + /// /// /// 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. Required properties of Type.OBJECT. + /// + /// 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. Data type. + /// + /// Optional. Maximum number of the properties for Type.OBJECT. /// - /// - /// Optional. Maximum number of the elements for Type.ARRAY. + /// + /// Optional. The title of the schema. + /// + /// + /// Optional. Minimum number of the properties for Type.OBJECT. /// /// /// Optional. Example of the object. Will only populated when the object is the root. /// - /// - /// Optional. Minimum number of the properties for Type.OBJECT. + /// + /// Optional. Required properties of Type.OBJECT. + /// + /// + /// Optional. Maximum number of the elements for Type.ARRAY. /// /// /// 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. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown. + /// + /// + /// 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. Maximum 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. The title of the schema. - /// - /// - /// Optional. Properties of Type.OBJECT. - /// - /// - /// 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. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING - /// - /// - /// 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. 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"]} - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Schema( + double? maximum, + global::Google.Gemini.SchemaType? type, + global::System.Collections.Generic.Dictionary? properties, + object? @default, + string? format, bool? nullable, - string? maxProperties, - string? maxLength, - string? description, + string? minLength, string? pattern, + global::System.Collections.Generic.IList? @enum, + double? minimum, global::System.Collections.Generic.IList? propertyOrdering, + global::Google.Gemini.Schema? items, + string? maxProperties, + string? title, + string? minProperties, + object? example, global::System.Collections.Generic.IList? required, - global::Google.Gemini.SchemaType? type, string? maxItems, - object? example, - string? minProperties, string? minItems, - double? minimum, - global::System.Collections.Generic.IList? anyOf, - double? maximum, - string? format, - string? title, - global::System.Collections.Generic.Dictionary? properties, - global::Google.Gemini.Schema? items, - string? minLength, - object? @default, - global::System.Collections.Generic.IList? @enum) + string? description, + string? maxLength, + global::System.Collections.Generic.IList? anyOf) { + this.Maximum = maximum; + this.Type = type; + this.Properties = properties; + this.Default = @default; + this.Format = format; this.Nullable = nullable; - this.MaxProperties = maxProperties; - this.MaxLength = maxLength; - this.Description = description; + this.MinLength = minLength; this.Pattern = pattern; + this.Enum = @enum; + this.Minimum = minimum; this.PropertyOrdering = propertyOrdering; + this.Items = items; + this.MaxProperties = maxProperties; + this.Title = title; + this.MinProperties = minProperties; + this.Example = example; this.Required = required; - this.Type = type; this.MaxItems = maxItems; - this.Example = example; - this.MinProperties = minProperties; this.MinItems = minItems; - this.Minimum = minimum; + this.Description = description; + this.MaxLength = maxLength; this.AnyOf = anyOf; - this.Maximum = maximum; - this.Format = format; - this.Title = title; - this.Properties = properties; - this.Items = items; - this.MinLength = minLength; - this.Default = @default; - this.Enum = @enum; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SearchTypes.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SearchTypes.g.cs index 1bf661d7..5b7ed61e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SearchTypes.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SearchTypes.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class SearchTypes { - /// - /// Standard web search for grounding and related configurations. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("webSearch")] - public global::Google.Gemini.WebSearch? WebSearch { get; set; } - /// /// Image search for grounding and related configurations. /// [global::System.Text.Json.Serialization.JsonPropertyName("imageSearch")] public global::Google.Gemini.ImageSearch? ImageSearch { get; set; } + /// + /// Standard web search for grounding and related configurations. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("webSearch")] + public global::Google.Gemini.WebSearch? WebSearch { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class SearchTypes /// /// Initializes a new instance of the class. /// - /// - /// Standard web search for grounding and related configurations. - /// /// /// Image search for grounding and related configurations. /// + /// + /// Standard web search for grounding and related configurations. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public SearchTypes( - global::Google.Gemini.WebSearch? webSearch, - global::Google.Gemini.ImageSearch? imageSearch) + global::Google.Gemini.ImageSearch? imageSearch, + global::Google.Gemini.WebSearch? webSearch) { - this.WebSearch = webSearch; this.ImageSearch = imageSearch; + this.WebSearch = webSearch; } /// 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 0aee1c55..08b87489 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,18 +8,18 @@ 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; } - /// /// The status code, which should be an enum value of google.rpc.Code. /// [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; } + /// /// A list of messages that carry the error details. There is a common set of message types for APIs to use. /// @@ -35,12 +35,12 @@ 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. - /// /// /// 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. + /// /// /// A list of messages that carry the error details. There is a common set of message types for APIs to use. /// @@ -48,12 +48,12 @@ public sealed partial class Status [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Status( - string? message, int? code, + string? message, global::System.Collections.Generic.IList? details) { - this.Message = message; this.Code = code; + this.Message = message; this.Details = details; } 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 c0571307..069a5d4c 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 @@ -9,16 +9,16 @@ namespace Google.Gemini public sealed partial class StreamableHttpTransport { /// - /// The full URL for the MCPServer endpoint. Example: "https://api.example.com/mcp" + /// HTTP timeout for regular operations. /// - [global::System.Text.Json.Serialization.JsonPropertyName("url")] - public string? Url { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("timeout")] + public string? Timeout { get; set; } /// - /// Whether to close the client session when the transport closes. + /// Timeout for SSE read operations. /// - [global::System.Text.Json.Serialization.JsonPropertyName("terminateOnClose")] - public bool? TerminateOnClose { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sseReadTimeout")] + public string? SseReadTimeout { get; set; } /// /// Optional: Fields for authentication headers, timeouts, etc., if needed. @@ -27,16 +27,16 @@ public sealed partial class StreamableHttpTransport public global::System.Collections.Generic.Dictionary? Headers { get; set; } /// - /// Timeout for SSE read operations. + /// The full URL for the MCPServer endpoint. Example: "https://api.example.com/mcp" /// - [global::System.Text.Json.Serialization.JsonPropertyName("sseReadTimeout")] - public string? SseReadTimeout { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("url")] + public string? Url { get; set; } /// - /// HTTP timeout for regular operations. + /// Whether to close the client session when the transport closes. /// - [global::System.Text.Json.Serialization.JsonPropertyName("timeout")] - public string? Timeout { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("terminateOnClose")] + public bool? TerminateOnClose { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -47,36 +47,36 @@ public sealed partial class StreamableHttpTransport /// /// Initializes a new instance of the class. /// - /// - /// The full URL for the MCPServer endpoint. Example: "https://api.example.com/mcp" + /// + /// HTTP timeout for regular operations. /// - /// - /// Whether to close the client session when the transport closes. + /// + /// Timeout for SSE read operations. /// /// /// Optional: Fields for authentication headers, timeouts, etc., if needed. /// - /// - /// Timeout for SSE read operations. + /// + /// The full URL for the MCPServer endpoint. Example: "https://api.example.com/mcp" /// - /// - /// HTTP timeout for regular operations. + /// + /// Whether to close the client session when the transport closes. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public StreamableHttpTransport( - string? url, - bool? terminateOnClose, - global::System.Collections.Generic.Dictionary? headers, + string? timeout, string? sseReadTimeout, - string? timeout) + global::System.Collections.Generic.Dictionary? headers, + string? url, + bool? terminateOnClose) { + this.Timeout = timeout; + this.SseReadTimeout = sseReadTimeout; + this.Headers = headers; this.Url = url; this.TerminateOnClose = terminateOnClose; - this.Headers = headers; - this.SseReadTimeout = sseReadTimeout; - this.Timeout = timeout; } /// 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 05793673..0e3c78c0 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,10 @@ namespace Google.Gemini public sealed partial class Tool { /// - /// Tool to retrieve public web data for grounding, powered by Google. - /// - [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; } - - /// - /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. + /// 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("googleSearch")] - public global::Google.Gemini.GoogleSearch? GoogleSearch { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("functionDeclarations")] + public global::System.Collections.Generic.IList? FunctionDeclarations { get; set; } /// /// Computer Use tool type. @@ -33,10 +21,10 @@ public sealed partial class Tool public global::Google.Gemini.ComputerUse? ComputerUse { 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. + /// The GoogleMaps Tool that provides geospatial context for the user's query. /// - [global::System.Text.Json.Serialization.JsonPropertyName("functionDeclarations")] - public global::System.Collections.Generic.IList? FunctionDeclarations { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("googleMaps")] + public global::Google.Gemini.GoogleMaps? GoogleMaps { get; set; } /// /// The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API. @@ -44,6 +32,18 @@ public sealed partial class Tool [global::System.Text.Json.Serialization.JsonPropertyName("fileSearch")] public global::Google.Gemini.FileSearch? FileSearch { get; set; } + /// + /// Tool to support URL context retrieval. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("urlContext")] + public global::Google.Gemini.UrlContext? UrlContext { get; set; } + + /// + /// Tool to retrieve public web data for grounding, powered by Google. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("googleSearchRetrieval")] + public global::Google.Gemini.GoogleSearchRetrieval? GoogleSearchRetrieval { get; set; } + /// /// 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. /// @@ -51,16 +51,16 @@ public sealed partial class Tool public global::Google.Gemini.CodeExecution? CodeExecution { get; set; } /// - /// Optional. MCP Servers to connect to. + /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. /// - [global::System.Text.Json.Serialization.JsonPropertyName("mcpServers")] - public global::System.Collections.Generic.IList? McpServers { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("googleSearch")] + public global::Google.Gemini.GoogleSearch? GoogleSearch { get; set; } /// - /// Tool to support URL context retrieval. + /// Optional. MCP Servers to connect to. /// - [global::System.Text.Json.Serialization.JsonPropertyName("urlContext")] - public global::Google.Gemini.UrlContext? UrlContext { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("mcpServers")] + public global::System.Collections.Generic.IList? McpServers { 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. /// - /// - /// Tool to retrieve public web data for grounding, powered by Google. - /// - /// - /// The GoogleMaps Tool that provides geospatial context for the user's query. - /// - /// - /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. + /// + /// 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. /// /// /// Computer Use tool type. /// - /// - /// 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. + /// + /// The GoogleMaps Tool that provides geospatial context for the user's query. /// /// /// The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API. /// + /// + /// Tool to support URL context retrieval. + /// + /// + /// Tool to retrieve public web data for grounding, powered by Google. + /// /// /// 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. /// + /// + /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. + /// /// /// Optional. MCP Servers to connect to. /// - /// - /// Tool to support URL context retrieval. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Tool( - global::Google.Gemini.GoogleSearchRetrieval? googleSearchRetrieval, - global::Google.Gemini.GoogleMaps? googleMaps, - global::Google.Gemini.GoogleSearch? googleSearch, - global::Google.Gemini.ComputerUse? computerUse, global::System.Collections.Generic.IList? functionDeclarations, + global::Google.Gemini.ComputerUse? computerUse, + global::Google.Gemini.GoogleMaps? googleMaps, global::Google.Gemini.FileSearch? fileSearch, + global::Google.Gemini.UrlContext? urlContext, + global::Google.Gemini.GoogleSearchRetrieval? googleSearchRetrieval, global::Google.Gemini.CodeExecution? codeExecution, - global::System.Collections.Generic.IList? mcpServers, - global::Google.Gemini.UrlContext? urlContext) + global::Google.Gemini.GoogleSearch? googleSearch, + global::System.Collections.Generic.IList? mcpServers) { - this.GoogleSearchRetrieval = googleSearchRetrieval; - this.GoogleMaps = googleMaps; - this.GoogleSearch = googleSearch; - this.ComputerUse = computerUse; this.FunctionDeclarations = functionDeclarations; + this.ComputerUse = computerUse; + this.GoogleMaps = googleMaps; this.FileSearch = fileSearch; + this.UrlContext = urlContext; + this.GoogleSearchRetrieval = googleSearchRetrieval; this.CodeExecution = codeExecution; + this.GoogleSearch = googleSearch; this.McpServers = mcpServers; - this.UrlContext = urlContext; } /// 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 c04b4915..eb31d18b 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,12 @@ namespace Google.Gemini /// public sealed partial class ToolCall { + /// + /// Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("id")] + public string? Id { get; set; } + /// /// Required. The type of tool that was called. /// @@ -21,12 +27,6 @@ public sealed partial class ToolCall [global::System.Text.Json.Serialization.JsonPropertyName("args")] public object? Args { get; set; } - /// - /// Optional. Unique identifier of the tool call. The server returns the tool response 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 ToolCall /// /// Initializes a new instance of the class. /// + /// + /// Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`. + /// /// /// Required. The type of tool that was called. /// /// /// Optional. The tool call arguments. Example: {"arg1" : "value1", "arg2" : "value2" , ...} /// - /// - /// Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ToolCall( + string? id, global::Google.Gemini.ToolCallToolType? toolType, - object? args, - string? id) + object? args) { + this.Id = id; this.ToolType = toolType; this.Args = args; - this.Id = id; } /// 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 b03cfbd7..cd0c2f36 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 @@ -9,11 +9,24 @@ namespace Google.Gemini public sealed partial class TunedModel { /// - /// Output only. The timestamp when this model was created.
+ /// 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("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } + + /// + /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// + [global::System.Text.Json.Serialization.JsonPropertyName("baseModel")] + public string? BaseModel { 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. @@ -22,16 +35,17 @@ public sealed partial class TunedModel public global::Google.Gemini.TunedModelSource? TunedModelSource { 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. + /// Optional. A short description of this model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("topP")] - public float? TopP { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("description")] + public string? Description { get; set; } /// - /// Tuning tasks that create tuned models. + /// Output only. The timestamp when this model was created.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("tuningTask")] - public global::Google.Gemini.TuningTask? TuningTask { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { 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. @@ -47,19 +61,6 @@ public sealed partial class TunedModel [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.TunedModelStateJsonConverter))] public global::Google.Gemini.TunedModelState? State { 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; } - - /// - /// 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("temperature")] - public float? Temperature { get; set; } - /// /// Optional. List of project numbers that have read access to the tuned model. /// @@ -67,29 +68,28 @@ public sealed partial class TunedModel public global::System.Collections.Generic.IList? ReaderProjectNumbers { get; set; } /// - /// Optional. A short description of this model. + /// 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("description")] - public string? Description { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// 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("baseModel")] - public string? BaseModel { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] + public float? Temperature { 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. 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topP")] + public float? TopP { 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 + /// Tuning tasks that create tuned models. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("tuningTask")] + public global::Google.Gemini.TuningTask? TuningTask { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -100,18 +100,26 @@ public sealed partial class TunedModel /// /// Initializes a new instance of the class. /// - /// - /// Output only. The timestamp when this model was created.
+ /// + /// 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 + /// + /// + /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// + /// + /// Output only. The timestamp when this model was updated.
/// Included only in responses /// /// /// Tuned model as a source for training a new 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. + /// + /// Optional. A short description of this model. /// - /// - /// Tuning tasks that create tuned models. + /// + /// Output only. The timestamp when this model was created.
+ /// Included only in responses /// /// /// 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. @@ -120,60 +128,52 @@ public sealed partial class TunedModel /// Output only. The state of the tuned model.
/// Included only in responses /// - /// - /// Output only. The timestamp when this model was updated.
- /// Included only in responses - /// - /// - /// 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. List of project numbers that have read access to the tuned model. /// - /// - /// Optional. A short description of this model. - /// - /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` - /// /// /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// - /// - /// 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. 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. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public TunedModel( - string? createTime, + string? name, + string? baseModel, + string? updateTime, global::Google.Gemini.TunedModelSource? tunedModelSource, - float? topP, - global::Google.Gemini.TuningTask? tuningTask, + string? description, + string? createTime, int? topK, global::Google.Gemini.TunedModelState? state, - string? updateTime, - float? temperature, global::System.Collections.Generic.IList? readerProjectNumbers, - string? description, - string? baseModel, string? displayName, - string? name) + float? temperature, + float? topP, + global::Google.Gemini.TuningTask? tuningTask) { - this.CreateTime = createTime; + this.Name = name; + this.BaseModel = baseModel; + this.UpdateTime = updateTime; this.TunedModelSource = tunedModelSource; - this.TopP = topP; - this.TuningTask = tuningTask; + this.Description = description; + this.CreateTime = createTime; this.TopK = topK; this.State = state; - this.UpdateTime = updateTime; - this.Temperature = temperature; this.ReaderProjectNumbers = readerProjectNumbers; - this.Description = description; - this.BaseModel = baseModel; this.DisplayName = displayName; - this.Name = name; + this.Temperature = temperature; + this.TopP = topP; + this.TuningTask = tuningTask; } /// 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 dccf0ecb..e7212e4d 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,11 +9,10 @@ namespace Google.Gemini public sealed partial class TuningTask { /// - /// 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 ///
- [global::System.Text.Json.Serialization.JsonPropertyName("startTime")] - public string? StartTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("hyperparameters")] + public global::Google.Gemini.Hyperparameters? Hyperparameters { get; set; } /// /// Output only. The timestamp when tuning this model completed.
@@ -36,10 +35,11 @@ public sealed partial class TuningTask public global::Google.Gemini.Dataset? TrainingData { get; set; } /// - /// Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance + /// Output only. The timestamp when tuning this model started.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("hyperparameters")] - public global::Google.Gemini.Hyperparameters? Hyperparameters { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("startTime")] + public string? StartTime { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -50,9 +50,8 @@ public sealed partial class TuningTask /// /// Initializes a new instance of the class. /// - /// - /// 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.
@@ -65,24 +64,25 @@ public sealed partial class TuningTask /// /// Dataset for training or validation. /// - /// - /// Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance + /// + /// Output only. The timestamp when tuning this model started.
+ /// Included only in responses /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public TuningTask( - string? startTime, + global::Google.Gemini.Hyperparameters? hyperparameters, string? completeTime, global::System.Collections.Generic.IList? snapshots, global::Google.Gemini.Dataset? trainingData, - global::Google.Gemini.Hyperparameters? hyperparameters) + string? startTime) { - this.StartTime = startTime; + this.Hyperparameters = hyperparameters; this.CompleteTime = completeTime; this.Snapshots = snapshots; this.TrainingData = trainingData; - this.Hyperparameters = hyperparameters; + this.StartTime = startTime; } /// 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 860307d0..9d29ed3d 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 @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class UploadToFileSearchStoreRequest { - /// - /// Optional. Display name of the created document. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } - /// /// Custom metadata to be associated with the data. /// [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] public global::System.Collections.Generic.IList? CustomMetadata { get; set; } + /// + /// Optional. Display name of the created document. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { 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 /// @@ -41,12 +41,12 @@ public sealed partial class UploadToFileSearchStoreRequest /// /// Initializes a new instance of the class. /// - /// - /// Optional. Display name of the created document. - /// /// /// Custom metadata to be associated with the data. /// + /// + /// 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 /// @@ -57,13 +57,13 @@ public sealed partial class UploadToFileSearchStoreRequest [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public UploadToFileSearchStoreRequest( - string? displayName, global::System.Collections.Generic.IList? customMetadata, + string? displayName, global::Google.Gemini.ChunkingConfig? chunkingConfig, string? mimeType) { - this.DisplayName = displayName; this.CustomMetadata = customMetadata; + this.DisplayName = displayName; this.ChunkingConfig = chunkingConfig; this.MimeType = mimeType; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UrlMetadata.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UrlMetadata.g.cs index d2fe110f..961d09f9 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UrlMetadata.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UrlMetadata.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini ///
public sealed partial class UrlMetadata { - /// - /// Retrieved url by the tool. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("retrievedUrl")] - public string? RetrievedUrl { get; set; } - /// /// Status of the url retrieval. /// @@ -21,6 +15,12 @@ public sealed partial class UrlMetadata [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusJsonConverter))] public global::Google.Gemini.UrlMetadataUrlRetrievalStatus? UrlRetrievalStatus { get; set; } + /// + /// Retrieved url by the tool. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("retrievedUrl")] + public string? RetrievedUrl { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,21 +30,21 @@ public sealed partial class UrlMetadata /// /// Initializes a new instance of the class. /// - /// - /// Retrieved url by the tool. - /// /// /// Status of the url retrieval. /// + /// + /// Retrieved url by the tool. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public UrlMetadata( - string? retrievedUrl, - global::Google.Gemini.UrlMetadataUrlRetrievalStatus? urlRetrievalStatus) + global::Google.Gemini.UrlMetadataUrlRetrievalStatus? urlRetrievalStatus, + string? retrievedUrl) { - this.RetrievedUrl = retrievedUrl; this.UrlRetrievalStatus = urlRetrievalStatus; + this.RetrievedUrl = retrievedUrl; } /// 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 874ed462..87263e13 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,33 +9,30 @@ namespace Google.Gemini public sealed partial class UsageMetadata { /// - /// Output only. Number of tokens present in tool-use prompt(s).
- /// Included only in responses + /// Total number of tokens across all the generated response candidates. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("toolUsePromptTokenCount")] - public int? ToolUsePromptTokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokenCount")] + public int? CandidatesTokenCount { get; set; } /// - /// Output only. Service tier of the request.
- /// Included only in responses + /// Total token count for the generation request (prompt + thoughts + response candidates). ///
- [global::System.Text.Json.Serialization.JsonPropertyName("serviceTier")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierJsonConverter))] - public global::Google.Gemini.UsageMetadataServiceTier? ServiceTier { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("totalTokenCount")] + public int? TotalTokenCount { get; set; } /// - /// Output only. Number of tokens of thoughts for thinking models.
+ /// Output only. List of modalities that were returned in the response.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("thoughtsTokenCount")] - public int? ThoughtsTokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokensDetails")] + public global::System.Collections.Generic.IList? CandidatesTokensDetails { get; set; } /// - /// Output only. List of modalities of the cached content in the request input.
+ /// Output only. Number of tokens of thoughts for thinking models.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("cacheTokensDetails")] - public global::System.Collections.Generic.IList? CacheTokensDetails { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("thoughtsTokenCount")] + public int? ThoughtsTokenCount { get; set; } /// /// Number of tokens in the cached part of the prompt (the cached content) @@ -44,31 +41,33 @@ public sealed partial class UsageMetadata public int? CachedContentTokenCount { get; set; } /// - /// Output only. List of modalities that were returned in the response.
+ /// Output only. Number of tokens present in tool-use prompt(s).
/// 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("toolUsePromptTokenCount")] + public int? ToolUsePromptTokenCount { get; set; } /// - /// Output only. List of modalities that were processed for tool-use request inputs.
+ /// Output only. List of modalities of the cached content in the request input.
/// 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("cacheTokensDetails")] + public global::System.Collections.Generic.IList? CacheTokensDetails { get; set; } /// - /// Total number of tokens across all the generated response candidates. + /// Output only. List of modalities that were processed for tool-use request inputs.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokenCount")] - public int? CandidatesTokenCount { 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.
+ /// Output only. Service tier of the request.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("promptTokensDetails")] - public global::System.Collections.Generic.IList? PromptTokensDetails { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("serviceTier")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierJsonConverter))] + public global::Google.Gemini.UsageMetadataServiceTier? ServiceTier { get; set; } /// /// 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. @@ -77,10 +76,11 @@ public sealed partial class UsageMetadata public int? PromptTokenCount { get; set; } /// - /// Total token count for the generation request (prompt + thoughts + response candidates). + /// Output only. List of modalities that were processed in the request input.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("totalTokenCount")] - public int? TotalTokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("promptTokensDetails")] + public global::System.Collections.Generic.IList? PromptTokensDetails { get; set; } /// /// Output only. Number of tokens in the response. Used by Gemini 3.1+ Live API models instead of candidatesTokenCount.
@@ -105,45 +105,45 @@ public sealed partial class UsageMetadata /// /// Initializes a new instance of the class. /// - /// - /// Output only. Number of tokens present in tool-use prompt(s).
- /// Included only in responses + /// + /// Total number of tokens across all the generated response candidates. /// - /// - /// Output only. Service tier of the request.
+ /// + /// Total token count for the generation request (prompt + thoughts + response candidates). + /// + /// + /// Output only. List of modalities that were returned in the response.
/// Included only in responses /// /// /// 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.
- /// Included only in responses - /// /// /// Number of tokens in the cached part of the prompt (the cached content) /// - /// - /// Output only. List of modalities that were returned in the response.
+ /// + /// Output only. Number of tokens present in tool-use prompt(s).
+ /// Included only in responses + /// + /// + /// Output only. List of modalities of the cached content in the request input.
/// Included only in responses /// /// /// Output only. List of modalities that were processed for tool-use request inputs.
/// Included only in responses /// - /// - /// Total number of tokens across all the generated response candidates. - /// - /// - /// Output only. List of modalities that were processed in the request input.
+ /// + /// Output only. Service tier of the request.
/// Included only in responses /// /// /// 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. /// - /// - /// Total token count for the generation request (prompt + thoughts + response candidates). + /// + /// Output only. List of modalities that were processed in the request input.
+ /// Included only in responses /// /// /// Output only. Number of tokens in the response. Used by Gemini 3.1+ Live API models instead of candidatesTokenCount.
@@ -157,31 +157,31 @@ public sealed partial class UsageMetadata [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public UsageMetadata( - int? toolUsePromptTokenCount, - global::Google.Gemini.UsageMetadataServiceTier? serviceTier, + int? candidatesTokenCount, + int? totalTokenCount, + global::System.Collections.Generic.IList? candidatesTokensDetails, int? thoughtsTokenCount, - global::System.Collections.Generic.IList? cacheTokensDetails, int? cachedContentTokenCount, - global::System.Collections.Generic.IList? candidatesTokensDetails, + int? toolUsePromptTokenCount, + global::System.Collections.Generic.IList? cacheTokensDetails, global::System.Collections.Generic.IList? toolUsePromptTokensDetails, - int? candidatesTokenCount, - global::System.Collections.Generic.IList? promptTokensDetails, + global::Google.Gemini.UsageMetadataServiceTier? serviceTier, int? promptTokenCount, - int? totalTokenCount, + global::System.Collections.Generic.IList? promptTokensDetails, int? responseTokenCount, global::System.Collections.Generic.IList? responseTokensDetails) { - this.ToolUsePromptTokenCount = toolUsePromptTokenCount; - this.ServiceTier = serviceTier; + this.CandidatesTokenCount = candidatesTokenCount; + this.TotalTokenCount = totalTokenCount; + this.CandidatesTokensDetails = candidatesTokensDetails; this.ThoughtsTokenCount = thoughtsTokenCount; - this.CacheTokensDetails = cacheTokensDetails; this.CachedContentTokenCount = cachedContentTokenCount; - this.CandidatesTokensDetails = candidatesTokensDetails; + this.ToolUsePromptTokenCount = toolUsePromptTokenCount; + this.CacheTokensDetails = cacheTokensDetails; this.ToolUsePromptTokensDetails = toolUsePromptTokensDetails; - this.CandidatesTokenCount = candidatesTokenCount; - this.PromptTokensDetails = promptTokensDetails; + this.ServiceTier = serviceTier; this.PromptTokenCount = promptTokenCount; - this.TotalTokenCount = totalTokenCount; + this.PromptTokensDetails = promptTokensDetails; 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 3719af7e..96e74ccb 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 end offset of the video. /// - [global::System.Text.Json.Serialization.JsonPropertyName("startOffset")] + [global::System.Text.Json.Serialization.JsonPropertyName("endOffset")] [global::System.Obsolete("This property marked as deprecated.")] - public string? StartOffset { get; set; } + 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]. @@ -24,11 +24,11 @@ public sealed partial class VideoMetadata public double? Fps { get; set; } /// - /// Optional. The end offset of the video. + /// Optional. The start offset of the video. /// - [global::System.Text.Json.Serialization.JsonPropertyName("endOffset")] + [global::System.Text.Json.Serialization.JsonPropertyName("startOffset")] [global::System.Obsolete("This property marked as deprecated.")] - public string? EndOffset { 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 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 end offset of the video. + /// + /// Optional. The start offset of the video. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public VideoMetadata( - string? startOffset, + string? endOffset, double? fps, - string? endOffset) + string? startOffset) { - this.StartOffset = startOffset; - this.Fps = fps; this.EndOffset = endOffset; + this.Fps = fps; + this.StartOffset = startOffset; } /// diff --git a/src/libs/Google.Gemini/openapi.json b/src/libs/Google.Gemini/openapi.json index b9949d96..c7e1e0e1 100644 --- a/src/libs/Google.Gemini/openapi.json +++ b/src/libs/Google.Gemini/openapi.json @@ -11,23 +11,15 @@ } ], "paths": { - "/tunedModels": { + "/corpora": { "get": { - "description": "Lists created tuned models.", - "operationId": "tunedModels.list", + "description": "Lists all `Corpora` owned by the user.", + "operationId": "corpora.list", "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", - "schema": { - "type": "string" - } - }, { "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 `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" @@ -36,7 +28,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 `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" } @@ -48,7 +40,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListTunedModelsResponse" + "$ref": "#/components/schemas/ListCorporaResponse" } } } @@ -56,23 +48,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 an empty `Corpus`.", + "operationId": "corpora.create", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/Corpus" } } } @@ -83,7 +65,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Corpus" } } } @@ -91,47 +73,29 @@ } } }, - "/tunedModels/{tunedModelsId}": { - "patch": { - "description": "Updates a tuned model.", - "operationId": "tunedModels.patch", + "/corpora/{corporaId}": { + "get": { + "description": "Gets information about a specific `Corpus`.", + "operationId": "corpora.get", "parameters": [ { - "name": "tunedModelsId", + "name": "corporaId", "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/[^/]+$" - } - }, - { - "name": "updateMask", - "in": "query", - "description": "Optional. The list of fields to update.", + "description": "Required. The name of the `Corpus`. Example: `corpora/my-corpus-123`", "schema": { "type": "string", - "format": "google-fieldmask" + "pattern": "^corpora/[^/]+$" } } ], - "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/Corpus" } } } @@ -139,17 +103,25 @@ } }, "delete": { - "description": "Deletes a tuned model.", - "operationId": "tunedModels.delete", + "description": "Deletes a `Corpus`.", + "operationId": "corpora.delete", "parameters": [ { - "name": "tunedModelsId", + "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": "boolean" + } + }, + { + "name": "corporaId", "in": "path", "required": true, - "description": "Required. The resource name of the model. Format: `tunedModels/my-model-id`", + "description": "Required. The resource name of the `Corpus`. Example: `corpora/my-corpus-123`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^corpora/[^/]+$" } } ], @@ -165,19 +137,29 @@ } } } - }, + } + }, + "/corpora/{corporaId}/operations/{operationsId}": { "get": { - "description": "Gets information about a specific TunedModel.", - "operationId": "tunedModels.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", "parameters": [ { - "name": "tunedModelsId", + "name": "operationsId", "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": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^corpora/[^/]+/operations/[^/]+$" } } ], @@ -187,7 +169,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/Operation" } } } @@ -195,19 +177,19 @@ } } }, - "/tunedModels/{tunedModelsId}:generateContent": { + "/corpora/{corporaId}/permissions": { "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", + "description": "Create a permission to a specific resource.", + "operationId": "corpora.permissions.create", "parameters": [ { - "name": "tunedModelsId", + "name": "corporaId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "Required. The parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^corpora/[^/]+$" } } ], @@ -215,7 +197,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "$ref": "#/components/schemas/Permission" } } } @@ -226,46 +208,52 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/Permission" } } } } } - } - }, - "/tunedModels/{tunedModelsId}:batchGenerateContent": { - "post": { - "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", - "operationId": "tunedModels.batchGenerateContent", + }, + "get": { + "description": "Lists permissions for the specific resource.", + "operationId": "corpora.permissions.list", "parameters": [ { - "name": "tunedModelsId", + "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 name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^corpora/[^/]+$" } } ], - "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/ListPermissionsResponse" } } } @@ -273,19 +261,36 @@ } } }, - "/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", + "/corpora/{corporaId}/permissions/{permissionsId}": { + "patch": { + "description": "Updates the permission.", + "operationId": "corpora.permissions.patch", "parameters": [ { - "name": "tunedModelsId", + "name": "permissionsId", "in": "path", "required": true, - "description": "Required. The resource name of the tuned model to transfer ownership. Format: `tunedModels/my-model-id`", + "schema": { + "type": "string" + } + }, + { + "name": "corporaId", + "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": "^tunedModels/[^/]+$" + "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" } } ], @@ -293,7 +298,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TransferOwnershipRequest" + "$ref": "#/components/schemas/Permission" } } } @@ -304,90 +309,79 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TransferOwnershipResponse" + "$ref": "#/components/schemas/Permission" } } } } } - } - }, - "/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", + }, + "delete": { + "description": "Deletes the permission.", + "operationId": "corpora.permissions.delete", "parameters": [ { - "name": "tunedModelsId", + "name": "permissionsId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "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/[^/]+$" } } ], - "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/Empty" } } } } } - } - }, - "/tunedModels/{tunedModelsId}: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": "tunedModels.asyncBatchEmbedContent", - "parameters": [ + }, + "get": { + "description": "Gets information about a specific Permission.", + "operationId": "corpora.permissions.get", + "parameters": [ { - "name": "tunedModelsId", + "name": "permissionsId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "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/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Permission" } } } @@ -395,27 +389,26 @@ } } }, - "/tunedModels/{tunedModelsId}/permissions/{permissionsId}": { + "/files": { "get": { - "description": "Gets information about a specific Permission.", - "operationId": "tunedModels.permissions.get", + "description": "Lists the metadata for `File`s owned by the requesting project.", + "operationId": "files.list", "parameters": [ { - "name": "tunedModelsId", - "in": "path", - "required": true, + "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" + "type": "integer", + "format": "int32" } }, { - "name": "permissionsId", - "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 `ListFiles` call.", "schema": { - "type": "string", - "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" + "type": "string" } } ], @@ -425,50 +418,48 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/ListFilesResponse" } } } } } }, - "patch": { - "description": "Updates the permission.", - "operationId": "tunedModels.permissions.patch", - "parameters": [ - { - "name": "tunedModelsId", - "in": "path", - "required": true, - "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": "^tunedModels/[^/]+/permissions/[^/]+$" + "post": { + "description": "Creates a `File`.", + "operationId": "media.upload", + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/CreateFileRequest" + } } - }, - { - "name": "updateMask", - "in": "query", - "description": "Required. The list of fields to update. Accepted ones: - role (`Permission.role` field)", - "schema": { - "type": "string", - "format": "google-fieldmask" + } + }, + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/CreateFileResponse" + } + } } } - ], + } + } + }, + "/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/Permission" + "$ref": "#/components/schemas/RegisterFilesRequest" } } } @@ -479,33 +470,27 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/RegisterFilesResponse" } } } } } - }, - "delete": { - "description": "Deletes the permission.", - "operationId": "tunedModels.permissions.delete", + } + }, + "/files/{filesId}": { + "get": { + "description": "Gets the metadata for the given `File`.", + "operationId": "files.get", "parameters": [ { - "name": "tunedModelsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "permissionsId", + "name": "filesId", "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 name of the `File` to get. Example: `files/abc-123`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" + "pattern": "^files/[^/]+$" } } ], @@ -515,44 +500,25 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/File" } } } } } - } - }, - "/tunedModels/{tunedModelsId}/permissions": { - "get": { - "description": "Lists permissions for the specific resource.", - "operationId": "tunedModels.permissions.list", + }, + "delete": { + "description": "Deletes the `File`.", + "operationId": "files.delete", "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": "tunedModelsId", + "name": "filesId", "in": "path", "required": true, - "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", + "description": "Required. The name of the `File` to delete. Example: `files/abc-123`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^files/[^/]+$" } } ], @@ -562,25 +528,25 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListPermissionsResponse" + "$ref": "#/components/schemas/Empty" } } } } } - }, + } + }, + "/tunedModels": { "post": { - "description": "Create a permission to a specific resource.", - "operationId": "tunedModels.permissions.create", + "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": "tunedModelsId", - "in": "path", - "required": true, - "description": "Required. The parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", + "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", - "pattern": "^tunedModels/[^/]+$" + "type": "string" } } ], @@ -588,7 +554,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/TunedModel" } } } @@ -599,41 +565,29 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/Operation" } } } } } - } - }, - "/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", + "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" } }, - { - "name": "tunedModelsId", - "in": "path", - "required": true, - "description": "The name of the operation's parent resource.", - "schema": { - "type": "string", - "pattern": "^tunedModels/[^/]+$" - } - }, { "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" @@ -642,18 +596,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": { @@ -662,7 +608,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListOperationsResponse" + "$ref": "#/components/schemas/ListTunedModelsResponse" } } } @@ -670,37 +616,43 @@ } } }, - "/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", + "/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": "tunedModelsId", "in": "path", "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "operationsId", - "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": "^tunedModels/[^/]+/operations/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], - "responses": { - "200": { + "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" } } } @@ -708,47 +660,58 @@ } } }, - "/cachedContents/{cachedContentsId}": { - "delete": { - "description": "Deletes CachedContent resource.", - "operationId": "cachedContents.delete", + "/tunedModels/{tunedModelsId}: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": "tunedModels.asyncBatchEmbedContent", "parameters": [ { - "name": "cachedContentsId", + "name": "tunedModelsId", "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": "^tunedModels/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/Operation" } } } } } - }, + } + }, + "/tunedModels/{tunedModelsId}": { "get": { - "description": "Reads CachedContent resource.", - "operationId": "cachedContents.get", + "description": "Gets information about a specific TunedModel.", + "operationId": "tunedModels.get", "parameters": [ { - "name": "cachedContentsId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The resource name referring to the content cache entry. Format: `cachedContents/{id}`", + "description": "Required. The resource name of the model. Format: `tunedModels/my-model-id`", "schema": { "type": "string", - "pattern": "^cachedContents/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], @@ -758,7 +721,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/TunedModel" } } } @@ -766,23 +729,23 @@ } }, "patch": { - "description": "Updates CachedContent resource (only expiration is updatable).", - "operationId": "cachedContents.patch", + "description": "Updates a tuned model.", + "operationId": "tunedModels.patch", "parameters": [ { - "name": "cachedContentsId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`", + "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": "^cachedContents/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } }, { "name": "updateMask", "in": "query", - "description": "The list of fields to update.", + "description": "Optional. The list of fields to update.", "schema": { "type": "string", "format": "google-fieldmask" @@ -793,34 +756,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" - } - } - } - }, - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/CachedContent" - } - } - } - } - } - } - }, - "/cachedContents": { - "post": { - "description": "Creates CachedContent resource.", - "operationId": "cachedContents.create", - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/TunedModel" } } } @@ -831,32 +767,25 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/TunedModel" } } } } } }, - "get": { - "description": "Lists CachedContents.", - "operationId": "cachedContents.list", + "delete": { + "description": "Deletes a tuned model.", + "operationId": "tunedModels.delete", "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": "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/[^/]+$" } } ], @@ -866,7 +795,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListCachedContentsResponse" + "$ref": "#/components/schemas/Empty" } } } @@ -874,50 +803,27 @@ } } }, - "/files": { - "get": { - "description": "Lists the metadata for `File`s owned by the requesting project.", - "operationId": "files.list", + "/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", "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 name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { - "type": "string" + "type": "string", + "pattern": "^tunedModels/[^/]+$" } } ], - "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/CreateFileRequest" + "$ref": "#/components/schemas/GenerateContentRequest" } } } @@ -928,7 +834,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CreateFileResponse" + "$ref": "#/components/schemas/GenerateContentResponse" } } } @@ -936,73 +842,66 @@ } } }, - "/files/{filesId}": { - "get": { - "description": "Gets the metadata for the given `File`.", - "operationId": "files.get", + "/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", "parameters": [ { - "name": "filesId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The name of the `File` to get. Example: `files/abc-123`", + "description": "Required. The resource name of the tuned model to transfer ownership. Format: `tunedModels/my-model-id`", "schema": { "type": "string", - "pattern": "^files/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/TransferOwnershipRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/File" + "$ref": "#/components/schemas/TransferOwnershipResponse" } } } } } - }, - "delete": { - "description": "Deletes the `File`.", - "operationId": "files.delete", + } + }, + "/tunedModels/{tunedModelsId}:batchGenerateContent": { + "post": { + "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", + "operationId": "tunedModels.batchGenerateContent", "parameters": [ { - "name": "filesId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The name of the `File` to delete. Example: `files/abc-123`", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^files/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Empty" - } - } - } - } - } - } - }, - "/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" + "$ref": "#/components/schemas/BatchGenerateContentRequest" } } } @@ -1013,7 +912,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/RegisterFilesResponse" + "$ref": "#/components/schemas/Operation" } } } @@ -1021,55 +920,90 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}": { + "/tunedModels/{tunedModelsId}/operations/{operationsId}": { "get": { - "description": "Gets information about a specific `FileSearchStore`.", - "operationId": "fileSearchStores.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": "fileSearchStoresId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The name of the `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", "schema": { - "type": "string", - "pattern": "^fileSearchStores/[^/]+$" + "type": "string" } - } - ], - "responses": { - "200": { - "description": "Successful response", + }, + { + "name": "operationsId", + "in": "path", + "required": true, + "description": "The name of the operation resource.", + "schema": { + "type": "string", + "pattern": "^tunedModels/[^/]+/operations/[^/]+$" + } + } + ], + "responses": { + "200": { + "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/FileSearchStore" + "$ref": "#/components/schemas/Operation" } } } } } - }, - "delete": { - "description": "Deletes a `FileSearchStore`.", - "operationId": "fileSearchStores.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 `FileSearchStore` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `FileSearchStore` contains any `Document`s.", + "description": "The standard list filter.", "schema": { - "type": "boolean" + "type": "string" } }, { - "name": "fileSearchStoresId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The resource name of the `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", + "description": "The name of the operation's parent resource.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+$" + "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" } } ], @@ -1079,7 +1013,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/ListOperationsResponse" } } } @@ -1087,15 +1021,15 @@ } } }, - "/fileSearchStores": { + "/tunedModels/{tunedModelsId}/permissions": { "get": { - "description": "Lists all `FileSearchStores` owned by the user.", - "operationId": "fileSearchStores.list", + "description": "Lists permissions for the specific resource.", + "operationId": "tunedModels.permissions.list", "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.", + "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" @@ -1104,10 +1038,20 @@ { "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.", + "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": { @@ -1116,7 +1060,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListFileSearchStoresResponse" + "$ref": "#/components/schemas/ListPermissionsResponse" } } } @@ -1124,44 +1068,17 @@ } }, "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" - } - } - } - } - } - } - }, - "/fileSearchStores/{fileSearchStoresId}:importFile": { - "post": { - "description": "Imports a `File` from File Service to a `FileSearchStore`.", - "operationId": "fileSearchStores.importFile", + "description": "Create a permission to a specific resource.", + "operationId": "tunedModels.permissions.create", "parameters": [ { - "name": "fileSearchStoresId", + "name": "tunedModelsId", "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 parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], @@ -1169,7 +1086,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ImportFileRequest" + "$ref": "#/components/schemas/Permission" } } } @@ -1180,7 +1097,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Permission" } } } @@ -1188,13 +1105,13 @@ } } }, - "/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", + "/tunedModels/{tunedModelsId}/permissions/{permissionsId}": { + "patch": { + "description": "Updates the permission.", + "operationId": "tunedModels.permissions.patch", "parameters": [ { - "name": "operationsId", + "name": "tunedModelsId", "in": "path", "required": true, "schema": { @@ -1202,37 +1119,53 @@ } }, { - "name": "fileSearchStoresId", + "name": "permissionsId", "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": "^fileSearchStores/[^/]+/upload/operations/[^/]+$" + "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" } } ], + "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" } } } } } - } - }, - "/fileSearchStores/{fileSearchStoresId}/documents/{documentsId}": { - "get": { - "description": "Gets information about a specific `Document`.", - "operationId": "fileSearchStores.documents.get", + }, + "delete": { + "description": "Deletes the permission.", + "operationId": "tunedModels.permissions.delete", "parameters": [ { - "name": "fileSearchStoresId", + "name": "tunedModelsId", "in": "path", "required": true, "schema": { @@ -1240,13 +1173,13 @@ } }, { - "name": "documentsId", + "name": "permissionsId", "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": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" + "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" } } ], @@ -1256,19 +1189,19 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Document" + "$ref": "#/components/schemas/Empty" } } } } } }, - "delete": { - "description": "Deletes a `Document`.", - "operationId": "fileSearchStores.documents.delete", + "get": { + "description": "Gets information about a specific Permission.", + "operationId": "tunedModels.permissions.get", "parameters": [ { - "name": "fileSearchStoresId", + "name": "tunedModelsId", "in": "path", "required": true, "schema": { @@ -1276,21 +1209,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": "permissionsId", "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": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" + "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" } } ], @@ -1300,7 +1225,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/Permission" } } } @@ -1308,36 +1233,19 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}/documents": { + "/models/{modelsId}": { "get": { - "description": "Lists all `Document`s in a `Corpus`.", - "operationId": "fileSearchStores.documents.list", + "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": "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": "modelsId", "in": "path", "required": true, - "description": "Required. The name of the `FileSearchStore` containing `Document`s. 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/[^/]+$" } } ], @@ -1347,7 +1255,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListDocumentsResponse" + "$ref": "#/components/schemas/Model" } } } @@ -1355,37 +1263,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}: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": "operationsId", + "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" - } - }, - { - "name": "fileSearchStoresId", - "in": "path", - "required": true, - "description": "The name of the operation resource.", - "schema": { - "type": "string", - "pattern": "^fileSearchStores/[^/]+/operations/[^/]+$" + "type": "string", + "pattern": "^models/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/CountTokensRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/CountTokensResponse" } } } @@ -1393,10 +1302,10 @@ } } }, - "/models/{modelsId}:streamGenerateContent": { + "/models/{modelsId}:asyncBatchEmbedContent": { "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", + "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": "modelsId", @@ -1413,7 +1322,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" } } } @@ -1424,12 +1333,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" - } - }, - "text/event-stream": { - "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/Operation" } } } @@ -1437,29 +1341,38 @@ } } }, - "/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", + "/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 of the model. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", "pattern": "^models/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/BatchGenerateContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Model" + "$ref": "#/components/schemas/Operation" } } } @@ -1467,38 +1380,36 @@ } } }, - "/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", + "/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": "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": "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.", "schema": { - "type": "string", - "pattern": "^models/[^/]+$" + "type": "integer", + "format": "int32" } - } - ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/BatchEmbedContentsRequest" - } + }, + { + "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" } } - }, + ], "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/BatchEmbedContentsResponse" + "$ref": "#/components/schemas/ListModelsResponse" } } } @@ -1506,10 +1417,10 @@ } } }, - "/models/{modelsId}:asyncBatchEmbedContent": { + "/models/{modelsId}:generateContent": { "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", + "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": "modelsId", @@ -1526,7 +1437,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" + "$ref": "#/components/schemas/GenerateContentRequest" } } } @@ -1537,7 +1448,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/GenerateContentResponse" } } } @@ -1545,16 +1456,16 @@ } } }, - "/models/{modelsId}:batchGenerateContent": { + "/models/{modelsId}:batchEmbedContents": { "post": { - "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", - "operationId": "models.batchGenerateContent", + "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": "modelsId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{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}`", "schema": { "type": "string", "pattern": "^models/[^/]+$" @@ -1565,7 +1476,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/BatchGenerateContentRequest" + "$ref": "#/components/schemas/BatchEmbedContentsRequest" } } } @@ -1576,7 +1487,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/BatchEmbedContentsResponse" } } } @@ -1584,16 +1495,16 @@ } } }, - "/models/{modelsId}:embedContent": { + "/models/{modelsId}:streamGenerateContent": { "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", + "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": "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}`", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", "pattern": "^models/[^/]+$" @@ -1604,7 +1515,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/EmbedContentRequest" + "$ref": "#/components/schemas/GenerateContentRequest" } } } @@ -1615,7 +1526,12 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/EmbedContentResponse" + "$ref": "#/components/schemas/GenerateContentResponse" + } + }, + "text/event-stream": { + "schema": { + "$ref": "#/components/schemas/GenerateContentResponse" } } } @@ -1623,16 +1539,16 @@ } } }, - "/models/{modelsId}:generateContent": { + "/models/{modelsId}:embedContent": { "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": "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": "modelsId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{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}`", "schema": { "type": "string", "pattern": "^models/[^/]+$" @@ -1643,7 +1559,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "$ref": "#/components/schemas/EmbedContentRequest" } } } @@ -1654,7 +1570,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/EmbedContentResponse" } } } @@ -1662,75 +1578,37 @@ } } }, - "/models": { + "/models/{modelsId}/operations/{operationsId}": { "get": { - "description": "Lists the [`Model`s](https://ai.google.dev/gemini-api/docs/models/gemini) available through the Gemini API.", - "operationId": "models.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": "models.operations.get", "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.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "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.", + "name": "operationsId", + "in": "path", + "required": true, "schema": { "type": "string" } - } - ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/ListModelsResponse" - } - } - } - } - } - } - }, - "/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}`", + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^models/[^/]+/operations/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/CountTokensRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CountTokensResponse" + "$ref": "#/components/schemas/Operation" } } } @@ -1801,27 +1679,19 @@ } } }, - "/models/{modelsId}/operations/{operationsId}": { + "/cachedContents/{cachedContentsId}": { "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", + "description": "Reads CachedContent resource.", + "operationId": "cachedContents.get", "parameters": [ { - "name": "operationsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "modelsId", + "name": "cachedContentsId", "in": "path", "required": true, - "description": "The name of the operation resource.", + "description": "Required. The resource name referring to the content cache entry. Format: `cachedContents/{id}`", "schema": { "type": "string", - "pattern": "^models/[^/]+/operations/[^/]+$" + "pattern": "^cachedContents/[^/]+$" } } ], @@ -1831,63 +1701,71 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/CachedContent" } } } } } - } - }, - "/corpora/{corporaId}": { - "delete": { - "description": "Deletes a `Corpus`.", - "operationId": "corpora.delete", + }, + "patch": { + "description": "Updates CachedContent resource (only expiration is updatable).", + "operationId": "cachedContents.patch", "parameters": [ { - "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.", + "name": "cachedContentsId", + "in": "path", + "required": true, + "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`", "schema": { - "type": "boolean" + "type": "string", + "pattern": "^cachedContents/[^/]+$" } }, { - "name": "corporaId", - "in": "path", - "required": true, - "description": "Required. The resource name of the `Corpus`. Example: `corpora/my-corpus-123`", + "name": "updateMask", + "in": "query", + "description": "The list of fields to update.", "schema": { "type": "string", - "pattern": "^corpora/[^/]+$" + "format": "google-fieldmask" } } ], - "responses": { - "200": { - "description": "Successful response", + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/CachedContent" + } + } + } + }, + "responses": { + "200": { + "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/CachedContent" } } } } } }, - "get": { - "description": "Gets information about a specific `Corpus`.", - "operationId": "corpora.get", + "delete": { + "description": "Deletes CachedContent resource.", + "operationId": "cachedContents.delete", "parameters": [ { - "name": "corporaId", + "name": "cachedContentsId", "in": "path", "required": true, - "description": "Required. The name of the `Corpus`. Example: `corpora/my-corpus-123`", + "description": "Required. The resource name referring to the content cache entry Format: `cachedContents/{id}`", "schema": { "type": "string", - "pattern": "^corpora/[^/]+$" + "pattern": "^cachedContents/[^/]+$" } } ], @@ -1897,7 +1775,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Corpus" + "$ref": "#/components/schemas/Empty" } } } @@ -1905,15 +1783,15 @@ } } }, - "/corpora": { + "/cachedContents": { "post": { - "description": "Creates an empty `Corpus`.", - "operationId": "corpora.create", + "description": "Creates CachedContent resource.", + "operationId": "cachedContents.create", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Corpus" + "$ref": "#/components/schemas/CachedContent" } } } @@ -1924,7 +1802,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Corpus" + "$ref": "#/components/schemas/CachedContent" } } } @@ -1932,13 +1810,13 @@ } }, "get": { - "description": "Lists all `Corpora` owned by the user.", - "operationId": "corpora.list", + "description": "Lists CachedContents.", + "operationId": "cachedContents.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": "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" @@ -1947,7 +1825,7 @@ { "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": "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" } @@ -1959,7 +1837,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListCorporaResponse" + "$ref": "#/components/schemas/ListCachedContentsResponse" } } } @@ -1967,27 +1845,42 @@ } } }, - "/corpora/{corporaId}/operations/{operationsId}": { + "/batches": { "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", + "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": "operationsId", - "in": "path", - "required": true, + "name": "filter", + "in": "query", + "description": "The standard list filter.", "schema": { "type": "string" } }, { - "name": "corporaId", - "in": "path", - "required": true, - "description": "The name of the operation resource.", + "name": "pageSize", + "in": "query", + "description": "The standard list page size.", "schema": { - "type": "string", - "pattern": "^corpora/[^/]+/operations/[^/]+$" + "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" } } ], @@ -1997,7 +1890,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/ListOperationsResponse" } } } @@ -2005,27 +1898,47 @@ } } }, - "/corpora/{corporaId}/permissions/{permissionsId}": { - "get": { - "description": "Gets information about a specific Permission.", - "operationId": "corpora.permissions.get", + "/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": "permissionsId", + "name": "batchesId", "in": "path", "required": true, + "description": "The name of the operation resource to be deleted.", "schema": { - "type": "string" + "type": "string", + "pattern": "^batches/[^/]+$" } - }, + } + ], + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Empty" + } + } + } + } + } + }, + "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": "corporaId", + "name": "batchesId", "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": "^corpora/[^/]+/permissions/[^/]+$" + "pattern": "^batches/[^/]+$" } } ], @@ -2035,39 +1948,63 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/Operation" } } } } } - }, - "patch": { - "description": "Updates the permission.", - "operationId": "corpora.permissions.patch", + } + }, + "/batches/{batchesId}:cancel": { + "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", "parameters": [ { - "name": "permissionsId", + "name": "batchesId", "in": "path", "required": true, + "description": "The name of the operation resource to be cancelled.", "schema": { - "type": "string" + "type": "string", + "pattern": "^batches/[^/]+$" } - }, + } + ], + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Empty" + } + } + } + } + } + } + }, + "/batches/{batchesId}:updateGenerateContentBatch": { + "patch": { + "description": "Updates a batch of GenerateContent requests for batch processing.", + "operationId": "batches.updateGenerateContentBatch", + "parameters": [ { - "name": "corporaId", + "name": "batchesId", "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": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", "schema": { "type": "string", - "pattern": "^corpora/[^/]+/permissions/[^/]+$" + "pattern": "^batches/[^/]+$" } }, { "name": "updateMask", "in": "query", - "description": "Required. The list of fields to update. Accepted ones: - role (`Permission.role` field)", + "description": "Optional. The list of fields to update.", "schema": { "type": "string", "format": "google-fieldmask" @@ -2078,7 +2015,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/GenerateContentBatch" } } } @@ -2089,43 +2026,55 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/GenerateContentBatch" } } } } } - }, - "delete": { - "description": "Deletes the permission.", - "operationId": "corpora.permissions.delete", + } + }, + "/batches/{batchesId}:updateEmbedContentBatch": { + "patch": { + "description": "Updates a batch of EmbedContent requests for batch processing.", + "operationId": "batches.updateEmbedContentBatch", "parameters": [ { - "name": "permissionsId", + "name": "batchesId", "in": "path", "required": true, + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", "schema": { - "type": "string" + "type": "string", + "pattern": "^batches/[^/]+$" } }, { - "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": "updateMask", + "in": "query", + "description": "Optional. The list of fields to update.", "schema": { "type": "string", - "pattern": "^corpora/[^/]+/permissions/[^/]+$" + "format": "google-fieldmask" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/EmbedContentBatch" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/EmbedContentBatch" } } } @@ -2133,15 +2082,15 @@ } } }, - "/corpora/{corporaId}/permissions": { + "/generatedFiles": { "get": { - "description": "Lists permissions for the specific resource.", - "operationId": "corpora.permissions.list", + "description": "Lists the generated files owned by the requesting project.", + "operationId": "generatedFiles.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. Maximum number of `GeneratedFile`s to return per page. If unspecified, defaults to 10. Maximum `page_size` is 50.", "schema": { "type": "integer", "format": "int32" @@ -2150,20 +2099,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 from a previous `ListGeneratedFiles` call.", "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": { @@ -2172,44 +2111,45 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListPermissionsResponse" + "$ref": "#/components/schemas/ListGeneratedFilesResponse" } } } } } - }, - "post": { - "description": "Create a permission to a specific resource.", - "operationId": "corpora.permissions.create", + } + }, + "/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": "corporaId", + "name": "operationsId", "in": "path", "required": true, - "description": "Required. The parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", "schema": { - "type": "string", - "pattern": "^corpora/[^/]+$" + "type": "string" } - } - ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Permission" - } + }, + { + "name": "generatedFilesId", + "in": "path", + "required": true, + "description": "The name of the operation resource.", + "schema": { + "type": "string", + "pattern": "^generatedFiles/[^/]+/operations/[^/]+$" } } - }, + ], "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/Operation" } } } @@ -2217,57 +2157,82 @@ } } }, - "/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", + "/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": "batchesId", + "name": "dynamicId", "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": "^dynamic/[^/]+$" } } ], + "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" } } } } } - }, - "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" } } } @@ -2275,28 +2240,19 @@ } } }, - "/batches/{batchesId}:updateGenerateContentBatch": { - "patch": { - "description": "Updates a batch of GenerateContent requests for batch processing.", - "operationId": "batches.updateGenerateContentBatch", + "/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": "batchesId", + "name": "fileSearchStoresId", "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. Immutable. The name of the `FileSearchStore` to upload the file into. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "format": "google-fieldmask" + "pattern": "^fileSearchStores/[^/]+$" } } ], @@ -2304,7 +2260,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentBatch" + "$ref": "#/components/schemas/UploadToFileSearchStoreRequest" } } } @@ -2315,7 +2271,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentBatch" + "$ref": "#/components/schemas/CustomLongRunningOperation" } } } @@ -2323,28 +2279,19 @@ } } }, - "/batches/{batchesId}:updateEmbedContentBatch": { - "patch": { - "description": "Updates a batch of EmbedContent requests for batch processing.", - "operationId": "batches.updateEmbedContentBatch", + "/fileSearchStores/{fileSearchStoresId}:importFile": { + "post": { + "description": "Imports a `File` from File Service to a `FileSearchStore`.", + "operationId": "fileSearchStores.importFile", "parameters": [ { - "name": "batchesId", + "name": "fileSearchStoresId", "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. Immutable. The name of the `FileSearchStore` to import the file into. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "format": "google-fieldmask" + "pattern": "^fileSearchStores/[^/]+$" } } ], @@ -2352,7 +2299,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/EmbedContentBatch" + "$ref": "#/components/schemas/ImportFileRequest" } } } @@ -2363,7 +2310,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/EmbedContentBatch" + "$ref": "#/components/schemas/Operation" } } } @@ -2371,19 +2318,19 @@ } } }, - "/batches/{batchesId}:cancel": { - "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", + "/fileSearchStores/{fileSearchStoresId}": { + "get": { + "description": "Gets information about a specific `FileSearchStore`.", + "operationId": "fileSearchStores.get", "parameters": [ { - "name": "batchesId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "The name of the operation resource to be cancelled.", + "description": "Required. The name of the `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "pattern": "^batches/[^/]+$" + "pattern": "^fileSearchStores/[^/]+$" } } ], @@ -2393,50 +2340,33 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/FileSearchStore" } } } } } - } - }, - "/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", + }, + "delete": { + "description": "Deletes a `FileSearchStore`.", + "operationId": "fileSearchStores.delete", "parameters": [ { - "name": "filter", - "in": "query", - "description": "The standard list filter.", - "schema": { - "type": "string" - } - }, - { - "name": "pageSize", - "in": "query", - "description": "The standard list page size.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", + "name": "force", "in": "query", - "description": "The standard list page token.", + "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": "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": "fileSearchStoresId", + "in": "path", + "required": true, + "description": "Required. The resource name of the `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", "schema": { - "type": "boolean" + "type": "string", + "pattern": "^fileSearchStores/[^/]+$" } } ], @@ -2446,7 +2376,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListOperationsResponse" + "$ref": "#/components/schemas/Empty" } } } @@ -2454,15 +2384,40 @@ } } }, - "/generatedFiles": { + "/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 the generated files owned by the requesting project.", - "operationId": "generatedFiles.list", + "description": "Lists all `FileSearchStores` owned by the user.", + "operationId": "fileSearchStores.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 `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" @@ -2471,7 +2426,7 @@ { "name": "pageToken", "in": "query", - "description": "Optional. A page token from a previous `ListGeneratedFiles` call.", + "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" } @@ -2483,7 +2438,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListGeneratedFilesResponse" + "$ref": "#/components/schemas/ListFileSearchStoresResponse" } } } @@ -2491,10 +2446,10 @@ } } }, - "/generatedFiles/{generatedFilesId}/operations/{operationsId}": { + "/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": "generatedFiles.operations.get", + "operationId": "fileSearchStores.operations.get", "parameters": [ { "name": "operationsId", @@ -2505,13 +2460,13 @@ } }, { - "name": "generatedFilesId", + "name": "fileSearchStoresId", "in": "path", "required": true, "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^generatedFiles/[^/]+/operations/[^/]+$" + "pattern": "^fileSearchStores/[^/]+/operations/[^/]+$" } } ], @@ -2529,38 +2484,37 @@ } } }, - "/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", + "/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", "parameters": [ { - "name": "dynamicId", + "name": "operationsId", "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/[^/]+$" + "type": "string" } - } - ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" - } + }, + { + "name": "fileSearchStoresId", + "in": "path", + "required": true, + "description": "The name of the operation resource.", + "schema": { + "type": "string", + "pattern": "^fileSearchStores/[^/]+/upload/operations/[^/]+$" } } - }, + ], "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/Operation" } } } @@ -2568,43 +2522,81 @@ } } }, - "/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", + "/fileSearchStores/{fileSearchStoresId}/documents/{documentsId}": { + "get": { + "description": "Gets information about a specific `Document`.", + "operationId": "fileSearchStores.documents.get", "parameters": [ { - "name": "dynamicId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "schema": { + "type": "string" + } + }, + { + "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", - "pattern": "^dynamic/[^/]+$" + "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Document" + } } } } - }, + } + }, + "delete": { + "description": "Deletes a `Document`.", + "operationId": "fileSearchStores.documents.delete", + "parameters": [ + { + "name": "fileSearchStoresId", + "in": "path", + "required": true, + "schema": { + "type": "string" + } + }, + { + "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 `Document` to delete. Example: `fileSearchStores/my-file-search-store-123/documents/the-doc-abc`", + "schema": { + "type": "string", + "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" + } + } + ], "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" } } } @@ -2612,38 +2604,46 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}:uploadToFileSearchStore": { - "post": { - "description": "Uploads data to a FileSearchStore, preprocesses and chunks before storing it in a FileSearchStore Document.", - "operationId": "media.uploadToFileSearchStore", + "/fileSearchStores/{fileSearchStoresId}/documents": { + "get": { + "description": "Lists all `Document`s in a `Corpus`.", + "operationId": "fileSearchStores.documents.list", "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", "in": "path", "required": true, - "description": "Required. Immutable. The name of the `FileSearchStore` to upload the file into. Example: `fileSearchStores/my-file-search-store-123`", + "description": "Required. The name of the `FileSearchStore` containing `Document`s. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", "pattern": "^fileSearchStores/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/UploadToFileSearchStoreRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CustomLongRunningOperation" + "$ref": "#/components/schemas/ListDocumentsResponse" } } } @@ -2654,896 +2654,1382 @@ }, "components": { "schemas": { - "WhiteSpaceConfig": { - "type": "object", + "LogprobsResultCandidate": { + "description": "Candidate for the logprobs token and score.", "properties": { - "maxTokensPerChunk": { - "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.", - "type": "integer", - "format": "int32" + "token": { + "description": "The candidate\u2019s token string value.", + "type": "string" }, - "maxOverlapTokens": { - "format": "int32", + "tokenId": { "type": "integer", - "description": "Maximum number of overlapping tokens between two adjacent chunks." + "format": "int32", + "description": "The candidate\u2019s token id value." + }, + "logProbability": { + "type": "number", + "format": "float", + "description": "The candidate's log probability." } }, - "description": "Configuration for a white space chunking algorithm [white space delimited]." + "type": "object" }, - "InputConfig": { + "UrlContextMetadata": { "type": "object", + "description": "Metadata related to url context retrieval tool.", "properties": { - "fileName": { - "type": "string", - "description": "The name of the `File` containing the input requests." - }, - "requests": { - "description": "The requests to be processed in the batch.", - "$ref": "#/components/schemas/InlinedRequests" + "urlMetadata": { + "description": "List of url context.", + "type": "array", + "items": { + "$ref": "#/components/schemas/UrlMetadata" + } } - }, - "description": "Configures the input to the batch request." + } }, - "File": { + "ComputerUse": { "type": "object", + "description": "Computer Use tool type.", "properties": { - "sha256Hash": { - "readOnly": true, - "type": "string", - "format": "byte", - "description": "Output only. SHA-256 hash of the uploaded bytes." + "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" + } }, - "state": { + "environment": { + "description": "Required. The environment being operated.", + "x-enum-descriptions": [ + "Defaults to browser.", + "Operates in a web browser." + ], "enum": [ - "STATE_UNSPECIFIED", - "PROCESSING", - "ACTIVE", - "FAILED" + "ENVIRONMENT_UNSPECIFIED", + "ENVIRONMENT_BROWSER" ], - "readOnly": true, + "type": "string" + } + } + }, + "Corpus": { + "description": "A `Corpus` is a collection of `Document`s. A project can create up to 10 corpora.", + "properties": { + "name": { "type": "string", - "description": "Output only. Processing state of the File.", - "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." - ] + "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`" }, - "uri": { + "createTime": { "readOnly": true, "type": "string", - "description": "Output only. The uri of the `File`." + "format": "google-datetime", + "description": "Output only. The Timestamp of when the `Corpus` was created." }, - "error": { - "$ref": "#/components/schemas/Status", - "description": "Output only. Error status if File processing failed.", + "updateTime": { + "description": "Output only. The Timestamp of when the `Corpus` was last updated.", + "type": "string", + "format": "google-datetime", "readOnly": true }, - "videoMetadata": { - "readOnly": true, - "description": "Output only. Metadata for a video.", - "$ref": "#/components/schemas/VideoFileMetadata" + "displayName": { + "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\"", + "type": "string" + } + }, + "type": "object" + }, + "EmbedContentBatch": { + "type": "object", + "description": "A resource representing a batch of `EmbedContent` requests.", + "properties": { + "model": { + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "type": "string" }, - "mimeType": { - "readOnly": true, + "endTime": { + "description": "Output only. The time at which the batch processing completed.", "type": "string", - "description": "Output only. MIME type of the file." + "format": "google-datetime", + "readOnly": true }, - "createTime": { - "description": "Output only. The timestamp of when the `File` was created.", + "name": { + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", "readOnly": true, - "type": "string", - "format": "google-datetime" + "type": "string" }, - "source": { - "enum": [ - "SOURCE_UNSPECIFIED", - "UPLOADED", - "GENERATED", - "REGISTERED" - ], - "description": "Source of the File.", + "output": { + "description": "Output only. The output of the batch request.", + "$ref": "#/components/schemas/EmbedContentBatchOutput", + "readOnly": true + }, + "createTime": { + "description": "Output only. The time at which the batch was created.", + "type": "string", + "format": "google-datetime", + "readOnly": true + }, + "batchStats": { + "description": "Output only. Stats about the batch.", + "$ref": "#/components/schemas/EmbedContentBatchStats", + "readOnly": true + }, + "updateTime": { + "type": "string", + "format": "google-datetime", + "readOnly": true, + "description": "Output only. The time at which the batch was last updated." + }, + "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.", + "type": "string", + "format": "int64" + }, + "inputConfig": { + "description": "Required. Input configuration of the instances on which batch processing are performed.", + "$ref": "#/components/schemas/InputEmbedContentConfig" + }, + "displayName": { + "description": "Required. The user-defined name of this batch.", + "type": "string" + }, + "state": { + "description": "Output only. The state of the batch.", + "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." + ], + "type": "string", + "readOnly": true, + "enum": [ + "BATCH_STATE_UNSPECIFIED", + "BATCH_STATE_PENDING", + "BATCH_STATE_RUNNING", + "BATCH_STATE_SUCCEEDED", + "BATCH_STATE_FAILED", + "BATCH_STATE_CANCELLED", + "BATCH_STATE_EXPIRED" + ] + } + } + }, + "CitationSource": { + "description": "A citation to a source for a portion of a specific response.", + "properties": { + "endIndex": { + "description": "Optional. End of the attributed segment, exclusive.", + "type": "integer", + "format": "int32" + }, + "uri": { + "description": "Optional. URI that is attributed as a source for a portion of the text.", + "type": "string" + }, + "license": { + "type": "string", + "description": "Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations." + }, + "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.", + "type": "integer", + "format": "int32" + } + }, + "type": "object" + }, + "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": { + "functionDeclarations": { + "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." + }, + "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" + }, + "googleMaps": { + "description": "Optional. Tool that allows grounding the model's response with geospatial context related to the user's query.", + "$ref": "#/components/schemas/GoogleMaps" + }, + "fileSearch": { + "description": "Optional. FileSearch tool type. Tool to retrieve knowledge from Semantic Retrieval corpora.", + "$ref": "#/components/schemas/FileSearch" + }, + "urlContext": { + "description": "Optional. Tool to support URL context retrieval.", + "$ref": "#/components/schemas/UrlContext" + }, + "googleSearchRetrieval": { + "description": "Optional. Retrieval tool that is powered by Google search.", + "$ref": "#/components/schemas/GoogleSearchRetrieval" + }, + "codeExecution": { + "description": "Optional. Enables the model to execute code as part of generation.", + "$ref": "#/components/schemas/CodeExecution" + }, + "googleSearch": { + "description": "Optional. GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google.", + "$ref": "#/components/schemas/GoogleSearch" + }, + "mcpServers": { + "type": "array", + "items": { + "$ref": "#/components/schemas/McpServer" + }, + "description": "Optional. MCP Servers to connect to." + } + }, + "type": "object" + }, + "GenerateContentBatch": { + "type": "object", + "description": "A resource representing a batch of `GenerateContent` requests.", + "properties": { + "name": { + "readOnly": true, + "type": "string", + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`." + }, + "output": { + "description": "Output only. The output of the batch request.", + "$ref": "#/components/schemas/GenerateContentBatchOutput", + "readOnly": true + }, + "createTime": { + "readOnly": true, + "type": "string", + "format": "google-datetime", + "description": "Output only. The time at which the batch was created." + }, + "model": { + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "type": "string" + }, + "endTime": { + "description": "Output only. The time at which the batch processing completed.", + "readOnly": true, + "type": "string", + "format": "google-datetime" + }, + "updateTime": { + "description": "Output only. The time at which the batch was last updated.", + "type": "string", + "format": "google-datetime", + "readOnly": true + }, + "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." + }, + "batchStats": { + "readOnly": true, + "description": "Output only. Stats about the batch.", + "$ref": "#/components/schemas/BatchStats" + }, + "state": { + "description": "Output only. The state of the batch.", + "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" + ], + "readOnly": true, + "type": "string" + }, + "inputConfig": { + "description": "Required. Input configuration of the instances on which batch processing are performed.", + "$ref": "#/components/schemas/InputConfig" + }, + "displayName": { + "type": "string", + "description": "Required. The user-defined name of this batch." + } + } + }, + "VideoFileMetadata": { + "description": "Metadata for a video `File`.", + "properties": { + "videoDuration": { + "type": "string", + "format": "google-duration", + "description": "Duration of the video." + } + }, + "type": "object" + }, + "ListTunedModelsResponse": { + "description": "Response from `ListTunedModels` containing a paginated list of Models.", + "properties": { + "tunedModels": { + "type": "array", + "items": { + "$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" + }, + "UploadToFileSearchStoreRequest": { + "description": "Request for `UploadToFileSearchStore`.", + "properties": { + "customMetadata": { + "type": "array", + "items": { + "$ref": "#/components/schemas/CustomMetadata" + }, + "description": "Custom metadata to be associated with the data." + }, + "displayName": { + "description": "Optional. Display name of the created document.", + "type": "string" + }, + "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" + }, + "mimeType": { + "type": "string", + "description": "Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content." + } + }, + "type": "object" + }, + "GenerateContentRequest": { + "description": "Request to generate a completion from the model.", + "properties": { + "generationConfig": { + "description": "Optional. Configuration options for model generation and outputs.", + "$ref": "#/components/schemas/GenerationConfig" + }, + "model": { + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "type": "string" + }, + "systemInstruction": { + "description": "Optional. Developer set [system instruction(s)](https://ai.google.dev/gemini-api/docs/system-instructions). Currently, text only.", + "$ref": "#/components/schemas/Content" + }, + "serviceTier": { + "type": "string", + "description": "Optional. The service tier of the request.", + "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": "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": "array", + "items": { + "$ref": "#/components/schemas/Content" + } + }, + "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}`" + }, + "store": { + "description": "Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config.", + "type": "boolean" + }, + "safetySettings": { + "type": "array", + "items": { + "$ref": "#/components/schemas/SafetySetting" + }, + "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." + }, + "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.", + "$ref": "#/components/schemas/ToolConfig" + }, + "tools": { + "type": "array", + "items": { + "$ref": "#/components/schemas/Tool" + }, + "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": "object" + }, + "GroundingChunkStringList": { + "type": "object", + "description": "A list of string values.", + "properties": { + "values": { + "description": "The string values of the list.", + "type": "array", + "items": { + "type": "string" + } + } + } + }, + "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": { + "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" + } + }, + "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.", + "$ref": "#/components/schemas/GenerateContentRequest" + } + } + }, + "VoiceConfig": { + "type": "object", + "description": "The configuration for the voice to use.", + "properties": { + "prebuiltVoiceConfig": { + "description": "The configuration for the prebuilt voice to use.", + "$ref": "#/components/schemas/PrebuiltVoiceConfig" + } + } + }, + "GoogleAiGenerativelanguageV1betaSegment": { + "type": "object", + "description": "Segment of the content.", + "properties": { + "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." + }, + "partIndex": { + "description": "The index of a Part object within its parent Content object.", + "type": "integer", + "format": "int32" + }, + "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." + }, + "text": { + "type": "string", + "description": "The text corresponding to the segment from the response." + } + } + }, + "ContentEmbedding": { + "type": "object", + "description": "A list of floats representing an embedding.", + "properties": { + "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" + } + }, + "shape": { + "type": "array", + "items": { + "type": "integer", + "format": "int32" + }, + "description": "This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048])." + } + } + }, + "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": { + "description": "White space chunking configuration.", + "$ref": "#/components/schemas/WhiteSpaceConfig" + } + } + }, + "Web": { + "description": "Chunk from the web.", + "properties": { + "uri": { + "type": "string", + "readOnly": true, + "description": "Output only. URI reference of the chunk." + }, + "title": { + "readOnly": true, + "type": "string", + "description": "Output only. Title of the chunk." + } + }, + "type": "object" + }, + "Schema": { + "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).", + "properties": { + "maximum": { + "description": "Optional. Maximum value of the Type.INTEGER and Type.NUMBER", + "type": "number", + "format": "double" + }, + "type": { + "description": "Required. Data type.", "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." + "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" ], "type": "string" }, - "sizeBytes": { - "format": "int64", - "readOnly": true, + "properties": { + "description": "Optional. Properties of Type.OBJECT.", + "additionalProperties": { + "$ref": "#/components/schemas/Schema" + }, + "type": "object" + }, + "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." + }, + "format": { "type": "string", - "description": "Output only. Size of the file in bytes." + "description": "Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality." }, - "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`", + "nullable": { + "type": "boolean", + "description": "Optional. Indicates if the value may be null." + }, + "minLength": { + "type": "string", + "format": "int64", + "description": "Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING" + }, + "pattern": { + "description": "Optional. Pattern of the Type.STRING to restrict a string to a regular expression.", "type": "string" }, - "downloadUri": { - "description": "Output only. The download uri of the `File`.", - "readOnly": true, + "enum": { + "type": "array", + "items": { + "type": "string" + }, + "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\"]}" + }, + "minimum": { + "type": "number", + "format": "double", + "description": "Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER" + }, + "propertyOrdering": { + "type": "array", + "items": { + "type": "string" + }, + "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." + }, + "items": { + "description": "Optional. Schema of the elements of Type.ARRAY.", + "$ref": "#/components/schemas/Schema" + }, + "maxProperties": { + "description": "Optional. Maximum number of the properties for Type.OBJECT.", + "type": "string", + "format": "int64" + }, + "title": { + "description": "Optional. The title of the schema.", "type": "string" }, - "displayName": { + "minProperties": { "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\"" + "format": "int64", + "description": "Optional. Minimum number of the properties for Type.OBJECT." }, - "expirationTime": { - "description": "Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.", - "readOnly": true, + "example": { + "description": "Optional. Example of the object. Will only populated when the object is the root." + }, + "required": { + "description": "Optional. Required properties of Type.OBJECT.", + "type": "array", + "items": { + "type": "string" + } + }, + "maxItems": { + "description": "Optional. Maximum number of the elements for Type.ARRAY.", "type": "string", - "format": "google-datetime" + "format": "int64" }, - "updateTime": { - "description": "Output only. The timestamp of when the `File` was last updated.", - "readOnly": true, + "minItems": { "type": "string", - "format": "google-datetime" - } - }, - "description": "A file uploaded to the API. Next ID: 15" - }, - "Status": { - "type": "object", - "properties": { - "message": { + "format": "int64", + "description": "Optional. Minimum number of the elements for Type.ARRAY." + }, + "description": { "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." + "description": "Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown." }, - "code": { - "format": "int32", - "type": "integer", - "description": "The status code, which should be an enum value of google.rpc.Code." + "maxLength": { + "type": "string", + "format": "int64", + "description": "Optional. Maximum length of the Type.STRING" }, - "details": { + "anyOf": { "type": "array", - "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use.", "items": { - "type": "object", - "additionalProperties": { - "description": "Properties of the object. Contains field @type with type URL." - } - } + "$ref": "#/components/schemas/Schema" + }, + "description": "Optional. The value should be validated against any (one or more) of the subschemas in the list." } - }, - "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)." + } }, - "ComputerUse": { + "UrlMetadata": { "type": "object", + "description": "Context of the a single url retrieval.", "properties": { - "environment": { + "urlRetrievalStatus": { "type": "string", - "description": "Required. The environment being operated.", + "description": "Status of the url retrieval.", "x-enum-descriptions": [ - "Defaults to browser.", - "Operates in a web browser." + "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": [ - "ENVIRONMENT_UNSPECIFIED", - "ENVIRONMENT_BROWSER" + "URL_RETRIEVAL_STATUS_UNSPECIFIED", + "URL_RETRIEVAL_STATUS_SUCCESS", + "URL_RETRIEVAL_STATUS_ERROR", + "URL_RETRIEVAL_STATUS_PAYWALL", + "URL_RETRIEVAL_STATUS_UNSAFE" ] }, - "excludedPredefinedFunctions": { + "retrievedUrl": { + "type": "string", + "description": "Retrieved url by the tool." + } + } + }, + "ListCorporaResponse": { + "description": "Response from `ListCorpora` containing a paginated list of `Corpora`. The results are sorted by ascending `corpus.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" + }, + "corpora": { + "description": "The returned corpora.", "type": "array", - "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.", "items": { - "type": "string" + "$ref": "#/components/schemas/Corpus" } } }, - "description": "Computer Use tool type." + "type": "object" }, - "SearchTypes": { - "description": "Different types of search that can be enabled on the GoogleSearch tool.", - "type": "object", + "RetrievalMetadata": { + "description": "Metadata related to retrieval in the grounding flow.", "properties": { - "webSearch": { - "$ref": "#/components/schemas/WebSearch", - "description": "Optional. Enables web search. Only text results are returned." - }, - "imageSearch": { - "$ref": "#/components/schemas/ImageSearch", - "description": "Optional. Enables image search. Image bytes are returned." + "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.", + "type": "number", + "format": "float" } - } + }, + "type": "object" }, - "LogprobsResult": { - "description": "Logprobs Result", + "FunctionCallingConfig": { "type": "object", + "description": "Configuration for specifying function calling behavior.", "properties": { - "chosenCandidates": { - "description": "Length = total number of decoding steps. The chosen candidates may or may not be in top_candidates.", - "items": { - "$ref": "#/components/schemas/LogprobsResultCandidate" - }, - "type": "array" - }, - "logProbabilitySum": { - "description": "Sum of log probabilities for all tokens.", - "format": "float", - "type": "number" + "mode": { + "type": "string", + "description": "Optional. Specifies the mode in which function calling should execute. If unspecified, the default value will be set to AUTO.", + "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" + ] }, - "topCandidates": { + "allowedFunctionNames": { "type": "array", - "description": "Length = total number of decoding steps.", "items": { - "$ref": "#/components/schemas/TopCandidates" - } + "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." } } }, - "SpeechConfig": { - "description": "Config for speech generation and transcription.", + "GoogleAiGenerativelanguageV1betaGroundingSupport": { "type": "object", + "description": "Grounding support.", "properties": { - "voiceConfig": { - "description": "The configuration in case of single-voice output.", - "$ref": "#/components/schemas/VoiceConfig" + "segment": { + "description": "Segment of the content this support belongs to.", + "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaSegment" }, - "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" + "confidenceScores": { + "type": "array", + "items": { + "type": "number", + "format": "float" + }, + "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." }, - "multiSpeakerVoiceConfig": { - "$ref": "#/components/schemas/MultiSpeakerVoiceConfig", - "description": "Optional. The configuration for the multi-speaker setup. It is mutually exclusive with the voice_config field." + "renderedParts": { + "readOnly": true, + "type": "array", + "items": { + "type": "integer", + "format": "int32" + }, + "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." + }, + "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" + } } } }, - "RetrievalMetadata": { - "type": "object", - "properties": { - "googleSearchDynamicRetrievalScore": { - "format": "float", - "type": "number", - "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." - } - }, - "description": "Metadata related to retrieval in the grounding flow." - }, - "StreamableHttpTransport": { - "type": "object", + "Document": { + "description": "A `Document` is a collection of `Chunk`s.", "properties": { - "url": { - "description": "The full URL for the MCPServer endpoint. Example: \"https://api.example.com/mcp\"", + "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" }, - "terminateOnClose": { - "type": "boolean", - "description": "Whether to close the client session when the transport closes." + "createTime": { + "description": "Output only. The Timestamp of when the `Document` was created.", + "readOnly": true, + "type": "string", + "format": "google-datetime" }, - "headers": { - "type": "object", - "additionalProperties": { - "type": "string" + "customMetadata": { + "type": "array", + "items": { + "$ref": "#/components/schemas/CustomMetadata" }, - "description": "Optional: Fields for authentication headers, timeouts, etc., if needed." + "description": "Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`." }, - "sseReadTimeout": { - "description": "Timeout for SSE read operations.", + "state": { + "description": "Output only. Current state of the `Document`.", + "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." + ], + "enum": [ + "STATE_UNSPECIFIED", + "STATE_PENDING", + "STATE_ACTIVE", + "STATE_FAILED" + ], "type": "string", - "format": "google-duration" + "readOnly": true }, - "timeout": { + "updateTime": { + "description": "Output only. The Timestamp of when the `Document` was last updated.", "type": "string", - "format": "google-duration", - "description": "HTTP timeout for regular operations." - } - }, - "description": "A transport that can stream HTTP requests and responses. Next ID: 6" - }, - "InlinedRequest": { - "type": "object", - "properties": { - "request": { - "$ref": "#/components/schemas/GenerateContentRequest", - "description": "Required. The request to be processed in the batch." + "format": "google-datetime", + "readOnly": true }, - "metadata": { - "description": "Optional. The metadata to be associated with the request.", - "type": "object", - "additionalProperties": { - "description": "Properties of the object." - } - } - }, - "description": "The request to be processed in the batch." - }, - "VideoFileMetadata": { - "type": "object", - "properties": { - "videoDuration": { - "description": "Duration of the video.", + "sizeBytes": { "type": "string", - "format": "google-duration" + "format": "int64", + "readOnly": true, + "description": "Output only. The size of raw bytes ingested into the Document." + }, + "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\"" + }, + "mimeType": { + "type": "string", + "readOnly": true, + "description": "Output only. The mime type of the Document." } }, - "description": "Metadata for a video `File`." + "type": "object" }, - "ListFileSearchStoresResponse": { - "description": "Response from `ListFileSearchStores` containing a paginated list of `FileSearchStores`. The results are sorted by ascending `file_search_store.create_time`.", + "Image": { "type": "object", + "description": "Chunk from image search.", "properties": { - "fileSearchStores": { - "type": "array", - "description": "The returned rag_stores.", - "items": { - "$ref": "#/components/schemas/FileSearchStore" - } + "domain": { + "type": "string", + "description": "The root domain of the web page that the image is from, e.g. \"example.com\"." }, - "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" + }, + "sourceUri": { + "type": "string", + "description": "The web page URI for attribution." + }, + "imageUri": { + "type": "string", + "description": "The image asset URL." } } }, - "Schema": { - "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).", + "FunctionCall": { "type": "object", + "description": "A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values.", "properties": { - "nullable": { - "description": "Optional. Indicates if the value may be null.", - "type": "boolean" + "args": { + "type": "object", + "additionalProperties": { + "description": "Properties of the object." + }, + "description": "Optional. The function parameters and values in JSON object format." }, - "maxProperties": { - "description": "Optional. Maximum number of the properties for Type.OBJECT.", - "type": "string", - "format": "int64" + "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" }, - "maxLength": { + "name": { "type": "string", - "format": "int64", - "description": "Optional. Maximum length of the 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." + } + } + }, + "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.", + "properties": { + "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`." }, - "description": { - "description": "Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown.", + "behavior": { + "description": "Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method.", + "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" + ], "type": "string" }, - "pattern": { - "type": "string", - "description": "Optional. Pattern of the Type.STRING to restrict a string to a regular expression." + "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" }, - "propertyOrdering": { - "type": "array", - "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.", - "items": { - "type": "string" - } + "response": { + "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.", + "$ref": "#/components/schemas/Schema" }, - "required": { - "type": "array", - "description": "Optional. Required properties of Type.OBJECT.", - "items": { - "type": "string" - } + "description": { + "description": "Required. A brief description of the function.", + "type": "string" }, - "type": { - "type": "string", - "description": "Required. Data type.", - "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" - ] + "name": { + "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.", + "type": "string" }, - "maxItems": { - "type": "string", - "format": "int64", - "description": "Optional. Maximum number of the elements for Type.ARRAY." + "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`." + } + }, + "type": "object" + }, + "CustomLongRunningOperation": { + "type": "object", + "properties": { + "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.", + "additionalProperties": { + "description": "Properties of the object. Contains field @type with type URL." + }, + "type": "object" }, - "example": { - "description": "Optional. Example of the object. Will only populated when the object is the root." + "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`." }, - "minProperties": { + "name": { "type": "string", - "format": "int64", - "description": "Optional. Minimum number of the properties for Type.OBJECT." - }, - "minItems": { - "description": "Optional. Minimum number of the elements for Type.ARRAY.", - "format": "int64", - "type": "string" - }, - "minimum": { - "description": "Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER", - "format": "double", - "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}`." }, - "anyOf": { - "type": "array", - "description": "Optional. The value should be validated against any (one or more) of the subschemas in the list.", - "items": { - "$ref": "#/components/schemas/Schema" - } + "error": { + "description": "The error result of the operation in case of failure or cancellation.", + "$ref": "#/components/schemas/Status" }, - "maximum": { - "type": "number", - "format": "double", - "description": "Optional. Maximum value of the Type.INTEGER and Type.NUMBER" + "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" + } + } + }, + "Operation": { + "description": "This resource represents a long-running operation that is the result of a network API call.", + "properties": { + "done": { + "type": "boolean", + "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." }, - "format": { - "type": "string", - "description": "Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality." + "error": { + "description": "The error result of the operation in case of failure or cancellation.", + "$ref": "#/components/schemas/Status" }, - "title": { - "description": "Optional. The title of the schema.", - "type": "string" + "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`." }, - "properties": { - "description": "Optional. Properties of Type.OBJECT.", + "metadata": { "type": "object", "additionalProperties": { - "$ref": "#/components/schemas/Schema" - } + "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." }, - "items": { - "description": "Optional. Schema of the elements of Type.ARRAY.", - "$ref": "#/components/schemas/Schema" + "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}`.", + "type": "string" + } + }, + "type": "object" + }, + "Blob": { + "description": "Raw media bytes. Text should not be sent as raw bytes, use the 'text' field.", + "properties": { + "mimeType": { + "description": "The IANA standard MIME type of the source data. Examples of supported types: - Images: image/png, image/jpeg, image/jpg, image/webp, image/heic, image/heif, image/gif, image/avif - Audio: audio/*, video/audio/s16le, video/audio/wav - Video: video/* - Text: text/plain, text/html, text/css, text/javascript, text/x-typescript, text/csv, text/markdown, text/x-python, text/xml, text/rtf, video/text/timestamp - Applications: application/x-javascript, application/x-typescript, application/x-python-code, application/json, application/x-ipynb+json, application/rtf, application/pdf For additional context, see [Supported file formats](https://ai.google.dev/gemini-api/docs/file-input-methods#supported-content-types). //", + "type": "string" }, - "minLength": { + "data": { "type": "string", - "format": "int64", - "description": "Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the 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." - }, - "enum": { - "type": "array", - "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\"]}", - "items": { - "type": "string" - } + "format": "byte", + "description": "Raw bytes for media formats." } - } + }, + "type": "object" }, - "FunctionResponsePart": { - "type": "object", + "RetrievalConfig": { + "description": "Retrieval config.", "properties": { - "inlineData": { - "description": "Inline media bytes.", - "$ref": "#/components/schemas/FunctionResponseBlob" + "latLng": { + "description": "Optional. The location of the user.", + "$ref": "#/components/schemas/LatLng" + }, + "languageCode": { + "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": "string" } }, - "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." + "type": "object" }, - "ListOperationsResponse": { - "description": "The response message for Operations.ListOperations.", + "Maps": { "type": "object", + "description": "A grounding chunk from Google Maps. A Maps chunk corresponds to a single place.", "properties": { - "nextPageToken": { + "placeAnswerSources": { + "description": "Sources that provide answers about the features of a given place in Google Maps.", + "$ref": "#/components/schemas/PlaceAnswerSources" + }, + "title": { "type": "string", - "description": "The standard List next-page token." + "description": "Title of the place." }, - "operations": { - "description": "A list of operations that matches the specified filter in the request.", - "items": { - "$ref": "#/components/schemas/Operation" - }, - "type": "array" + "uri": { + "description": "URI reference of the place.", + "type": "string" }, - "unreachable": { - "type": "array", - "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.", - "items": { - "type": "string" - } + "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." + }, + "text": { + "type": "string", + "description": "Text description of the place answer." } } }, - "TuningExamples": { - "description": "A set of tuning examples. Can be training or validation data.", + "AttributionSourceId": { "type": "object", + "description": "Identifier for the source contributing to this attribution.", "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.", - "items": { - "$ref": "#/components/schemas/TuningExample" - }, - "type": "array" + "groundingPassage": { + "description": "Identifier for an inline passage.", + "$ref": "#/components/schemas/GroundingPassageId" + }, + "semanticRetrieverChunk": { + "description": "Identifier for a `Chunk` fetched via Semantic Retriever.", + "$ref": "#/components/schemas/SemanticRetrieverChunk" } } }, - "Empty": { - "type": "object", - "properties": {}, - "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); }" - }, - "GenerateContentBatch": { - "description": "A resource representing a batch of `GenerateContent` requests.", + "Candidate": { "type": "object", + "description": "A response candidate generated from the model.", "properties": { - "displayName": { - "type": "string", - "description": "Required. The user-defined name of this batch." - }, - "inputConfig": { - "description": "Required. Input configuration of the instances on which batch processing are performed.", - "$ref": "#/components/schemas/InputConfig" - }, - "endTime": { - "description": "Output only. The time at which the batch processing completed.", - "format": "google-datetime", + "avgLogprobs": { + "description": "Output only. Average log probability score of the candidate.", "readOnly": true, - "type": "string" - }, - "model": { - "type": "string", - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`." + "type": "number", + "format": "double" }, - "output": { - "$ref": "#/components/schemas/GenerateContentBatchOutput", - "description": "Output only. The output of the batch request.", + "content": { + "description": "Output only. Generated content returned from the model.", + "$ref": "#/components/schemas/Content", "readOnly": true }, - "createTime": { - "readOnly": true, - "type": "string", - "format": "google-datetime", - "description": "Output only. The time at which the batch was created." - }, - "updateTime": { + "tokenCount": { + "description": "Output only. Token count for this candidate.", "readOnly": true, - "type": "string", - "format": "google-datetime", - "description": "Output only. The time at which the batch was last updated." + "type": "integer", + "format": "int32" }, - "batchStats": { + "groundingMetadata": { "readOnly": true, - "description": "Output only. Stats about the batch.", - "$ref": "#/components/schemas/BatchStats" + "description": "Output only. Grounding metadata for the candidate. This field is populated for `GenerateContent` calls.", + "$ref": "#/components/schemas/GroundingMetadata" }, - "state": { - "description": "Output only. The state of the batch.", - "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." + "finishReason": { + "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" ], "readOnly": true, "type": "string", - "enum": [ - "BATCH_STATE_UNSPECIFIED", - "BATCH_STATE_PENDING", - "BATCH_STATE_RUNNING", - "BATCH_STATE_SUCCEEDED", - "BATCH_STATE_FAILED", - "BATCH_STATE_CANCELLED", - "BATCH_STATE_EXPIRED" + "description": "Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.", + "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." ] }, - "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" + "urlContextMetadata": { + "description": "Output only. Metadata related to url context retrieval tool.", + "$ref": "#/components/schemas/UrlContextMetadata", + "readOnly": true }, - "name": { - "readOnly": true, - "type": "string", - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`." - } - } - }, - "GroundingChunkStringList": { - "description": "A list of string values.", - "type": "object", - "properties": { - "values": { - "description": "The string values of the list.", - "items": { - "type": "string" - }, - "type": "array" - } - } - }, - "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.", - "type": "object", - "properties": { - "parts": { + "safetyRatings": { "type": "array", - "description": "Ordered `Parts` that constitute a single message. Parts may have different MIME types.", "items": { - "$ref": "#/components/schemas/Part" - } + "$ref": "#/components/schemas/SafetyRating" + }, + "description": "List of ratings for the safety of a response candidate. There is at most one rating per category." }, - "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" - } - } - }, - "InlinedEmbedContentResponses": { - "description": "The responses to the requests in the batch.", - "type": "object", - "properties": { - "inlinedResponses": { + "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", - "description": "Output only. The responses to the requests in the batch.", "items": { - "$ref": "#/components/schemas/InlinedEmbedContentResponse" + "$ref": "#/components/schemas/GroundingAttribution" } - } - } - }, - "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.", - "type": "object", - "properties": { - "language": { - "type": "string", - "enum": [ - "LANGUAGE_UNSPECIFIED", - "PYTHON" - ], - "description": "Required. Programming language of the `code`.", - "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." + "logprobsResult": { + "readOnly": true, + "description": "Output only. Log-likelihood scores for the response tokens and top tokens", + "$ref": "#/components/schemas/LogprobsResult" }, - "id": { + "index": { + "description": "Output only. Index of the candidate in the list of response candidates.", + "readOnly": true, + "type": "integer", + "format": "int32" + }, + "finishMessage": { + "readOnly": true, "type": "string", - "description": "Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`." - } - } - }, - "CreateFileResponse": { - "description": "Response for `CreateFile`.", - "type": "object", - "properties": { - "file": { - "description": "Metadata for the created file.", - "$ref": "#/components/schemas/File" + "description": "Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set." + }, + "citationMetadata": { + "readOnly": true, + "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.", + "$ref": "#/components/schemas/CitationMetadata" } } }, - "ListCorporaResponse": { + "GroundingAttribution": { "type": "object", + "description": "Attribution for a source that contributed to an answer.", "properties": { - "corpora": { - "type": "array", - "description": "The returned corpora.", - "items": { - "$ref": "#/components/schemas/Corpus" - } + "content": { + "description": "Grounding source content that makes up this attribution.", + "$ref": "#/components/schemas/Content" }, - "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." + "sourceId": { + "description": "Output only. Identifier for the source contributing to this attribution.", + "$ref": "#/components/schemas/AttributionSourceId", + "readOnly": true } - }, - "description": "Response from `ListCorpora` containing a paginated list of `Corpora`. The results are sorted by ascending `corpus.create_time`." + } }, "Dataset": { - "type": "object", + "description": "Dataset for training or validation.", "properties": { "examples": { - "$ref": "#/components/schemas/TuningExamples", - "description": "Optional. Inline examples with simple input/output text." + "description": "Optional. Inline examples with simple input/output text.", + "$ref": "#/components/schemas/TuningExamples" } }, - "description": "Dataset for training or validation." + "type": "object" }, - "Permission": { - "type": "object", + "ReviewSnippet": { + "description": "Encapsulates a snippet of a user review that answers a question about the features of a specific place in Google Maps.", "properties": { - "emailAddress": { - "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.", - "type": "string" - }, - "role": { - "description": "Required. The role granted by this permission.", - "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" - ], - "type": "string" + "googleMapsUri": { + "type": "string", + "description": "A link that corresponds to the user review on Google Maps." }, - "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, + "reviewId": { + "description": "The ID of the review snippet.", "type": "string" }, - "granteeType": { + "title": { "type": "string", - "description": "Optional. Immutable. The type of the grantee.", - "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": "Title of the review." } }, - "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" + "type": "object" }, - "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`.", - "type": "object", + "GroundingMetadata": { + "description": "Metadata returned to client when grounding is enabled.", "properties": { - "response": { - "description": "Optional. The tool response.", - "type": "object", - "additionalProperties": { - "description": "Properties of the object." + "webSearchQueries": { + "description": "Web search queries for the following-up web search.", + "type": "array", + "items": { + "type": "string" } }, - "toolType": { - "description": "Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`.", - "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" - ], - "type": "string" - }, - "id": { - "type": "string", - "description": "Optional. The identifier of the tool call this response is for." - } - } - }, - "EmbedContentBatchOutput": { - "type": "object", - "properties": { - "responsesFile": { - "readOnly": true, + "googleMapsWidgetContextToken": { "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": "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." }, - "inlinedResponses": { - "$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.", - "readOnly": true + "searchEntryPoint": { + "description": "Optional. Google search entry for the following-up web searches.", + "$ref": "#/components/schemas/SearchEntryPoint" + }, + "imageSearchQueries": { + "description": "Image search queries used for grounding.", + "type": "array", + "items": { + "type": "string" + } + }, + "groundingSupports": { + "type": "array", + "items": { + "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaGroundingSupport" + }, + "description": "List of grounding support." + }, + "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." + }, + "retrievalMetadata": { + "description": "Metadata related to retrieval in the grounding flow.", + "$ref": "#/components/schemas/RetrievalMetadata" } }, - "description": "The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field." + "type": "object" }, - "BatchEmbedContentsRequest": { - "description": "Batch request to get embeddings from the model for a list of prompts.", - "type": "object", + "InlinedResponses": { + "description": "The responses to the requests in the batch.", "properties": { - "requests": { - "description": "Required. Embed requests for the batch. The model in each of these requests must match the model specified `BatchEmbedContentsRequest.model`.", + "inlinedResponses": { + "type": "array", "items": { - "$ref": "#/components/schemas/EmbedContentRequest" + "$ref": "#/components/schemas/InlinedResponse" }, - "type": "array" + "readOnly": true, + "description": "Output only. The responses to the requests in the batch." } - } + }, + "type": "object" }, - "GeneratedFile": { - "description": "A file generated on behalf of a user.", - "type": "object", + "TransferOwnershipRequest": { + "description": "Request to transfer the ownership of the tuned model.", "properties": { - "error": { - "description": "Error details if the GeneratedFile ends up in the STATE_FAILED state.", - "$ref": "#/components/schemas/Status" - }, - "name": { - "description": "Identifier. The name of the generated file. Example: `generatedFiles/abc-123`", + "emailAddress": { + "description": "Required. The email address of the user to whom the tuned model is being transferred to.", "type": "string" - }, - "state": { - "description": "Output only. The state of the GeneratedFile.", - "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." - ], - "readOnly": true, - "type": "string", - "enum": [ - "STATE_UNSPECIFIED", - "GENERATING", - "GENERATED", - "FAILED" - ] - }, - "mimeType": { - "type": "string", - "description": "MIME type of the generatedFile." } - } + }, + "type": "object" }, - "PrebuiltVoiceConfig": { - "description": "The configuration for the prebuilt speaker to use.", - "type": "object", + "InlinedEmbedContentRequest": { + "description": "The request to be processed in the batch.", "properties": { - "voiceName": { - "description": "The name of the preset voice to use.", - "type": "string" + "metadata": { + "type": "object", + "additionalProperties": { + "description": "Properties of the object." + }, + "description": "Optional. The metadata to be associated with the request." + }, + "request": { + "description": "Required. The request to be processed in the batch.", + "$ref": "#/components/schemas/EmbedContentRequest" } - } + }, + "type": "object" }, - "TuningExample": { + "VideoMetadata": { "type": "object", + "deprecated": true, + "description": "Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content.", "properties": { - "textInput": { + "endOffset": { "type": "string", - "description": "Optional. Text model input." + "format": "google-duration", + "description": "Optional. The end offset of the video." }, - "output": { - "description": "Required. The expected model output.", - "type": "string" + "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].", + "type": "number", + "format": "double" + }, + "startOffset": { + "description": "Optional. The start offset of the video.", + "type": "string", + "format": "google-duration" } - }, - "description": "A single example for tuning." + } }, - "UrlContextMetadata": { - "description": "Metadata related to url context retrieval tool.", + "InlinedRequest": { "type": "object", + "description": "The request to be processed in the batch.", "properties": { - "urlMetadata": { - "description": "List of url context.", - "items": { - "$ref": "#/components/schemas/UrlMetadata" + "metadata": { + "description": "Optional. The metadata to be associated with the request.", + "additionalProperties": { + "description": "Properties of the object." }, - "type": "array" + "type": "object" + }, + "request": { + "description": "Required. The request to be processed in the batch.", + "$ref": "#/components/schemas/GenerateContentRequest" } } }, "ToolConfig": { - "type": "object", + "description": "The Tool configuration containing parameters for specifying `Tool` use in the request.", "properties": { "retrievalConfig": { - "$ref": "#/components/schemas/RetrievalConfig", - "description": "Optional. Retrieval config." + "description": "Optional. Retrieval config.", + "$ref": "#/components/schemas/RetrievalConfig" }, "functionCallingConfig": { "description": "Optional. Function calling config.", @@ -3554,1877 +4040,1662 @@ "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." } }, - "description": "The Tool configuration containing parameters for specifying `Tool` use in the request." - }, - "GoogleMaps": { - "description": "The GoogleMaps Tool that provides geospatial context for the user's query.", - "type": "object", - "properties": { - "enableWidget": { - "type": "boolean", - "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": "object" }, - "RegisterFilesResponse": { + "BatchEmbedContentsRequest": { "type": "object", + "description": "Batch request to get embeddings from the model for a list of prompts.", "properties": { - "files": { - "description": "The registered files to be used when calling GenerateContent.", + "requests": { + "description": "Required. Embed requests for the batch. The model in each of these requests must match the model specified `BatchEmbedContentsRequest.model`.", + "type": "array", "items": { - "$ref": "#/components/schemas/File" - }, - "type": "array" + "$ref": "#/components/schemas/EmbedContentRequest" + } } - }, - "description": "Response for `RegisterFiles`." + } }, - "EmbedContentResponse": { - "type": "object", + "GenerateContentResponse": { + "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`.", "properties": { - "embedding": { - "$ref": "#/components/schemas/ContentEmbedding", - "description": "Output only. The embedding generated from the input content.", + "usageMetadata": { + "description": "Output only. Metadata on the generation requests' token usage.", + "$ref": "#/components/schemas/UsageMetadata", "readOnly": true }, - "usageMetadata": { - "description": "Output only. The usage metadata for the request.", - "$ref": "#/components/schemas/EmbeddingUsageMetadata", + "responseId": { + "readOnly": true, + "type": "string", + "description": "Output only. response_id is used to identify each response." + }, + "modelStatus": { + "description": "Output only. The current model status of this model.", + "$ref": "#/components/schemas/ModelStatus", + "readOnly": true + }, + "modelVersion": { + "description": "Output only. The model version used to generate the response.", + "type": "string", "readOnly": true + }, + "candidates": { + "type": "array", + "items": { + "$ref": "#/components/schemas/Candidate" + }, + "description": "Candidate responses from the model." + }, + "promptFeedback": { + "description": "Returns the prompt's feedback related to the content filters.", + "$ref": "#/components/schemas/PromptFeedback" } }, - "description": "The response to an `EmbedContentRequest`." - }, - "TransferOwnershipResponse": { - "description": "Response from `TransferOwnership`.", - "type": "object", - "properties": {} - }, - "AsyncBatchEmbedContentRequest": { - "description": "Request for an `AsyncBatchEmbedContent` operation.", - "type": "object", - "properties": { - "batch": { - "description": "Required. The batch to create.", - "$ref": "#/components/schemas/EmbedContentBatch" - } - } + "type": "object" }, - "GroundingPassageId": { - "description": "Identifier for a part within a `GroundingPassage`.", - "type": "object", + "FileSearchStore": { + "description": "A `FileSearchStore` is a collection of `Document`s.", "properties": { - "passageId": { - "description": "Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`.", + "name": { + "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.", "readOnly": true, "type": "string" }, - "partIndex": { - "format": "int32", + "createTime": { + "type": "string", + "format": "google-datetime", "readOnly": true, - "type": "integer", - "description": "Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`." - } - } - }, - "TransferOwnershipRequest": { - "description": "Request to transfer the ownership of the tuned model.", - "type": "object", - "properties": { - "emailAddress": { + "description": "Output only. The Timestamp of when the `FileSearchStore` was created." + }, + "pendingDocumentsCount": { + "type": "string", + "format": "int64", + "readOnly": true, + "description": "Output only. The number of documents in the `FileSearchStore` that are being processed." + }, + "updateTime": { + "description": "Output only. The Timestamp of when the `FileSearchStore` was last updated.", + "readOnly": true, + "type": "string", + "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" + }, + "failedDocumentsCount": { + "description": "Output only. The number of documents in the `FileSearchStore` that have failed processing.", + "readOnly": true, + "type": "string", + "format": "int64" + }, + "activeDocumentsCount": { + "type": "string", + "format": "int64", + "readOnly": true, + "description": "Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval." + }, + "embeddingModel": { + "type": "string", + "description": "Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used." + }, + "displayName": { "type": "string", - "description": "Required. The email address of the user to whom the tuned model is being transferred to." + "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": "object" }, - "ListCachedContentsResponse": { - "description": "Response with CachedContents list.", - "type": "object", + "SemanticRetrieverChunk": { + "description": "Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`.", "properties": { - "cachedContents": { - "type": "array", - "description": "List of cached contents.", - "items": { - "$ref": "#/components/schemas/CachedContent" - } + "source": { + "type": "string", + "readOnly": true, + "description": "Output only. Name of the source matching the request's `SemanticRetrieverConfig.source`. Example: `corpora/123` or `corpora/123/documents/abc`" }, - "nextPageToken": { + "chunk": { + "readOnly": true, "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." + "description": "Output only. Name of the `Chunk` containing the attributed text. Example: `corpora/123/documents/abc/chunks/xyz`" } - } + }, + "type": "object" }, - "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.", - "type": "object", + "File": { + "description": "A file uploaded to the API. Next ID: 15", "properties": { - "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`." - }, - "codeExecutionResult": { - "$ref": "#/components/schemas/CodeExecutionResult", - "description": "Result of executing the `ExecutableCode`." - }, - "toolCall": { - "$ref": "#/components/schemas/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." + "expirationTime": { + "readOnly": true, + "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." }, - "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" + "updateTime": { + "type": "string", + "format": "google-datetime", + "readOnly": true, + "description": "Output only. The timestamp of when the `File` was last updated." }, - "inlineData": { - "$ref": "#/components/schemas/Blob", - "description": "Inline media bytes." + "source": { + "description": "Source of the File.", + "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" + ], + "type": "string" }, - "executableCode": { - "$ref": "#/components/schemas/ExecutableCode", - "description": "Code generated by the model that is meant to be executed." + "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" }, - "text": { + "mimeType": { + "description": "Output only. MIME type of the file.", "type": "string", - "description": "Inline text." - }, - "fileData": { - "$ref": "#/components/schemas/FileData", - "description": "URI based data." - }, - "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." - } + "readOnly": true }, - "thought": { - "description": "Optional. Indicates if the part is thought from the model.", - "type": "boolean" + "sizeBytes": { + "description": "Output only. Size of the file in bytes.", + "type": "string", + "format": "int64", + "readOnly": true }, - "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" + "sha256Hash": { + "description": "Output only. SHA-256 hash of the uploaded bytes.", + "type": "string", + "format": "byte", + "readOnly": true }, - "functionResponse": { - "$ref": "#/components/schemas/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." + "videoMetadata": { + "readOnly": true, + "description": "Output only. Metadata for a video.", + "$ref": "#/components/schemas/VideoFileMetadata" }, - "mediaResolution": { - "$ref": "#/components/schemas/MediaResolution", - "description": "Optional. Media resolution for the input media." + "error": { + "description": "Output only. Error status if File processing failed.", + "$ref": "#/components/schemas/Status", + "readOnly": true }, - "thoughtSignature": { + "uri": { + "description": "Output only. The uri of the `File`.", "type": "string", - "format": "byte", - "description": "Optional. An opaque signature for the thought so it can be reused in subsequent requests." - } - } - }, - "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.", - "type": "object", - "properties": {} - }, - "GroundingChunkCustomMetadata": { - "description": "User provided metadata about the GroundingFact.", - "type": "object", - "properties": { - "stringValue": { + "readOnly": true + }, + "downloadUri": { + "readOnly": true, "type": "string", - "description": "Optional. The string value of the metadata." + "description": "Output only. The download uri of the `File`." }, - "stringListValue": { - "$ref": "#/components/schemas/GroundingChunkStringList", - "description": "Optional. A list of string values for the metadata." + "createTime": { + "description": "Output only. The timestamp of when the `File` was created.", + "type": "string", + "format": "google-datetime", + "readOnly": true }, - "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." + "state": { + "description": "Output only. Processing state of the File.", + "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", + "PROCESSING", + "ACTIVE", + "FAILED" + ], + "readOnly": true, + "type": "string" }, - "key": { + "displayName": { "type": "string", - "description": "The key of the metadata." - } - } - }, - "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.", - "type": "object", - "properties": { - "latitude": { - "format": "double", - "type": "number", - "description": "The latitude in degrees. It must be in the range [-90.0, +90.0]." - }, - "longitude": { - "description": "The longitude in degrees. It must be in the range [-180.0, +180.0].", - "format": "double", - "type": "number" + "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": "object" }, - "ListDocumentsResponse": { - "type": "object", + "BatchEmbedContentsResponse": { + "description": "The response to a `BatchEmbedContentsRequest`.", "properties": { - "documents": { + "embeddings": { + "description": "Output only. The embeddings for each request, in the same order as provided in the batch request.", + "readOnly": true, "type": "array", - "description": "The returned `Document`s.", "items": { - "$ref": "#/components/schemas/Document" + "$ref": "#/components/schemas/ContentEmbedding" } }, - "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" + "usageMetadata": { + "description": "Output only. The usage metadata for the request.", + "$ref": "#/components/schemas/EmbeddingUsageMetadata", + "readOnly": true } }, - "description": "Response from `ListDocuments` containing a paginated list of `Document`s. The `Document`s are sorted by ascending `document.create_time`." + "type": "object" }, - "Web": { + "UrlContext": { "type": "object", + "description": "Tool to support URL context retrieval.", + "properties": {} + }, + "TuningSnapshot": { + "description": "Record for a single tuning step.", "properties": { - "uri": { - "description": "Output only. URI reference of the chunk.", + "step": { "readOnly": true, - "type": "string" + "type": "integer", + "format": "int32", + "description": "Output only. The tuning step." }, - "title": { + "epoch": { + "type": "integer", + "format": "int32", "readOnly": true, - "type": "string", - "description": "Output only. Title of the chunk." - } - }, - "description": "Chunk from the web." - }, - "FunctionResponseBlob": { - "type": "object", - "properties": { - "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" + "description": "Output only. The epoch this step was part of." }, - "data": { - "description": "Raw bytes for media formats.", + "meanLoss": { + "description": "Output only. The mean loss of the training examples for this step.", + "type": "number", + "format": "float", + "readOnly": true + }, + "computeTime": { "type": "string", - "format": "byte" + "format": "google-datetime", + "readOnly": true, + "description": "Output only. The timestamp when this metric was computed." } }, - "description": "Raw media bytes for function response. Text should not be sent as raw bytes, use the 'FunctionResponse.response' field." + "type": "object" }, - "McpServer": { - "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: 6", - "type": "object", - "properties": { - "streamableHttpTransport": { - "description": "A transport that can stream HTTP requests and responses.", - "$ref": "#/components/schemas/StreamableHttpTransport" - }, - "name": { - "type": "string", - "description": "The name of the MCPServer." - } - } + "WebSearch": { + "description": "Standard web search for grounding and related configurations.", + "properties": {}, + "type": "object" }, - "LogprobsResultCandidate": { - "description": "Candidate for the logprobs token and score.", + "TuningExample": { "type": "object", + "description": "A single example for tuning.", "properties": { - "tokenId": { - "description": "The candidate\u2019s token id value.", - "type": "integer", - "format": "int32" - }, - "token": { - "description": "The candidate\u2019s token string value.", + "textInput": { + "description": "Optional. Text model input.", "type": "string" }, - "logProbability": { - "format": "float", - "type": "number", - "description": "The candidate's log probability." - } - } - }, - "ImageConfig": { - "description": "Config for image generation features.", - "type": "object", - "properties": { - "imageSize": { - "type": "string", - "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`." - }, - "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.", + "output": { + "description": "Required. The expected model output.", "type": "string" } } }, - "ListFilesResponse": { - "description": "Response for `ListFiles`.", - "type": "object", + "FileSearch": { + "description": "The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API.", "properties": { - "files": { - "description": "The list of `File`s.", + "fileSearchStoreNames": { + "description": "Required. The names of the file_search_stores to retrieve from. Example: `fileSearchStores/my-file-search-store-123`", + "type": "array", "items": { - "$ref": "#/components/schemas/File" - }, - "type": "array" - }, - "nextPageToken": { - "type": "string", - "description": "A token that can be sent as a `page_token` into a subsequent `ListFiles` call." - } - } - }, - "FileSearchStore": { - "description": "A `FileSearchStore` is a collection of `Document`s.", - "type": "object", - "properties": { - "createTime": { - "format": "google-datetime", - "readOnly": true, - "type": "string", - "description": "Output only. The Timestamp of when the `FileSearchStore` was created." - }, - "updateTime": { - "description": "Output only. The Timestamp of when the `FileSearchStore` was last updated.", - "readOnly": true, - "type": "string", - "format": "google-datetime" - }, - "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" - }, - "embeddingModel": { - "type": "string", - "description": "Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used." + "type": "string" + } }, - "name": { - "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." + "topK": { + "type": "integer", + "format": "int32", + "description": "Optional. The number of semantic retrieval chunks to retrieve." }, - "activeDocumentsCount": { - "description": "Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.", + "metadataFilter": { + "type": "string", + "description": "Optional. Metadata filter to apply to the semantic retrieval documents and chunks." + } + }, + "type": "object" + }, + "EmbedContentBatchStats": { + "description": "Stats about the batch.", + "properties": { + "requestCount": { + "description": "Output only. The number of requests in the batch.", "readOnly": true, "type": "string", "format": "int64" }, - "pendingDocumentsCount": { - "readOnly": true, + "successfulRequestCount": { "type": "string", "format": "int64", - "description": "Output only. The number of documents in the `FileSearchStore` that are being processed." + "readOnly": true, + "description": "Output only. The number of requests that were successfully processed." }, - "failedDocumentsCount": { - "description": "Output only. The number of documents in the `FileSearchStore` that have failed processing.", - "format": "int64", + "failedRequestCount": { + "description": "Output only. The number of requests that failed to be processed.", "readOnly": true, - "type": "string" + "type": "string", + "format": "int64" }, - "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`.", + "pendingRequestCount": { + "description": "Output only. The number of requests that are still pending processing.", "readOnly": true, "type": "string", "format": "int64" } - } + }, + "type": "object" }, - "CitationMetadata": { + "SpeechConfig": { "type": "object", + "description": "Config for speech generation and transcription.", "properties": { - "citationSources": { + "voiceConfig": { + "description": "The configuration in case of single-voice output.", + "$ref": "#/components/schemas/VoiceConfig" + }, + "languageCode": { + "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`." + }, + "multiSpeakerVoiceConfig": { + "description": "Optional. The configuration for the multi-speaker setup. It is mutually exclusive with the voice_config field.", + "$ref": "#/components/schemas/MultiSpeakerVoiceConfig" + } + } + }, + "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.", + "properties": { + "reviewSnippets": { "type": "array", - "description": "Citations to sources for a specific response.", "items": { - "$ref": "#/components/schemas/CitationSource" - } + "$ref": "#/components/schemas/ReviewSnippet" + }, + "description": "Snippets of reviews that are used to generate answers about the features of a given place in Google Maps." } }, - "description": "A collection of source attributions for a piece of content." + "type": "object" }, - "GenerationConfig": { - "type": "object", + "CountTokensResponse": { + "description": "A response from `CountTokens`. It returns the model's `token_count` for the `prompt`.", "properties": { - "responseMimeType": { - "type": "string", - "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." - }, - "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" - }, - "candidateCount": { - "type": "integer", - "format": "int32", - "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)" - }, - "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." - }, - "seed": { - "format": "int32", + "totalTokens": { + "description": "The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative.", "type": "integer", - "description": "Optional. Seed used in decoding. If not set, the request uses a randomly generated seed." - }, - "responseJsonSchema": { - "description": "Optional. An internal detail. Use `responseJsonSchema` rather than this field." - }, - "mediaResolution": { - "type": "string", - "enum": [ - "MEDIA_RESOLUTION_UNSPECIFIED", - "MEDIA_RESOLUTION_LOW", - "MEDIA_RESOLUTION_MEDIUM", - "MEDIA_RESOLUTION_HIGH" - ], - "description": "Optional. If specified, the media resolution specified will be used.", - "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)." - ] - }, - "responseLogprobs": { - "type": "boolean", - "description": "Optional. If true, export the logprobs results in response." + "format": "int32" }, - "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.", + "promptTokensDetails": { + "type": "array", "items": { - "type": "string" + "$ref": "#/components/schemas/ModalityTokenCount" }, - "type": "array" - }, - "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." - }, - "enableEnhancedCivicAnswers": { - "description": "Optional. Enables enhanced civic answers. It may not be available for all models.", - "type": "boolean" - }, - "presencePenalty": { - "format": "float", - "type": "number", - "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." + "readOnly": true, + "description": "Output only. List of modalities that were processed in the request input." }, - "responseModalities": { + "cacheTokensDetails": { + "description": "Output only. List of modalities that were processed in the cached content.", + "readOnly": true, "type": "array", - "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.", "items": { - "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" - ], - "type": "string" + "$ref": "#/components/schemas/ModalityTokenCount" } }, - "topK": { - "format": "int32", - "type": "integer", - "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." - }, - "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." - }, - "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." - }, - "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" - }, - "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.", - "format": "float", - "type": "number" - }, - "logprobs": { - "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].", + "cachedContentTokenCount": { "type": "integer", - "format": "int32" + "format": "int32", + "description": "Number of tokens in the cached part of the prompt (the cached content)." } }, - "description": "Configuration options for model generation and outputs. Not all parameters are configurable for every model." - }, - "ListModelsResponse": { - "description": "Response from `ListModel` containing a paginated list of Models.", - "type": "object", - "properties": { - "models": { - "type": "array", - "description": "The returned Models.", - "items": { - "$ref": "#/components/schemas/Model" - } - }, - "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" }, - "CustomLongRunningOperation": { + "GeneratedFile": { "type": "object", + "description": "A file generated on behalf of a user.", "properties": { - "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." - } - }, - "error": { - "description": "The error result of the operation in case of failure or cancellation.", - "$ref": "#/components/schemas/Status" - }, "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}`." - }, - "done": { - "type": "boolean", - "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." + "description": "Identifier. The name of the generated file. Example: `generatedFiles/abc-123`" }, - "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." - } - } - } - }, - "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`.", - "type": "object", - "properties": { - "toolType": { - "type": "string", + "state": { "enum": [ - "TOOL_TYPE_UNSPECIFIED", - "GOOGLE_SEARCH_WEB", - "GOOGLE_SEARCH_IMAGE", - "URL_CONTEXT", - "GOOGLE_MAPS", - "FILE_SEARCH" + "STATE_UNSPECIFIED", + "GENERATING", + "GENERATED", + "FAILED" ], - "description": "Required. The type of tool that was called.", + "type": "string", + "readOnly": true, + "description": "Output only. The state of the GeneratedFile.", "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." + "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." ] }, - "args": { - "description": "Optional. The tool call arguments. Example: {\"arg1\" : \"value1\", \"arg2\" : \"value2\" , ...}", - "type": "object", - "additionalProperties": { - "description": "Properties of the object." - } + "error": { + "description": "Error details if the GeneratedFile ends up in the STATE_FAILED state.", + "$ref": "#/components/schemas/Status" }, - "id": { - "description": "Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`.", + "mimeType": { + "description": "MIME type of the generatedFile.", "type": "string" } } }, - "BatchGenerateContentRequest": { - "description": "Request for a `BatchGenerateContent` operation.", - "type": "object", - "properties": { - "batch": { - "$ref": "#/components/schemas/GenerateContentBatch", - "description": "Required. The batch to create." - } - } - }, - "GoogleAiGenerativelanguageV1betaGroundingSupport": { - "description": "Grounding support.", + "ImportFileRequest": { "type": "object", + "description": "Request for `ImportFile` to import a File API file with a `FileSearchStore`.", "properties": { - "segment": { - "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaSegment", - "description": "Segment of the content this support belongs to." + "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" }, - "confidenceScores": { + "customMetadata": { "type": "array", - "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.", - "items": { - "type": "number", - "format": "float" - } - }, - "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.", "items": { - "format": "int32", - "type": "integer" + "$ref": "#/components/schemas/CustomMetadata" }, - "readOnly": true, - "type": "array" + "description": "Custom metadata to be associated with the file." }, - "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).", - "items": { - "format": "int32", - "type": "integer" - }, - "type": "array" + "fileName": { + "type": "string", + "description": "Required. The name of the `File` to import. Example: `files/abc-123`" } } }, - "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.", + "RetrievedContext": { "type": "object", + "description": "Chunk from context retrieved by the file search tool.", "properties": { - "web": { - "$ref": "#/components/schemas/Web", - "description": "Grounding chunk from the web." + "title": { + "type": "string", + "description": "Optional. Title of the document." }, - "retrievedContext": { - "$ref": "#/components/schemas/RetrievedContext", - "description": "Optional. Grounding chunk from context retrieved by the file search tool." + "pageNumber": { + "type": "integer", + "format": "int32", + "description": "Optional. Page number of the retrieved context, if applicable." }, - "image": { - "$ref": "#/components/schemas/Image", - "description": "Optional. Grounding chunk from image search." + "uri": { + "description": "Optional. URI reference of the semantic retrieval document.", + "type": "string" }, - "maps": { - "$ref": "#/components/schemas/Maps", - "description": "Optional. Grounding chunk from Google Maps." - } - } - }, - "AttributionSourceId": { - "description": "Identifier for the source contributing to this attribution.", - "type": "object", - "properties": { - "groundingPassage": { - "$ref": "#/components/schemas/GroundingPassageId", - "description": "Identifier for an inline passage." + "fileSearchStore": { + "type": "string", + "description": "Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123`" }, - "semanticRetrieverChunk": { - "$ref": "#/components/schemas/SemanticRetrieverChunk", - "description": "Identifier for a `Chunk` fetched via Semantic Retriever." + "text": { + "description": "Optional. Text of the chunk.", + "type": "string" + }, + "mediaId": { + "description": "Optional. The media blob resource name for multimodal file search results. Format: fileSearchStores/{file_search_store_id}/media/{blob_id}", + "type": "string" + }, + "customMetadata": { + "description": "Optional. User-provided metadata about the retrieved context.", + "type": "array", + "items": { + "$ref": "#/components/schemas/GroundingChunkCustomMetadata" + } } } }, - "VideoMetadata": { - "deprecated": true, + "CustomMetadata": { "type": "object", + "description": "User provided metadata stored as key-value pairs.", "properties": { - "startOffset": { - "format": "google-duration", + "stringListValue": { + "description": "The StringList value of the metadata to store.", + "$ref": "#/components/schemas/StringList" + }, + "key": { "type": "string", - "description": "Optional. The start offset of the video." + "description": "Required. The key of the metadata to store." }, - "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" + "stringValue": { + "type": "string", + "description": "The string value of the metadata to store." }, - "endOffset": { - "description": "Optional. The end offset of the video.", - "format": "google-duration", - "type": "string" + "numericValue": { + "description": "The numeric value of the metadata to store.", + "type": "number", + "format": "float" } - }, - "description": "Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content." + } }, - "ModalityTokenCount": { - "description": "Represents token counting info for a single modality.", + "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.", "properties": { - "modality": { - "type": "string", - "description": "The modality associated with this token count.", - "x-enum-descriptions": [ - "Unspecified modality.", - "Plain text.", - "Image.", - "Video.", - "Audio.", - "Document, e.g. PDF." - ], - "enum": [ - "MODALITY_UNSPECIFIED", - "TEXT", - "IMAGE", - "VIDEO", - "AUDIO", - "DOCUMENT" - ] - }, - "tokenCount": { - "type": "integer", - "format": "int32", - "description": "Number of tokens." + "inlineData": { + "description": "Inline media bytes.", + "$ref": "#/components/schemas/FunctionResponseBlob" } } }, - "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.", + "CodeExecution": { + "type": "object", + "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": {} + }, + "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": { - "response": { - "type": "object", - "additionalProperties": { - "description": "Properties of the object." - }, - "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." - }, - "id": { - "description": "Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`.", - "type": "string" - }, - "parts": { - "type": "array", - "description": "Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types.", - "items": { - "$ref": "#/components/schemas/FunctionResponsePart" - } - }, - "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." - }, - "willContinue": { - "type": "boolean", - "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`." - }, - "scheduling": { - "type": "string", + "category": { "enum": [ - "SCHEDULING_UNSPECIFIED", - "SILENT", - "WHEN_IDLE", - "INTERRUPT" + "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": "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", + "enumDeprecated": [ + false, + false, + false, + false, + false, + false, + false, + false, + false, + false, + false, + true + ], + "description": "Required. The category for this setting.", "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." + "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." ] + }, + "threshold": { + "description": "Required. Controls the probability threshold at which harm is blocked.", + "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" + ], + "type": "string" } } }, - "InlinedEmbedContentRequests": { - "description": "The requests to be processed in the batch if provided as part of the batch creation request.", - "type": "object", + "ListFileSearchStoresResponse": { + "description": "Response from `ListFileSearchStores` containing a paginated list of `FileSearchStores`. The results are sorted by ascending `file_search_store.create_time`.", "properties": { - "requests": { + "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." + }, + "fileSearchStores": { "type": "array", - "description": "Required. The requests to be processed in the batch.", "items": { - "$ref": "#/components/schemas/InlinedEmbedContentRequest" - } + "$ref": "#/components/schemas/FileSearchStore" + }, + "description": "The returned rag_stores." } - } - }, - "WebSearch": { - "type": "object", - "properties": {}, - "description": "Standard web search for grounding and related configurations." + }, + "type": "object" }, - "CustomMetadata": { - "description": "User provided metadata stored as key-value pairs.", + "StreamableHttpTransport": { "type": "object", + "description": "A transport that can stream HTTP requests and responses. Next ID: 6", "properties": { - "stringListValue": { - "description": "The StringList value of the metadata to store.", - "$ref": "#/components/schemas/StringList" + "timeout": { + "description": "HTTP timeout for regular operations.", + "type": "string", + "format": "google-duration" }, - "numericValue": { - "description": "The numeric value of the metadata to store.", - "type": "number", - "format": "float" + "sseReadTimeout": { + "type": "string", + "format": "google-duration", + "description": "Timeout for SSE read operations." }, - "stringValue": { - "description": "The string value of the metadata to store.", + "headers": { + "type": "object", + "description": "Optional: Fields for authentication headers, timeouts, etc., if needed.", + "additionalProperties": { + "type": "string" + } + }, + "url": { + "description": "The full URL for the MCPServer endpoint. Example: \"https://api.example.com/mcp\"", "type": "string" }, - "key": { - "type": "string", - "description": "Required. The key of the metadata to store." + "terminateOnClose": { + "description": "Whether to close the client session when the transport closes.", + "type": "boolean" } } }, - "Maps": { - "description": "A grounding chunk from Google Maps. A Maps chunk corresponds to a single place.", - "type": "object", + "ImageSearch": { + "description": "Image search for grounding and related configurations.", + "properties": {}, + "type": "object" + }, + "PromptFeedback": { + "description": "A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`.", "properties": { - "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" - }, - "uri": { + "blockReason": { "type": "string", - "description": "URI reference of the place." + "description": "Optional. If set, the prompt was blocked and no candidates are returned. Rephrase the prompt.", + "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" + ] }, - "text": { - "description": "Text description of the place answer.", - "type": "string" + "safetyRatings": { + "type": "array", + "items": { + "$ref": "#/components/schemas/SafetyRating" + }, + "description": "Ratings for safety of the prompt. There is at most one rating per category." + } + }, + "type": "object" + }, + "InputConfig": { + "description": "Configures the input to the batch request.", + "properties": { + "requests": { + "description": "The requests to be processed in the batch.", + "$ref": "#/components/schemas/InlinedRequests" }, - "title": { + "fileName": { "type": "string", - "description": "Title of the place." - }, - "placeAnswerSources": { - "description": "Sources that provide answers about the features of a given place in Google Maps.", - "$ref": "#/components/schemas/PlaceAnswerSources" + "description": "The name of the `File` containing the input requests." } - } + }, + "type": "object" }, - "EmbedContentBatch": { + "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.", "properties": { - "output": { - "$ref": "#/components/schemas/EmbedContentBatchOutput", - "description": "Output only. The output of the batch request.", - "readOnly": true - }, - "updateTime": { - "description": "Output only. The time at which the batch was last updated.", - "readOnly": true, - "type": "string", - "format": "google-datetime" - }, - "createTime": { - "description": "Output only. The time at which the batch was created.", - "readOnly": true, + "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.", "type": "string", "format": "google-datetime" }, - "displayName": { + "endTime": { "type": "string", - "description": "Required. The user-defined name of this batch." + "format": "google-datetime", + "description": "Optional. Exclusive end of the interval. If specified, a Timestamp matching this interval will have to be before the end." + } + } + }, + "GenerationConfig": { + "description": "Configuration options for model generation and outputs. Not all parameters are configurable for every model.", + "properties": { + "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." }, - "inputConfig": { - "$ref": "#/components/schemas/InputEmbedContentConfig", - "description": "Required. Input configuration of the instances on which batch processing are performed." + "stopSequences": { + "type": "array", + "items": { + "type": "string" + }, + "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." }, - "endTime": { - "description": "Output only. The time at which the batch processing completed.", - "format": "google-datetime", - "readOnly": true, - "type": "string" + "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" }, - "model": { - "type": "string", - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`." + "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" }, - "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." + "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" }, - "name": { - "readOnly": true, - "type": "string", - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`." + "speechConfig": { + "description": "Optional. The speech generation config.", + "$ref": "#/components/schemas/SpeechConfig" }, - "batchStats": { - "readOnly": true, - "$ref": "#/components/schemas/EmbedContentBatchStats", - "description": "Output only. Stats about the batch." + "thinkingConfig": { + "description": "Optional. Config for thinking features. An error will be returned if this field is set for models that don't support thinking.", + "$ref": "#/components/schemas/ThinkingConfig" }, - "state": { - "description": "Output only. The state of the batch.", - "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." - ], - "readOnly": true, + "responseMimeType": { "type": "string", - "enum": [ - "BATCH_STATE_UNSPECIFIED", - "BATCH_STATE_PENDING", - "BATCH_STATE_RUNNING", - "BATCH_STATE_SUCCEEDED", - "BATCH_STATE_FAILED", - "BATCH_STATE_CANCELLED", - "BATCH_STATE_EXPIRED" - ] - } - }, - "description": "A resource representing a batch of `EmbedContent` requests." - }, - "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", - "type": "object", - "properties": { - "googleSearchRetrieval": { - "$ref": "#/components/schemas/GoogleSearchRetrieval", - "description": "Optional. Retrieval tool that is powered by Google search." + "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." }, - "googleMaps": { - "$ref": "#/components/schemas/GoogleMaps", - "description": "Optional. Tool that allows grounding the model's response with geospatial context related to the user's query." + "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." }, - "googleSearch": { - "description": "Optional. GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google.", - "$ref": "#/components/schemas/GoogleSearch" + "responseJsonSchema": { + "description": "Optional. An internal detail. Use `responseJsonSchema` rather than this field." }, - "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" + "responseLogprobs": { + "type": "boolean", + "description": "Optional. If true, export the logprobs results in response." }, - "functionDeclarations": { + "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", - "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.", "items": { - "$ref": "#/components/schemas/FunctionDeclaration" + "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" + ] } }, - "fileSearch": { - "$ref": "#/components/schemas/FileSearch", - "description": "Optional. FileSearch tool type. Tool to retrieve knowledge from Semantic Retrieval corpora." + "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." }, - "codeExecution": { - "$ref": "#/components/schemas/CodeExecution", - "description": "Optional. Enables the model to execute code as part of generation." + "logprobs": { + "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].", + "type": "integer", + "format": "int32" }, - "mcpServers": { - "description": "Optional. MCP Servers to connect to.", - "items": { - "$ref": "#/components/schemas/McpServer" - }, - "type": "array" + "enableEnhancedCivicAnswers": { + "type": "boolean", + "description": "Optional. Enables enhanced civic answers. It may not be available for all models." + }, + "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" + }, + "mediaResolution": { + "description": "Optional. If specified, the media resolution specified will be used.", + "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)." + ], + "enum": [ + "MEDIA_RESOLUTION_UNSPECIFIED", + "MEDIA_RESOLUTION_LOW", + "MEDIA_RESOLUTION_MEDIUM", + "MEDIA_RESOLUTION_HIGH" + ], + "type": "string" + }, + "seed": { + "type": "integer", + "format": "int32", + "description": "Optional. Seed used in decoding. If not set, the request uses a randomly generated seed." }, - "urlContext": { - "description": "Optional. Tool to support URL context retrieval.", - "$ref": "#/components/schemas/UrlContext" + "candidateCount": { + "type": "integer", + "format": "int32", + "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)" + }, + "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" } - } + }, + "type": "object" }, - "InlinedResponse": { - "description": "The response to a single request in the batch.", + "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: 6", "properties": { - "error": { - "readOnly": true, - "description": "Output only. The error encountered while processing the request.", - "$ref": "#/components/schemas/Status" - }, - "response": { - "readOnly": true, - "description": "Output only. The response to the request.", - "$ref": "#/components/schemas/GenerateContentResponse" + "name": { + "description": "The name of the MCPServer.", + "type": "string" }, - "metadata": { - "description": "Output only. The metadata associated with the request.", - "readOnly": true, - "type": "object", - "additionalProperties": { - "description": "Properties of the object." - } + "streamableHttpTransport": { + "description": "A transport that can stream HTTP requests and responses.", + "$ref": "#/components/schemas/StreamableHttpTransport" } } }, "StringList": { "description": "User provided string values assigned to a single metadata key.", - "type": "object", "properties": { "values": { - "description": "The string values of the metadata to store.", + "type": "array", "items": { "type": "string" }, - "type": "array" + "description": "The string values of the metadata to store." } - } + }, + "type": "object" }, - "UploadToFileSearchStoreRequest": { - "type": "object", + "FunctionResponseBlob": { + "description": "Raw media bytes for function response. Text should not be sent as raw bytes, use the 'FunctionResponse.response' field.", "properties": { - "displayName": { + "mimeType": { "type": "string", - "description": "Optional. Display name of the created document." + "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)." }, - "customMetadata": { - "description": "Custom metadata to be associated with the data.", - "items": { - "$ref": "#/components/schemas/CustomMetadata" - }, - "type": "array" - }, - "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" - }, - "mimeType": { - "description": "Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content.", - "type": "string" + "data": { + "type": "string", + "format": "byte", + "description": "Raw bytes for media formats." } }, - "description": "Request for `UploadToFileSearchStore`." + "type": "object" }, - "DynamicRetrievalConfig": { - "description": "Describes the options to customize dynamic retrieval.", + "TransferOwnershipResponse": { + "type": "object", + "description": "Response from `TransferOwnership`.", + "properties": {} + }, + "SearchEntryPoint": { "type": "object", + "description": "Google search entry point.", "properties": { - "mode": { - "type": "string", - "description": "The mode of the predictor to be used in dynamic retrieval.", - "x-enum-descriptions": [ - "Always trigger retrieval.", - "Run retrieval only when system decides it is necessary." - ], - "enum": [ - "MODE_UNSPECIFIED", - "MODE_DYNAMIC" - ] + "renderedContent": { + "description": "Optional. Web content snippet that can be embedded in a web page or an app webview.", + "type": "string" }, - "dynamicThreshold": { - "type": "number", - "format": "float", - "description": "The threshold to be used in dynamic retrieval. If not set, a system default value is used." + "sdkBlob": { + "type": "string", + "format": "byte", + "description": "Optional. Base64 encoded JSON representing array of tuple." } } }, - "EmbedContentRequest": { + "Model": { "type": "object", + "description": "Information about a Generative Language Model.", "properties": { - "title": { - "description": "Optional. Deprecated: Please use EmbedContentConfig.title instead. 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.", - "deprecated": true, + "name": { + "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" }, - "content": { - "description": "Required. The content to embed. Only the `parts.text` fields will be counted.", - "$ref": "#/components/schemas/Content" + "inputTokenLimit": { + "type": "integer", + "format": "int32", + "description": "Maximum number of input tokens allowed for this model." }, - "model": { + "outputTokenLimit": { + "description": "Maximum number of output tokens available for this model.", + "type": "integer", + "format": "int32" + }, + "description": { "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}`" + "description": "A short description of the model." }, - "outputDimensionality": { - "deprecated": true, - "format": "int32", - "type": "integer", - "description": "Optional. Deprecated: Please use EmbedContentConfig.output_dimensionality instead. 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`)." + "maxTemperature": { + "description": "The maximum temperature this model can use.", + "type": "number", + "format": "float" }, - "embedContentConfig": { - "$ref": "#/components/schemas/EmbedContentConfig", - "description": "Optional. Configuration for the EmbedContent request." + "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`." }, - "taskType": { - "deprecated": true, - "enum": [ - "TASK_TYPE_UNSPECIFIED", - "RETRIEVAL_QUERY", - "RETRIEVAL_DOCUMENT", - "SEMANTIC_SIMILARITY", - "CLASSIFICATION", - "CLUSTERING", - "QUESTION_ANSWERING", - "FACT_VERIFICATION", - "CODE_RETRIEVAL_QUERY" - ], - "type": "string", - "description": "Optional. Deprecated: Please use EmbedContentConfig.task_type instead. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`).", - "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." - ] - } - }, - "description": "Request containing the `Content` for the model to embed." - }, - "SearchEntryPoint": { - "description": "Google search entry point.", - "type": "object", - "properties": { - "renderedContent": { - "type": "string", - "description": "Optional. Web content snippet that can be embedded in a web page or an app webview." + "baseModelId": { + "description": "Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash`", + "type": "string" }, - "sdkBlob": { - "description": "Optional. Base64 encoded JSON representing array of tuple.", - "format": "byte", + "version": { + "description": "Required. The version number of the model. This represents the major version (`1.0` or `1.5`)", "type": "string" + }, + "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" + }, + "displayName": { + "type": "string", + "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." + }, + "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.", + "type": "number", + "format": "float" + }, + "thinking": { + "description": "Whether the model supports thinking.", + "type": "boolean" + }, + "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." } } }, - "VoiceConfig": { - "description": "The configuration for the voice to use.", - "type": "object", - "properties": { - "prebuiltVoiceConfig": { - "description": "The configuration for the prebuilt voice to use.", - "$ref": "#/components/schemas/PrebuiltVoiceConfig" - } - } - }, - "CreateFileRequest": { - "type": "object", + "ListModelsResponse": { + "description": "Response from `ListModel` containing a paginated list of Models.", "properties": { - "file": { - "description": "Optional. Metadata for the file to create.", - "$ref": "#/components/schemas/File" + "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" + }, + "models": { + "type": "array", + "items": { + "$ref": "#/components/schemas/Model" + }, + "description": "The returned Models." } }, - "description": "Request for `CreateFile`." + "type": "object" }, - "PlaceAnswerSources": { - "type": "object", + "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.", "properties": { - "reviewSnippets": { - "description": "Snippets of reviews that are used to generate answers about the features of a given place in Google Maps.", - "items": { - "$ref": "#/components/schemas/ReviewSnippet" + "executableCode": { + "description": "Code generated by the model that is meant to be executed.", + "$ref": "#/components/schemas/ExecutableCode" + }, + "mediaResolution": { + "description": "Optional. Media resolution for the input media.", + "$ref": "#/components/schemas/MediaResolution" + }, + "partMetadata": { + "additionalProperties": { + "description": "Properties of the object." }, - "type": "array" + "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" + }, + "codeExecutionResult": { + "description": "Result of executing the `ExecutableCode`.", + "$ref": "#/components/schemas/CodeExecutionResult" + }, + "inlineData": { + "description": "Inline media bytes.", + "$ref": "#/components/schemas/Blob" + }, + "text": { + "description": "Inline text.", + "type": "string" + }, + "thoughtSignature": { + "type": "string", + "format": "byte", + "description": "Optional. An opaque signature for the thought so it can be reused in subsequent requests." + }, + "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" + }, + "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" + }, + "fileData": { + "description": "URI based data.", + "$ref": "#/components/schemas/FileData" + }, + "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" + }, + "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" + }, + "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" } }, - "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" }, - "ReviewSnippet": { - "description": "Encapsulates a snippet of a user review that answers a question about the features of a specific place in Google Maps.", - "type": "object", + "GoogleSearch": { + "description": "GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google.", "properties": { - "googleMapsUri": { - "type": "string", - "description": "A link that corresponds to the user review on Google Maps." - }, - "title": { - "description": "Title of the review.", - "type": "string" + "searchTypes": { + "description": "Optional. The set of search types to enable. If not set, web search is enabled by default.", + "$ref": "#/components/schemas/SearchTypes" }, - "reviewId": { - "type": "string", - "description": "The ID of the review snippet." + "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).", + "$ref": "#/components/schemas/Interval" } - } + }, + "type": "object" }, - "FunctionCallingConfig": { - "type": "object", + "ListDocumentsResponse": { + "description": "Response from `ListDocuments` containing a paginated list of `Document`s. The `Document`s are sorted by ascending `document.create_time`.", "properties": { - "mode": { - "type": "string", - "enum": [ - "MODE_UNSPECIFIED", - "AUTO", - "ANY", - "NONE", - "VALIDATED" - ], - "description": "Optional. Specifies the mode in which function calling should execute. If unspecified, the default value will be set to AUTO.", - "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\"." - ] - }, - "allowedFunctionNames": { + "documents": { + "description": "The returned `Document`s.", "type": "array", - "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.", "items": { - "type": "string" + "$ref": "#/components/schemas/Document" } + }, + "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." } }, - "description": "Configuration for specifying function calling behavior." + "type": "object" }, - "Document": { - "description": "A `Document` is a collection of `Chunk`s.", + "GroundingChunkCustomMetadata": { "type": "object", + "description": "User provided metadata about the GroundingFact.", "properties": { - "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\"" - }, - "customMetadata": { - "type": "array", - "description": "Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`.", - "items": { - "$ref": "#/components/schemas/CustomMetadata" - } - }, - "state": { - "readOnly": true, - "type": "string", - "description": "Output only. Current state of the `Document`.", - "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." - ], - "enum": [ - "STATE_UNSPECIFIED", - "STATE_PENDING", - "STATE_ACTIVE", - "STATE_FAILED" - ] - }, - "sizeBytes": { - "readOnly": true, - "type": "string", - "format": "int64", - "description": "Output only. The size of raw bytes ingested into the Document." - }, - "mimeType": { - "readOnly": true, - "type": "string", - "description": "Output only. The mime type of the Document." + "numericValue": { + "description": "Optional. The numeric value of the metadata. The expected range for this value depends on the specific `key` used.", + "type": "number", + "format": "float" }, - "name": { + "stringValue": { "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`" + "description": "Optional. The string value of the metadata." }, - "updateTime": { - "format": "google-datetime", - "readOnly": true, + "key": { "type": "string", - "description": "Output only. The Timestamp of when the `Document` was last updated." + "description": "The key of the metadata." }, - "createTime": { - "description": "Output only. The Timestamp of when the `Document` was created.", - "format": "google-datetime", - "readOnly": true, - "type": "string" + "stringListValue": { + "description": "Optional. A list of string values for the metadata.", + "$ref": "#/components/schemas/GroundingChunkStringList" } } }, - "InlinedRequests": { + "InlinedEmbedContentResponses": { "type": "object", + "description": "The responses to the requests in the batch.", "properties": { - "requests": { - "description": "Required. The requests to be processed in the batch.", + "inlinedResponses": { + "readOnly": true, + "type": "array", "items": { - "$ref": "#/components/schemas/InlinedRequest" + "$ref": "#/components/schemas/InlinedEmbedContentResponse" }, - "type": "array" + "description": "Output only. The responses to the requests in the batch." } - }, - "description": "The requests to be processed in the batch if provided as part of the batch creation request." + } }, - "SemanticRetrieverChunk": { + "ThinkingConfig": { "type": "object", + "description": "Config for thinking features.", "properties": { - "source": { - "readOnly": true, - "type": "string", - "description": "Output only. Name of the source matching the request's `SemanticRetrieverConfig.source`. Example: `corpora/123` or `corpora/123/documents/abc`" + "thinkingBudget": { + "description": "The number of thoughts tokens that the model should generate.", + "type": "integer", + "format": "int32" }, - "chunk": { - "readOnly": true, - "type": "string", - "description": "Output only. Name of the `Chunk` containing the attributed text. Example: `corpora/123/documents/abc/chunks/xyz`" + "thinkingLevel": { + "description": "Optional. Controls the maximum depth of the model's internal reasoning process before it produces a response. The default value is model-dependent. Refer to the [Thinking levels guide](https://ai.google.dev/gemini-api/docs/thinking#thinking-levels) for more details. Recommended for Gemini 3 or later models. Use with earlier models results in an error.", + "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" + ], + "type": "string" + }, + "includeThoughts": { + "description": "Indicates whether to include thoughts in the response. If true, thoughts are returned only when available.", + "type": "boolean" } - }, - "description": "Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`." + } }, - "Corpus": { - "type": "object", + "ImageConfig": { + "description": "Config for image generation features.", "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" - }, - "updateTime": { - "readOnly": true, + "aspectRatio": { "type": "string", - "format": "google-datetime", - "description": "Output only. The Timestamp of when the `Corpus` was last updated." + "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." }, - "createTime": { - "description": "Output only. The Timestamp of when the `Corpus` was created.", - "readOnly": true, + "imageSize": { "type": "string", - "format": "google-datetime" - }, - "displayName": { - "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\"", - "type": "string" + "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`." } }, - "description": "A `Corpus` is a collection of `Document`s. A project can create up to 10 corpora." + "type": "object" }, - "CitationSource": { + "CreateFileResponse": { "type": "object", + "description": "Response for `CreateFile`.", "properties": { - "startIndex": { - "format": "int32", - "type": "integer", - "description": "Optional. Start of segment of the response that is attributed to this source. Index indicates the start of the segment, measured in bytes." - }, - "uri": { - "description": "Optional. URI that is attributed as a source for a portion of the text.", - "type": "string" + "file": { + "description": "Metadata for the created file.", + "$ref": "#/components/schemas/File" + } + } + }, + "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": { + "category": { + "description": "Required. The category for this rating.", + "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." + ], + "type": "string", + "enumDeprecated": [ + false, + false, + false, + false, + false, + false, + false, + false, + false, + false, + false, + true + ], + "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" + ] }, - "endIndex": { - "type": "integer", - "format": "int32", - "description": "Optional. End of the attributed segment, exclusive." + "blocked": { + "type": "boolean", + "description": "Was this content blocked because of this rating?" }, - "license": { - "description": "Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations.", + "probability": { + "description": "Required. The probability of harm for this content.", + "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." + ], + "enum": [ + "HARM_PROBABILITY_UNSPECIFIED", + "NEGLIGIBLE", + "LOW", + "MEDIUM", + "HIGH" + ], "type": "string" } }, - "description": "A citation to a source for a portion of a specific response." + "type": "object" }, - "Interval": { + "GoogleMaps": { "type": "object", + "description": "The GoogleMaps Tool that provides geospatial context for the user's query.", "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" - }, - "endTime": { - "type": "string", - "format": "google-datetime", - "description": "Optional. Exclusive end of the interval. If specified, a Timestamp matching this interval will have to be before the end." + "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" } - }, - "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." + } }, - "EmbedContentBatchStats": { + "TuningTask": { "type": "object", + "description": "Tuning tasks that create tuned models.", "properties": { - "failedRequestCount": { - "readOnly": true, - "type": "string", - "format": "int64", - "description": "Output only. The number of requests that failed to be processed." + "hyperparameters": { + "description": "Immutable. Hyperparameters controlling the tuning process. If not provided, default values will be used.", + "$ref": "#/components/schemas/Hyperparameters" }, - "pendingRequestCount": { + "completeTime": { + "description": "Output only. The timestamp when tuning this model completed.", "readOnly": true, "type": "string", - "format": "int64", - "description": "Output only. The number of requests that are still pending processing." + "format": "google-datetime" }, - "successfulRequestCount": { - "description": "Output only. The number of requests that were successfully processed.", - "format": "int64", + "snapshots": { "readOnly": true, - "type": "string" + "type": "array", + "items": { + "$ref": "#/components/schemas/TuningSnapshot" + }, + "description": "Output only. Metrics collected during tuning." }, - "requestCount": { - "format": "int64", - "readOnly": true, + "trainingData": { + "description": "Required. Input only. Immutable. The model training data.", + "$ref": "#/components/schemas/Dataset" + }, + "startTime": { + "description": "Output only. The timestamp when tuning this model started.", "type": "string", - "description": "Output only. The number of requests in the batch." + "format": "google-datetime", + "readOnly": true } - }, - "description": "Stats about the batch." + } }, - "UrlContext": { - "type": "object", - "properties": {}, - "description": "Tool to support URL context retrieval." + "SpeakerVoiceConfig": { + "description": "The configuration for a single speaker in a multi speaker setup.", + "properties": { + "speaker": { + "description": "Required. The name of the speaker to use. Should be the same as in the prompt.", + "type": "string" + }, + "voiceConfig": { + "description": "Required. The configuration for the voice to use.", + "$ref": "#/components/schemas/VoiceConfig" + } + }, + "type": "object" }, "BatchStats": { "description": "Stats about the batch.", - "type": "object", "properties": { "requestCount": { - "description": "Output only. The number of requests in the batch.", - "format": "int64", - "readOnly": true, - "type": "string" - }, - "failedRequestCount": { - "format": "int64", "readOnly": true, "type": "string", - "description": "Output only. The number of requests that failed to be processed." - }, - "pendingRequestCount": { - "description": "Output only. The number of requests that are still pending processing.", "format": "int64", - "readOnly": true, - "type": "string" + "description": "Output only. The number of requests in the batch." }, "successfulRequestCount": { "description": "Output only. The number of requests that were successfully processed.", "readOnly": true, "type": "string", "format": "int64" - } - } - }, - "GoogleSearchRetrieval": { - "description": "Tool to retrieve public web data for grounding, powered by Google.", - "type": "object", - "properties": { - "dynamicRetrievalConfig": { - "$ref": "#/components/schemas/DynamicRetrievalConfig", - "description": "Specifies the dynamic retrieval configuration for the given source." - } - } - }, - "TunedModelSource": { - "description": "Tuned model as a source for training a new model.", - "type": "object", - "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" - } - } - }, - "ImageSearch": { - "type": "object", - "properties": {}, - "description": "Image search for grounding and related configurations." - }, - "Model": { - "description": "Information about a Generative Language Model.", - "type": "object", - "properties": { - "inputTokenLimit": { - "description": "Maximum number of input tokens allowed for this model.", - "format": "int32", - "type": "integer" - }, - "baseModelId": { - "description": "Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash`", - "type": "string" - }, - "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.", - "type": "number", - "format": "float" - }, - "version": { - "description": "Required. The version number of the model. This represents the major version (`1.0` or `1.5`)", - "type": "string" - }, - "supportedGenerationMethods": { - "description": "The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`.", - "items": { - "type": "string" - }, - "type": "array" - }, - "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" - }, - "description": { - "description": "A short description of the model.", - "type": "string" - }, - "maxTemperature": { - "type": "number", - "format": "float", - "description": "The maximum temperature this model can use." - }, - "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" - }, - "outputTokenLimit": { - "description": "Maximum number of output tokens available for this model.", - "type": "integer", - "format": "int32" - }, - "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.", - "type": "number", - "format": "float" - }, - "name": { - "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" }, - "thinking": { - "type": "boolean", - "description": "Whether the model supports thinking." - } - } - }, - "EmbeddingUsageMetadata": { - "type": "object", - "properties": { - "promptTokenCount": { - "description": "Output only. Number of tokens in the prompt.", - "readOnly": true, - "type": "integer", - "format": "int32" + "failedRequestCount": { + "description": "Output only. The number of requests that failed to be processed.", + "type": "string", + "format": "int64", + "readOnly": true }, - "promptTokenDetails": { - "description": "Output only. List of modalities that were processed in the request input.", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - }, + "pendingRequestCount": { + "description": "Output only. The number of requests that are still pending processing.", "readOnly": true, - "type": "array" + "type": "string", + "format": "int64" } }, - "description": "Metadata on the usage of the embedding request." + "type": "object" }, - "TopCandidates": { + "RegisterFilesResponse": { "type": "object", + "description": "Response for `RegisterFiles`.", "properties": { - "candidates": { + "files": { + "description": "The registered files to be used when calling GenerateContent.", "type": "array", - "description": "Sorted by log probability in descending order.", "items": { - "$ref": "#/components/schemas/LogprobsResultCandidate" + "$ref": "#/components/schemas/File" } } - }, - "description": "Candidates with top log probabilities at each decoding step." + } }, - "CachedContent": { + "Empty": { "type": "object", + "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": {} + }, + "RegisterFilesRequest": { + "description": "Request for `RegisterFiles`.", "properties": { - "ttl": { - "description": "Input only. New TTL for this resource, input only.", - "format": "google-duration", - "type": "string" - }, - "displayName": { - "description": "Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters.", - "type": "string" - }, - "contents": { - "description": "Optional. Input only. Immutable. The content to cache.", - "items": { - "$ref": "#/components/schemas/Content" - }, - "type": "array" - }, - "model": { - "type": "string", - "description": "Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}`" - }, - "updateTime": { - "readOnly": true, - "type": "string", - "format": "google-datetime", - "description": "Output only. When the cache entry was last updated in UTC time." - }, - "systemInstruction": { - "$ref": "#/components/schemas/Content", - "description": "Optional. Input only. Immutable. Developer set system instruction. Currently text only." - }, - "createTime": { - "description": "Output only. Creation time of the cache entry.", - "format": "google-datetime", - "readOnly": true, - "type": "string" - }, - "toolConfig": { - "description": "Optional. Input only. Immutable. Tool config. This config is shared for all tools.", - "$ref": "#/components/schemas/ToolConfig" - }, - "usageMetadata": { - "description": "Output only. Metadata on the usage of the cached content.", - "$ref": "#/components/schemas/CachedContentUsageMetadata", - "readOnly": true - }, - "tools": { - "description": "Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response", + "uris": { + "description": "Required. The Google Cloud Storage URIs to register. Example: `gs://bucket/object`.", + "type": "array", "items": { - "$ref": "#/components/schemas/Tool" - }, - "type": "array" - }, - "name": { - "readOnly": true, - "type": "string", - "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`" - }, - "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.", - "type": "string", - "format": "google-datetime" + "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" }, - "TunedModel": { - "description": "A fine-tuned model created using ModelService.CreateTunedModel.", - "type": "object", + "ModelStatus": { + "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": { - "createTime": { - "readOnly": true, - "type": "string", - "format": "google-datetime", - "description": "Output only. The timestamp when this model was created." - }, - "tunedModelSource": { - "$ref": "#/components/schemas/TunedModelSource", - "description": "Optional. TunedModel to use as the starting point for training the new model." - }, - "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.", - "format": "float", - "type": "number" - }, - "tuningTask": { - "$ref": "#/components/schemas/TuningTask", - "description": "Required. The tuning task that creates the tuned model." - }, - "topK": { - "type": "integer", - "format": "int32", - "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." - }, - "state": { - "readOnly": true, - "type": "string", - "description": "Output only. The state of the tuned model.", + "modelStage": { + "description": "The stage of the underlying 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." + "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." + ], + "type": "string", + "enumDeprecated": [ + false, + true, + false, + false, + false, + false, + true, + false ], "enum": [ - "STATE_UNSPECIFIED", - "CREATING", - "ACTIVE", - "FAILED" + "MODEL_STAGE_UNSPECIFIED", + "UNSTABLE_EXPERIMENTAL", + "EXPERIMENTAL", + "PREVIEW", + "STABLE", + "LEGACY", + "DEPRECATED", + "RETIRED" ] }, - "updateTime": { - "readOnly": true, + "retirementTime": { "type": "string", "format": "google-datetime", - "description": "Output only. The timestamp when this model was updated." + "description": "The time at which the model will be retired." }, - "temperature": { - "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.", - "format": "float", - "type": "number" - }, - "readerProjectNumbers": { + "message": { + "description": "A message explaining the model status.", + "type": "string" + } + }, + "type": "object" + }, + "ListPermissionsResponse": { + "description": "Response from `ListPermissions` containing a paginated list of permissions.", + "properties": { + "permissions": { "type": "array", - "description": "Optional. List of project numbers that have read access to the tuned model.", "items": { - "type": "string", - "format": "int64" - } - }, - "description": { - "description": "Optional. A short description of this model.", - "type": "string" + "$ref": "#/components/schemas/Permission" + }, + "description": "Returned permissions." }, - "baseModel": { - "description": "Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001`", + "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" + }, + "SearchTypes": { + "type": "object", + "description": "Different types of search that can be enabled on the GoogleSearch tool.", + "properties": { + "imageSearch": { + "description": "Optional. Enables image search. Image bytes are returned.", + "$ref": "#/components/schemas/ImageSearch" }, - "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" + "webSearch": { + "description": "Optional. Enables web search. Only text results are returned.", + "$ref": "#/components/schemas/WebSearch" + } + } + }, + "TunedModelSource": { + "type": "object", + "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`" }, - "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`", + "baseModel": { + "type": "string", "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`" } } }, + "WhiteSpaceConfig": { + "description": "Configuration for a white space chunking algorithm [white space delimited].", + "properties": { + "maxTokensPerChunk": { + "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.", + "type": "integer", + "format": "int32" + }, + "maxOverlapTokens": { + "type": "integer", + "format": "int32", + "description": "Maximum number of overlapping tokens between two adjacent chunks." + } + }, + "type": "object" + }, "Hyperparameters": { "description": "Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance", - "type": "object", "properties": { - "learningRateMultiplier": { - "format": "float", - "type": "number", - "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." - }, "batchSize": { - "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.", "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." + "format": "int32" }, - "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.", + "learningRateMultiplier": { + "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.", "type": "number", "format": "float" }, "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.", - "format": "int32", - "type": "integer" + "type": "integer", + "format": "int32" + }, + "learningRate": { + "type": "number", + "format": "float", + "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": "object" }, - "Image": { - "description": "Chunk from image search.", - "type": "object", + "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": { - "sourceUri": { - "description": "The web page URI for attribution.", - "type": "string" - }, - "imageUri": { - "type": "string", - "description": "The image asset URL." - }, - "title": { + "id": { "type": "string", - "description": "The title of the web page that the image is from." + "description": "Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`." }, - "domain": { - "description": "The root domain of the web page that the image is from, e.g. \"example.com\".", + "language": { + "description": "Required. Programming language of the `code`.", + "x-enum-descriptions": [ + "Unspecified language. This value should not be used.", + "Python >= 3.10, with numpy and simpy available. Python is the default language." + ], + "enum": [ + "LANGUAGE_UNSPECIFIED", + "PYTHON" + ], "type": "string" + }, + "code": { + "type": "string", + "description": "Required. The code to be executed." } - } + }, + "type": "object" }, - "RegisterFilesRequest": { - "description": "Request for `RegisterFiles`.", + "ListCachedContentsResponse": { "type": "object", + "description": "Response with CachedContents list.", "properties": { - "uris": { - "description": "Required. The Google Cloud Storage URIs to register. Example: `gs://bucket/object`.", + "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" + }, + "cachedContents": { + "description": "List of cached contents.", + "type": "array", "items": { - "type": "string" - }, - "type": "array" + "$ref": "#/components/schemas/CachedContent" + } } } }, - "GroundingAttribution": { - "type": "object", - "properties": { - "sourceId": { - "readOnly": true, - "$ref": "#/components/schemas/AttributionSourceId", - "description": "Output only. Identifier for the source contributing to this attribution." - }, - "content": { - "$ref": "#/components/schemas/Content", - "description": "Grounding source content that makes up this attribution." - } - }, - "description": "Attribution for a source that contributed to an answer." - }, - "RetrievedContext": { + "CodeExecutionResult": { "type": "object", + "description": "Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used.", "properties": { - "customMetadata": { - "type": "array", - "description": "Optional. User-provided metadata about the retrieved context.", - "items": { - "$ref": "#/components/schemas/GroundingChunkCustomMetadata" - } - }, - "pageNumber": { - "description": "Optional. Page number of the retrieved context, if applicable.", - "type": "integer", - "format": "int32" - }, - "mediaId": { - "description": "Optional. The media blob resource name for multimodal file search results. Format: fileSearchStores/{file_search_store_id}/media/{blob_id}", + "outcome": { + "description": "Required. Outcome of the code execution.", + "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" + ], "type": "string" }, - "uri": { + "id": { "type": "string", - "description": "Optional. URI reference of the semantic retrieval document." + "description": "Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id." }, - "fileSearchStore": { + "output": { "type": "string", - "description": "Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123`" - }, - "text": { - "description": "Optional. Text of the chunk.", - "type": "string" - }, - "title": { - "description": "Optional. Title of the document.", - "type": "string" + "description": "Optional. Contains stdout when code execution is successful, stderr or other description otherwise." } - }, - "description": "Chunk from context retrieved by the file search tool." + } }, - "BatchEmbedContentsResponse": { + "UsageMetadata": { "type": "object", + "description": "Metadata on the generation request's token usage.", "properties": { - "embeddings": { + "candidatesTokenCount": { + "description": "Total number of tokens across all the generated response candidates.", + "type": "integer", + "format": "int32" + }, + "totalTokenCount": { + "type": "integer", + "format": "int32", + "description": "Total token count for the generation request (prompt + thoughts + response candidates)." + }, + "candidatesTokensDetails": { + "description": "Output only. List of modalities that were returned in the response.", "readOnly": true, "type": "array", - "description": "Output only. The embeddings for each request, in the same order as provided in the batch request.", "items": { - "$ref": "#/components/schemas/ContentEmbedding" + "$ref": "#/components/schemas/ModalityTokenCount" } }, - "usageMetadata": { + "thoughtsTokenCount": { + "description": "Output only. Number of tokens of thoughts for thinking models.", + "type": "integer", + "format": "int32", + "readOnly": true + }, + "cachedContentTokenCount": { + "description": "Number of tokens in the cached part of the prompt (the cached content)", + "type": "integer", + "format": "int32" + }, + "toolUsePromptTokenCount": { + "type": "integer", + "format": "int32", "readOnly": true, - "$ref": "#/components/schemas/EmbeddingUsageMetadata", - "description": "Output only. The usage metadata for the request." - } - }, - "description": "The response to a `BatchEmbedContentsRequest`." - }, - "GenerateContentRequest": { - "type": "object", - "properties": { - "tools": { + "description": "Output only. Number of tokens present in tool-use prompt(s)." + }, + "cacheTokensDetails": { "type": "array", - "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.", "items": { - "$ref": "#/components/schemas/Tool" - } - }, - "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" + "$ref": "#/components/schemas/ModalityTokenCount" + }, + "readOnly": true, + "description": "Output only. List of modalities of the cached content in the request input." }, - "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." + "toolUsePromptTokensDetails": { + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + }, + "readOnly": true, + "description": "Output only. List of modalities that were processed for tool-use request inputs." }, "serviceTier": { + "readOnly": true, "type": "string", "enum": [ "unspecified", @@ -5432,7 +5703,7 @@ "flex", "priority" ], - "description": "Optional. The service tier of the request.", + "description": "Output only. Service tier of the request.", "x-enum-descriptions": [ "Default service tier, which is standard.", "Standard service tier.", @@ -5440,783 +5711,689 @@ "Priority service tier." ] }, - "systemInstruction": { - "$ref": "#/components/schemas/Content", - "description": "Optional. Developer set [system instruction(s)](https://ai.google.dev/gemini-api/docs/system-instructions). Currently, text only." + "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." }, - "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.", + "promptTokensDetails": { + "type": "array", "items": { - "$ref": "#/components/schemas/SafetySetting" + "$ref": "#/components/schemas/ModalityTokenCount" }, - "type": "array" + "readOnly": true, + "description": "Output only. List of modalities that were processed in the request input." }, - "contents": { + "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", - "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.", + "readOnly": true, "items": { - "$ref": "#/components/schemas/Content" + "$ref": "#/components/schemas/ModalityTokenCount" } - }, - "generationConfig": { - "description": "Optional. Configuration options for model generation and outputs.", - "$ref": "#/components/schemas/GenerationConfig" - }, - "model": { - "type": "string", - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`." - }, - "store": { - "type": "boolean", - "description": "Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config." - } - }, - "description": "Request to generate a completion from the model." - }, - "Blob": { - "type": "object", - "properties": { - "mimeType": { - "type": "string", - "description": "The IANA standard MIME type of the source data. Examples of supported types: - Images: image/png, image/jpeg, image/jpg, image/webp, image/heic, image/heif, image/gif, image/avif - Audio: audio/*, video/audio/s16le, video/audio/wav - Video: video/* - Text: text/plain, text/html, text/css, text/javascript, text/x-typescript, text/csv, text/markdown, text/x-python, text/xml, text/rtf, video/text/timestamp - Applications: application/x-javascript, application/x-typescript, application/x-python-code, application/json, application/x-ipynb+json, application/rtf, application/pdf For additional context, see [Supported file formats](https://ai.google.dev/gemini-api/docs/file-input-methods#supported-content-types). //" - }, - "data": { - "format": "byte", - "type": "string", - "description": "Raw bytes for media formats." - } - }, - "description": "Raw media bytes. Text should not be sent as raw bytes, use the 'text' field." - }, - "RetrievalConfig": { - "type": "object", - "properties": { - "latLng": { - "description": "Optional. The location of the user.", - "$ref": "#/components/schemas/LatLng" - }, - "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)." } - }, - "description": "Retrieval config." + } }, - "Candidate": { - "description": "A response candidate generated from the model.", - "type": "object", + "EmbedContentConfig": { + "description": "Configurations for the EmbedContent request.", "properties": { - "groundingMetadata": { - "$ref": "#/components/schemas/GroundingMetadata", - "description": "Output only. Grounding metadata for the candidate. This field is populated for `GenerateContent` calls.", - "readOnly": true - }, - "finishReason": { - "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.", + "taskType": { + "description": "Optional. The task type of the embedding.", "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." + "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": [ + "TASK_TYPE_UNSPECIFIED", + "RETRIEVAL_QUERY", + "RETRIEVAL_DOCUMENT", + "SEMANTIC_SIMILARITY", + "CLASSIFICATION", + "CLUSTERING", + "QUESTION_ANSWERING", + "FACT_VERIFICATION", + "CODE_RETRIEVAL_QUERY" ], - "readOnly": true, "type": "string" }, - "finishMessage": { - "readOnly": true, - "type": "string", - "description": "Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set." - }, - "avgLogprobs": { - "format": "double", - "readOnly": true, - "type": "number", - "description": "Output only. Average log probability score of the candidate." - }, - "index": { - "readOnly": true, - "type": "integer", - "format": "int32", - "description": "Output only. Index of the candidate in the list of response candidates." - }, - "safetyRatings": { - "type": "array", - "description": "List of ratings for the safety of a response candidate. There is at most one rating per category.", - "items": { - "$ref": "#/components/schemas/SafetyRating" - } - }, - "groundingAttributions": { - "readOnly": true, - "type": "array", - "description": "Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.", - "items": { - "$ref": "#/components/schemas/GroundingAttribution" - } + "documentOcr": { + "description": "Optional. Whether to enable OCR for document content.", + "type": "boolean" }, - "content": { - "description": "Output only. Generated content returned from the model.", - "$ref": "#/components/schemas/Content", - "readOnly": true + "audioTrackExtraction": { + "type": "boolean", + "description": "Optional. Whether to extract audio from video content." }, - "urlContextMetadata": { - "$ref": "#/components/schemas/UrlContextMetadata", - "description": "Output only. Metadata related to url context retrieval tool.", - "readOnly": true + "autoTruncate": { + "type": "boolean", + "description": "Optional. Whether to silently truncate the input content if it's longer than the maximum sequence length." }, - "tokenCount": { - "description": "Output only. Token count for this candidate.", - "readOnly": true, + "title": { + "type": "string", + "description": "Optional. The title for the text." + }, + "outputDimensionality": { + "description": "Optional. Reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end.", "type": "integer", "format": "int32" + } + }, + "type": "object" + }, + "GenerateContentBatchOutput": { + "description": "The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field.", + "properties": { + "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 `GenerateContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests." }, - "citationMetadata": { - "$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.", - "readOnly": true - }, - "logprobsResult": { - "description": "Output only. Log-likelihood scores for the response tokens and top tokens", - "$ref": "#/components/schemas/LogprobsResult", + "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.", + "$ref": "#/components/schemas/InlinedResponses", "readOnly": true } - } + }, + "type": "object" }, - "InlinedEmbedContentResponse": { + "FileData": { "type": "object", + "description": "URI based data.", "properties": { - "error": { - "$ref": "#/components/schemas/Status", - "description": "Output only. The error encountered while processing the request.", - "readOnly": true + "mimeType": { + "description": "Optional. The IANA standard MIME type of the source data.", + "type": "string" }, - "response": { - "description": "Output only. The response to the request.", - "$ref": "#/components/schemas/EmbedContentResponse", - "readOnly": true + "fileUri": { + "type": "string", + "description": "Required. URI." + } + } + }, + "GroundingPassageId": { + "description": "Identifier for a part within a `GroundingPassage`.", + "properties": { + "partIndex": { + "type": "integer", + "format": "int32", + "readOnly": true, + "description": "Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`." }, - "metadata": { - "description": "Output only. The metadata associated with the request.", + "passageId": { + "description": "Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`.", "readOnly": true, - "type": "object", - "additionalProperties": { - "description": "Properties of the object." - } + "type": "string" } }, - "description": "The response to a single request in the batch." + "type": "object" }, - "InlinedEmbedContentRequest": { - "description": "The request to be processed in the batch.", + "CitationMetadata": { "type": "object", + "description": "A collection of source attributions for a piece of content.", "properties": { - "request": { - "description": "Required. The request to be processed in the batch.", - "$ref": "#/components/schemas/EmbedContentRequest" - }, - "metadata": { - "description": "Optional. The metadata to be associated with the request.", - "type": "object", - "additionalProperties": { - "description": "Properties of the object." + "citationSources": { + "description": "Citations to sources for a specific response.", + "type": "array", + "items": { + "$ref": "#/components/schemas/CitationSource" } } } }, - "SafetySetting": { - "type": "object", + "TuningExamples": { + "description": "A set of tuning examples. Can be training or validation data.", "properties": { - "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" - ], - "type": "string", - "description": "Required. The category for this setting.", - "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." - ], - "enumDeprecated": [ - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - true - ] - }, - "threshold": { + "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" + } + } + }, + "type": "object" + }, + "DynamicRetrievalConfig": { + "description": "Describes the options to customize dynamic retrieval.", + "properties": { + "mode": { "type": "string", - "description": "Required. Controls the probability threshold at which harm is blocked.", + "description": "The mode of the predictor to be used in dynamic retrieval.", "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." + "Always trigger retrieval.", + "Run retrieval only when system decides it is necessary." ], "enum": [ - "HARM_BLOCK_THRESHOLD_UNSPECIFIED", - "BLOCK_LOW_AND_ABOVE", - "BLOCK_MEDIUM_AND_ABOVE", - "BLOCK_ONLY_HIGH", - "BLOCK_NONE", - "OFF" + "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" } }, - "description": "Safety setting, affecting the safety-blocking behavior. Passing a safety setting for a category changes the allowed probability that content is blocked." + "type": "object" }, - "GoogleAiGenerativelanguageV1betaSegment": { - "description": "Segment of the content.", + "CreateFileRequest": { "type": "object", + "description": "Request for `CreateFile`.", "properties": { - "endIndex": { - "description": "End index in the given Part, measured in bytes. Offset from the start of the Part, exclusive, starting at zero.", - "format": "int32", - "type": "integer" - }, - "partIndex": { - "format": "int32", - "type": "integer", - "description": "The index of a Part object within its parent Content object." - }, - "startIndex": { - "description": "Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero.", - "type": "integer", - "format": "int32" - }, - "text": { - "type": "string", - "description": "The text corresponding to the segment from the response." + "file": { + "description": "Optional. Metadata for the file to create.", + "$ref": "#/components/schemas/File" } } }, - "FunctionDeclaration": { - "type": "object", + "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": { "name": { - "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.", - "type": "string" - }, - "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`." - }, - "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" - }, - "description": { - "description": "Required. A brief description of the function.", + "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" }, "response": { - "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.", - "$ref": "#/components/schemas/Schema" - }, - "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`." + "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.", + "additionalProperties": { + "description": "Properties of the object." + }, + "type": "object" }, - "behavior": { - "enum": [ - "UNSPECIFIED", - "BLOCKING", - "NON_BLOCKING" - ], - "description": "Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method.", - "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." - ], + "id": { + "description": "Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`.", "type": "string" - } - }, - "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." - }, - "PromptFeedback": { - "type": "object", - "properties": { - "safetyRatings": { + }, + "parts": { + "description": "Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types.", "type": "array", - "description": "Ratings for safety of the prompt. There is at most one rating per category.", "items": { - "$ref": "#/components/schemas/SafetyRating" + "$ref": "#/components/schemas/FunctionResponsePart" } }, - "blockReason": { + "willContinue": { + "type": "boolean", + "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`." + }, + "scheduling": { "type": "string", - "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.", - "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." + "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.", + "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" ] } }, - "description": "A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`." + "type": "object" }, - "ListPermissionsResponse": { + "ListFilesResponse": { "type": "object", + "description": "Response for `ListFiles`.", "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.", + "description": "A token that can be sent as a `page_token` into a subsequent `ListFiles` call.", "type": "string" }, - "permissions": { - "description": "Returned permissions.", + "files": { + "description": "The list of `File`s.", + "type": "array", "items": { - "$ref": "#/components/schemas/Permission" - }, - "type": "array" + "$ref": "#/components/schemas/File" + } } - }, - "description": "Response from `ListPermissions` containing a paginated list of permissions." + } }, - "Operation": { - "description": "This resource represents a long-running operation that is the result of a network API call.", + "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": { - "metadata": { - "type": "object", + "response": { "additionalProperties": { - "description": "Properties of the object. Contains field @type with type URL." + "description": "Properties of the object." }, - "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." - }, - "error": { - "description": "The error result of the operation in case of failure or cancellation.", - "$ref": "#/components/schemas/Status" + "description": "Optional. The tool response.", + "type": "object" }, - "name": { + "toolType": { "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}`." - }, - "done": { - "type": "boolean", - "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." + "description": "Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`.", + "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" + ] }, - "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`." + "id": { + "type": "string", + "description": "Optional. The identifier of the tool call this response is for." } } }, - "GoogleSearch": { - "description": "GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google.", + "GoogleSearchRetrieval": { + "description": "Tool to retrieve public web data for grounding, powered by Google.", + "properties": { + "dynamicRetrievalConfig": { + "description": "Specifies the dynamic retrieval configuration for the given source.", + "$ref": "#/components/schemas/DynamicRetrievalConfig" + } + }, + "type": "object" + }, + "PrebuiltVoiceConfig": { "type": "object", + "description": "The configuration for the prebuilt speaker to use.", "properties": { - "timeRangeFilter": { - "$ref": "#/components/schemas/Interval", - "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)." - }, - "searchTypes": { - "description": "Optional. The set of search types to enable. If not set, web search is enabled by default.", - "$ref": "#/components/schemas/SearchTypes" + "voiceName": { + "type": "string", + "description": "The name of the preset voice to use." } } }, - "UrlMetadata": { + "InlinedRequests": { "type": "object", + "description": "The requests to be processed in the batch if provided as part of the batch creation request.", "properties": { - "retrievedUrl": { - "description": "Retrieved url by the tool.", - "type": "string" - }, - "urlRetrievalStatus": { - "description": "Status of the url retrieval.", - "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" - ], - "type": "string" + "requests": { + "type": "array", + "items": { + "$ref": "#/components/schemas/InlinedRequest" + }, + "description": "Required. The requests to be processed in the batch." } - }, - "description": "Context of the a single url retrieval." + } }, - "InputEmbedContentConfig": { + "ListGeneratedFilesResponse": { "type": "object", + "description": "Response for `ListGeneratedFiles`.", "properties": { - "fileName": { - "type": "string", - "description": "The name of the `File` containing the input requests." + "generatedFiles": { + "description": "The list of `GeneratedFile`s.", + "type": "array", + "items": { + "$ref": "#/components/schemas/GeneratedFile" + } }, - "requests": { - "description": "The requests to be processed in the batch.", - "$ref": "#/components/schemas/InlinedEmbedContentRequests" + "nextPageToken": { + "type": "string", + "description": "A token that can be sent as a `page_token` into a subsequent `ListGeneratedFiles` call." } - }, - "description": "Configures the input to the batch request." + } }, - "CachedContentUsageMetadata": { + "LatLng": { "type": "object", + "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.", "properties": { - "totalTokenCount": { + "latitude": { + "description": "The latitude in degrees. It must be in the range [-90.0, +90.0].", + "type": "number", + "format": "double" + }, + "longitude": { + "type": "number", + "format": "double", + "description": "The longitude in degrees. It must be in the range [-180.0, +180.0]." + } + } + }, + "TunedModel": { + "description": "A fine-tuned model created using ModelService.CreateTunedModel.", + "properties": { + "name": { + "type": "string", + "readOnly": 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`" + }, + "baseModel": { + "type": "string", + "description": "Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001`" + }, + "updateTime": { + "readOnly": true, + "type": "string", + "format": "google-datetime", + "description": "Output only. The timestamp when this model was updated." + }, + "tunedModelSource": { + "description": "Optional. TunedModel to use as the starting point for training the new model.", + "$ref": "#/components/schemas/TunedModelSource" + }, + "description": { + "description": "Optional. A short description of this model.", + "type": "string" + }, + "createTime": { + "description": "Output only. The timestamp when this model was created.", + "readOnly": true, + "type": "string", + "format": "google-datetime" + }, + "topK": { "type": "integer", "format": "int32", - "description": "Total number of tokens that the cached content consumes." + "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." + }, + "state": { + "enum": [ + "STATE_UNSPECIFIED", + "CREATING", + "ACTIVE", + "FAILED" + ], + "type": "string", + "readOnly": true, + "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." + ] + }, + "readerProjectNumbers": { + "type": "array", + "items": { + "type": "string", + "format": "int64" + }, + "description": "Optional. List of project numbers that have read access to the tuned model." + }, + "displayName": { + "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." + }, + "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." + }, + "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" + }, + "tuningTask": { + "description": "Required. The tuning task that creates the tuned model.", + "$ref": "#/components/schemas/TuningTask" } }, - "description": "Metadata on the usage of the cached content." + "type": "object" }, - "ListTunedModelsResponse": { - "type": "object", + "Permission": { + "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": { - "tunedModels": { - "description": "The returned Models.", - "items": { - "$ref": "#/components/schemas/TunedModel" - }, - "type": "array" + "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." }, - "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" + "name": { + "type": "string", + "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." + }, + "role": { + "type": "string", + "description": "Required. The role granted by this permission.", + "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" + ] + }, + "granteeType": { + "type": "string", + "description": "Optional. Immutable. The type of the grantee.", + "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": "Response from `ListTunedModels` containing a paginated list of Models." + "type": "object" }, - "ImportFileRequest": { + "InlinedResponse": { "type": "object", + "description": "The response to a single request in the batch.", "properties": { - "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" + "error": { + "description": "Output only. The error encountered while processing the request.", + "$ref": "#/components/schemas/Status", + "readOnly": true }, - "customMetadata": { - "type": "array", - "description": "Custom metadata to be associated with the file.", - "items": { - "$ref": "#/components/schemas/CustomMetadata" + "metadata": { + "readOnly": true, + "type": "object", + "description": "Output only. The metadata associated with the request.", + "additionalProperties": { + "description": "Properties of the object." } - } - }, - "description": "Request for `ImportFile` to import a File API file with a `FileSearchStore`." - }, - "InlinedResponses": { - "description": "The responses to the requests in the batch.", - "type": "object", - "properties": { - "inlinedResponses": { - "description": "Output only. The responses to the requests in the batch.", - "items": { - "$ref": "#/components/schemas/InlinedResponse" - }, + }, + "response": { "readOnly": true, - "type": "array" + "description": "Output only. The response to the request.", + "$ref": "#/components/schemas/GenerateContentResponse" } } }, - "ThinkingConfig": { - "description": "Config for thinking features.", + "InputEmbedContentConfig": { "type": "object", + "description": "Configures the input to the batch request.", "properties": { - "thinkingBudget": { - "description": "The number of thoughts tokens that the model should generate.", - "format": "int32", - "type": "integer" + "requests": { + "description": "The requests to be processed in the batch.", + "$ref": "#/components/schemas/InlinedEmbedContentRequests" }, - "thinkingLevel": { + "fileName": { "type": "string", - "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. The default value is model-dependent. Refer to the [Thinking levels guide](https://ai.google.dev/gemini-api/docs/thinking#thinking-levels) for more details. Recommended for Gemini 3 or later models. Use with earlier models results in an error.", - "x-enum-descriptions": [ - "Default value.", - "Little to no thinking.", - "Low thinking level.", - "Medium thinking level.", - "High thinking level." - ] - }, - "includeThoughts": { - "type": "boolean", - "description": "Indicates whether to include thoughts in the response. If true, thoughts are returned only when available." + "description": "The name of the `File` containing the input requests." } } }, - "MultiSpeakerVoiceConfig": { - "type": "object", + "InlinedEmbedContentRequests": { + "description": "The requests to be processed in the batch if provided as part of the batch creation request.", "properties": { - "speakerVoiceConfigs": { - "description": "Required. All the enabled speaker voices.", + "requests": { + "type": "array", "items": { - "$ref": "#/components/schemas/SpeakerVoiceConfig" + "$ref": "#/components/schemas/InlinedEmbedContentRequest" }, - "type": "array" + "description": "Required. The requests to be processed in the batch." } }, - "description": "The configuration for the multi-speaker setup." + "type": "object" }, - "CountTokensRequest": { - "type": "object", + "MultiSpeakerVoiceConfig": { + "description": "The configuration for the multi-speaker setup.", "properties": { - "contents": { + "speakerVoiceConfigs": { "type": "array", - "description": "Optional. The input given to the model as a prompt. This field is ignored when `generate_content_request` is set.", "items": { - "$ref": "#/components/schemas/Content" - } - }, - "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." + "$ref": "#/components/schemas/SpeakerVoiceConfig" + }, + "description": "Required. All the enabled speaker voices." } }, - "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`." + "type": "object" }, - "CountTokensResponse": { - "type": "object", + "LogprobsResult": { + "description": "Logprobs Result", "properties": { - "cachedContentTokenCount": { - "description": "Number of tokens in the cached part of the prompt (the cached content).", - "type": "integer", - "format": "int32" + "logProbabilitySum": { + "description": "Sum of log probabilities for all tokens.", + "type": "number", + "format": "float" }, - "cacheTokensDetails": { - "readOnly": true, + "topCandidates": { + "description": "Length = total number of decoding steps.", "type": "array", - "description": "Output only. List of modalities that were processed in the cached content.", "items": { - "$ref": "#/components/schemas/ModalityTokenCount" + "$ref": "#/components/schemas/TopCandidates" } }, - "totalTokens": { - "description": "The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative.", - "format": "int32", - "type": "integer" - }, - "promptTokensDetails": { - "description": "Output only. List of modalities that were processed in the request input.", + "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/ModalityTokenCount" - }, - "readOnly": true, - "type": "array" + "$ref": "#/components/schemas/LogprobsResultCandidate" + } } }, - "description": "A response from `CountTokens`. It returns the model's `token_count` for the `prompt`." + "type": "object" }, - "CodeExecutionResult": { - "description": "Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used.", + "AsyncBatchEmbedContentRequest": { "type": "object", + "description": "Request for an `AsyncBatchEmbedContent` operation.", "properties": { - "id": { - "type": "string", - "description": "Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id." - }, - "outcome": { - "type": "string", - "enum": [ - "OUTCOME_UNSPECIFIED", - "OUTCOME_OK", - "OUTCOME_FAILED", - "OUTCOME_DEADLINE_EXCEEDED" - ], - "description": "Required. Outcome of the code execution.", - "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." - ] - }, - "output": { - "type": "string", - "description": "Optional. Contains stdout when code execution is successful, stderr or other description otherwise." + "batch": { + "description": "Required. The batch to create.", + "$ref": "#/components/schemas/EmbedContentBatch" } } }, - "GenerateContentBatchOutput": { - "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.", "properties": { - "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 `GenerateContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests." + "parts": { + "description": "Ordered `Parts` that constitute a single message. Parts may have different MIME types.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Part" + } }, - "inlinedResponses": { - "readOnly": true, - "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.", - "$ref": "#/components/schemas/InlinedResponses" + "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": "The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field." + "type": "object" }, - "FunctionCall": { - "description": "A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values.", - "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`.", "properties": { "id": { + "description": "Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`.", + "type": "string" + }, + "toolType": { "type": "string", - "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`." + "description": "Required. The type of tool that was called.", + "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" + ] }, "args": { - "type": "object", + "description": "Optional. The tool call arguments. Example: {\"arg1\" : \"value1\", \"arg2\" : \"value2\" , ...}", "additionalProperties": { "description": "Properties of the object." }, - "description": "Optional. The function parameters and values in JSON object format." - }, - "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." + "type": "object" } - } + }, + "type": "object" }, - "TuningSnapshot": { + "EmbeddingUsageMetadata": { "type": "object", + "description": "Metadata on the usage of the embedding request.", "properties": { - "step": { - "description": "Output only. The tuning step.", - "readOnly": true, - "type": "integer", - "format": "int32" - }, - "epoch": { - "description": "Output only. The epoch this step was part of.", + "promptTokenCount": { "readOnly": true, "type": "integer", - "format": "int32" - }, - "meanLoss": { - "description": "Output only. The mean loss of the training examples for this step.", - "format": "float", - "readOnly": true, - "type": "number" + "format": "int32", + "description": "Output only. Number of tokens in the prompt." }, - "computeTime": { - "description": "Output only. The timestamp when this metric was computed.", - "format": "google-datetime", + "promptTokenDetails": { "readOnly": true, - "type": "string" - } - }, - "description": "Record for a single tuning step." - }, - "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", - "type": "object", - "properties": { - "whiteSpaceConfig": { - "$ref": "#/components/schemas/WhiteSpaceConfig", - "description": "White space chunking configuration." + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + }, + "description": "Output only. List of modalities that were processed in the request input." } } }, - "EmbedContentConfig": { - "type": "object", + "EmbedContentRequest": { + "description": "Request containing the `Content` for the model to embed.", "properties": { + "content": { + "description": "Required. The content to embed. Only the `parts.text` fields will be counted.", + "$ref": "#/components/schemas/Content" + }, + "embedContentConfig": { + "description": "Optional. Configuration for the EmbedContent request.", + "$ref": "#/components/schemas/EmbedContentConfig" + }, + "title": { + "deprecated": true, + "description": "Optional. Deprecated: Please use EmbedContentConfig.title instead. 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" + }, "outputDimensionality": { + "deprecated": true, + "description": "Optional. Deprecated: Please use EmbedContentConfig.output_dimensionality instead. 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`).", "type": "integer", - "format": "int32", - "description": "Optional. Reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end." - }, - "documentOcr": { - "type": "boolean", - "description": "Optional. Whether to enable OCR for document content." + "format": "int32" }, "taskType": { - "description": "Optional. The task type of the embedding.", + "description": "Optional. Deprecated: Please use EmbedContentConfig.task_type instead. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`).", "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.", @@ -6228,6 +6405,8 @@ "Specifies that the given text will be used for fact verification.", "Specifies that the given text will be used for code retrieval." ], + "type": "string", + "deprecated": true, "enum": [ "TASK_TYPE_UNSPECIFIED", "RETRIEVAL_QUERY", @@ -6238,453 +6417,274 @@ "QUESTION_ANSWERING", "FACT_VERIFICATION", "CODE_RETRIEVAL_QUERY" - ], - "type": "string" + ] }, - "title": { - "description": "Optional. The title for the text.", + "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" - }, - "audioTrackExtraction": { - "description": "Optional. Whether to extract audio from video content.", - "type": "boolean" - }, - "autoTruncate": { - "type": "boolean", - "description": "Optional. Whether to silently truncate the input content if it's longer than the maximum sequence length." } }, - "description": "Configurations for the EmbedContent request." + "type": "object" }, - "ListGeneratedFilesResponse": { - "description": "Response for `ListGeneratedFiles`.", + "ModalityTokenCount": { "type": "object", + "description": "Represents token counting info for a single modality.", "properties": { - "generatedFiles": { - "type": "array", - "description": "The list of `GeneratedFile`s.", - "items": { - "$ref": "#/components/schemas/GeneratedFile" - } + "tokenCount": { + "description": "Number of tokens.", + "type": "integer", + "format": "int32" }, - "nextPageToken": { - "type": "string", - "description": "A token that can be sent as a `page_token` into a subsequent `ListGeneratedFiles` call." - } - } - }, - "TuningTask": { - "description": "Tuning tasks that create tuned models.", - "type": "object", - "properties": { - "startTime": { - "description": "Output only. The timestamp when tuning this model started.", - "format": "google-datetime", - "readOnly": true, + "modality": { + "description": "The modality associated with this token count.", + "x-enum-descriptions": [ + "Unspecified modality.", + "Plain text.", + "Image.", + "Video.", + "Audio.", + "Document, e.g. PDF." + ], + "enum": [ + "MODALITY_UNSPECIFIED", + "TEXT", + "IMAGE", + "VIDEO", + "AUDIO", + "DOCUMENT" + ], "type": "string" - }, - "completeTime": { - "description": "Output only. The timestamp when tuning this model completed.", - "readOnly": true, - "type": "string", - "format": "google-datetime" - }, - "snapshots": { - "readOnly": true, - "type": "array", - "description": "Output only. Metrics collected during tuning.", - "items": { - "$ref": "#/components/schemas/TuningSnapshot" - } - }, - "trainingData": { - "$ref": "#/components/schemas/Dataset", - "description": "Required. Input only. Immutable. The model training data." - }, - "hyperparameters": { - "description": "Immutable. Hyperparameters controlling the tuning process. If not provided, default values will be used.", - "$ref": "#/components/schemas/Hyperparameters" } } }, - "FileSearch": { - "type": "object", - "properties": { - "fileSearchStoreNames": { - "type": "array", - "description": "Required. The names of the file_search_stores to retrieve from. Example: `fileSearchStores/my-file-search-store-123`", - "items": { - "type": "string" - } - }, - "topK": { - "format": "int32", - "type": "integer", - "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": "The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API." - }, - "SpeakerVoiceConfig": { - "description": "The configuration for a single speaker in a multi speaker setup.", + "EmbedContentResponse": { "type": "object", + "description": "The response to an `EmbedContentRequest`.", "properties": { - "speaker": { - "description": "Required. The name of the speaker to use. Should be the same as in the prompt.", - "type": "string" + "embedding": { + "description": "Output only. The embedding generated from the input content.", + "$ref": "#/components/schemas/ContentEmbedding", + "readOnly": true }, - "voiceConfig": { - "$ref": "#/components/schemas/VoiceConfig", - "description": "Required. The configuration for the voice to use." + "usageMetadata": { + "readOnly": true, + "description": "Output only. The usage metadata for the request.", + "$ref": "#/components/schemas/EmbeddingUsageMetadata" } } }, - "GroundingMetadata": { - "description": "Metadata returned to client when grounding is enabled.", + "GroundingChunk": { "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.", "properties": { - "googleMapsWidgetContextToken": { - "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.", - "type": "string" - }, - "searchEntryPoint": { - "$ref": "#/components/schemas/SearchEntryPoint", - "description": "Optional. Google search entry for the following-up web searches." - }, - "webSearchQueries": { - "description": "Web search queries for the following-up web search.", - "items": { - "type": "string" - }, - "type": "array" - }, - "retrievalMetadata": { - "description": "Metadata related to retrieval in the grounding flow.", - "$ref": "#/components/schemas/RetrievalMetadata" + "image": { + "description": "Optional. Grounding chunk from image search.", + "$ref": "#/components/schemas/Image" }, - "groundingSupports": { - "description": "List of grounding support.", - "items": { - "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaGroundingSupport" - }, - "type": "array" + "retrievedContext": { + "description": "Optional. Grounding chunk from context retrieved by the file search tool.", + "$ref": "#/components/schemas/RetrievedContext" }, - "imageSearchQueries": { - "description": "Image search queries used for grounding.", - "items": { - "type": "string" - }, - "type": "array" + "web": { + "description": "Grounding chunk from the web.", + "$ref": "#/components/schemas/Web" }, - "groundingChunks": { - "type": "array", - "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.", - "items": { - "$ref": "#/components/schemas/GroundingChunk" - } + "maps": { + "description": "Optional. Grounding chunk from Google Maps.", + "$ref": "#/components/schemas/Maps" } } }, - "UsageMetadata": { - "description": "Metadata on the generation request's token usage.", + "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": { - "toolUsePromptTokenCount": { - "description": "Output only. Number of tokens present in tool-use prompt(s).", - "format": "int32", - "readOnly": true, - "type": "integer" - }, - "serviceTier": { - "description": "Output only. Service tier of the request.", - "x-enum-descriptions": [ - "Default service tier, which is standard.", - "Standard service tier.", - "Flex service tier.", - "Priority service tier." - ], - "readOnly": true, - "type": "string", - "enum": [ - "unspecified", - "standard", - "flex", - "priority" - ] - }, - "thoughtsTokenCount": { - "description": "Output only. Number of tokens of thoughts for thinking models.", - "readOnly": true, - "type": "integer", - "format": "int32" - }, - "cacheTokensDetails": { - "description": "Output only. List of modalities of the cached content in the request input.", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - }, - "readOnly": true, - "type": "array" - }, - "cachedContentTokenCount": { - "description": "Number of tokens in the cached part of the prompt (the cached content)", - "type": "integer", - "format": "int32" - }, - "candidatesTokensDetails": { - "readOnly": true, - "type": "array", - "description": "Output only. List of modalities that were returned in the response.", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - } - }, - "toolUsePromptTokensDetails": { - "description": "Output only. List of modalities that were processed for tool-use request inputs.", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - }, - "readOnly": true, - "type": "array" - }, - "candidatesTokenCount": { - "format": "int32", - "type": "integer", - "description": "Total number of tokens across all the generated response candidates." - }, - "promptTokensDetails": { - "readOnly": true, - "type": "array", - "description": "Output only. List of modalities that were processed in the request input.", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - } - }, - "promptTokenCount": { + "code": { "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." - }, - "totalTokenCount": { - "description": "Total token count for the generation request (prompt + thoughts + response candidates).", - "type": "integer", - "format": "int32" + "description": "The status code, which should be an enum value of google.rpc.Code." }, - "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 + "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." }, - "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.", + "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", - "readOnly": true, "items": { - "$ref": "#/components/schemas/ModalityTokenCount" + "type": "object", + "additionalProperties": { + "description": "Properties of the object. Contains field @type with type URL." + } } } } }, - "GenerateContentResponse": { - "type": "object", + "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.", "properties": { - "candidates": { + "displayName": { + "description": "Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters.", + "type": "string" + }, + "tools": { + "description": "Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response", "type": "array", - "description": "Candidate responses from the model.", "items": { - "$ref": "#/components/schemas/Candidate" + "$ref": "#/components/schemas/Tool" } }, - "modelStatus": { - "readOnly": true, - "$ref": "#/components/schemas/ModelStatus", - "description": "Output only. The current model status of this model." + "toolConfig": { + "description": "Optional. Input only. Immutable. Tool config. This config is shared for all tools.", + "$ref": "#/components/schemas/ToolConfig" }, - "modelVersion": { + "model": { + "type": "string", + "description": "Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}`" + }, + "systemInstruction": { + "description": "Optional. Input only. Immutable. Developer set system instruction. Currently text only.", + "$ref": "#/components/schemas/Content" + }, + "contents": { + "description": "Optional. Input only. Immutable. The content to cache.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Content" + } + }, + "name": { "readOnly": true, "type": "string", - "description": "Output only. The model version used to generate the response." + "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`" }, - "promptFeedback": { - "description": "Returns the prompt's feedback related to the content filters.", - "$ref": "#/components/schemas/PromptFeedback" + "createTime": { + "description": "Output only. Creation time of the cache entry.", + "type": "string", + "format": "google-datetime", + "readOnly": true }, "usageMetadata": { - "readOnly": true, - "description": "Output only. Metadata on the generation requests' token usage.", - "$ref": "#/components/schemas/UsageMetadata" + "description": "Output only. Metadata on the usage of the cached content.", + "$ref": "#/components/schemas/CachedContentUsageMetadata", + "readOnly": true }, - "responseId": { + "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.", + "type": "string", + "format": "google-datetime" + }, + "ttl": { + "description": "Input only. New TTL for this resource, input only.", + "type": "string", + "format": "google-duration" + }, + "updateTime": { "readOnly": true, "type": "string", - "description": "Output only. response_id is used to identify each response." + "format": "google-datetime", + "description": "Output only. When the cache entry was last updated in UTC time." } }, - "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`." + "type": "object" }, - "ModelStatus": { - "type": "object", + "EmbedContentBatchOutput": { + "description": "The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field.", "properties": { - "modelStage": { - "enum": [ - "MODEL_STAGE_UNSPECIFIED", - "UNSTABLE_EXPERIMENTAL", - "EXPERIMENTAL", - "PREVIEW", - "STABLE", - "LEGACY", - "DEPRECATED", - "RETIRED" - ], - "type": "string", - "description": "The stage of the underlying model.", - "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." - ], - "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" - }, - "message": { - "description": "A message explaining the model status.", + "responsesFile": { + "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.", + "readOnly": true, "type": "string" + }, + "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.", + "$ref": "#/components/schemas/InlinedEmbedContentResponses", + "readOnly": true } }, - "description": "The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable." + "type": "object" }, - "FileData": { - "description": "URI based data.", + "BatchGenerateContentRequest": { "type": "object", + "description": "Request for a `BatchGenerateContent` operation.", "properties": { - "mimeType": { - "type": "string", - "description": "Optional. The IANA standard MIME type of the source data." - }, - "fileUri": { - "description": "Required. URI.", - "type": "string" + "batch": { + "description": "Required. The batch to create.", + "$ref": "#/components/schemas/GenerateContentBatch" } } }, - "ContentEmbedding": { - "type": "object", + "TopCandidates": { + "description": "Candidates with top log probabilities at each decoding step.", "properties": { - "values": { - "description": "The embedding values. This is for 3P users only and will not be populated for 1P calls.", - "items": { - "format": "float", - "type": "number" - }, - "type": "array" - }, - "shape": { + "candidates": { + "description": "Sorted by log probability in descending order.", "type": "array", - "description": "This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048]).", "items": { - "type": "integer", - "format": "int32" + "$ref": "#/components/schemas/LogprobsResultCandidate" } } }, - "description": "A list of floats representing an embedding." + "type": "object" }, - "SafetyRating": { + "InlinedEmbedContentResponse": { "type": "object", + "description": "The response to a single request in the batch.", "properties": { - "probability": { - "type": "string", - "description": "Required. The probability of harm for this content.", - "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." - ], - "enum": [ - "HARM_PROBABILITY_UNSPECIFIED", - "NEGLIGIBLE", - "LOW", - "MEDIUM", - "HIGH" - ] + "response": { + "readOnly": true, + "description": "Output only. The response to the request.", + "$ref": "#/components/schemas/EmbedContentResponse" }, - "blocked": { - "type": "boolean", - "description": "Was this content blocked because of this rating?" + "error": { + "description": "Output only. The error encountered while processing the request.", + "$ref": "#/components/schemas/Status", + "readOnly": true }, - "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" - ], - "type": "string", - "enumDeprecated": [ - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - true - ], - "description": "Required. The category for this rating.", - "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." - ] + "metadata": { + "type": "object", + "readOnly": true, + "additionalProperties": { + "description": "Properties of the object." + }, + "description": "Output only. The metadata associated with the request." } - }, - "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." + } + }, + "CachedContentUsageMetadata": { + "type": "object", + "description": "Metadata on the usage of the cached content.", + "properties": { + "totalTokenCount": { + "type": "integer", + "format": "int32", + "description": "Total number of tokens that the cached content consumes." + } + } + }, + "ListOperationsResponse": { + "type": "object", + "description": "The response message for Operations.ListOperations.", + "properties": { + "nextPageToken": { + "description": "The standard List next-page token.", + "type": "string" + }, + "operations": { + "description": "A list of operations that matches the specified filter in the request.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Operation" + } + }, + "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.", + "type": "array", + "items": { + "type": "string" + } + } + } } } }