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 147c23fc..32acb3b3 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 @@ -451,20 +451,20 @@ partial void ProcessBatchesUpdateEmbedContentBatchResponseContent( /// /// Configures the input to the batch request. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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. + /// + /// 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. /// - /// - /// Required. The user-defined name of this batch. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// - /// - /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. + /// + /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -473,22 +473,22 @@ partial void ProcessBatchesUpdateEmbedContentBatchResponseContent( string batchesId, string? updateMask = default, global::Google.Gemini.InputEmbedContentConfig? inputConfig = default, - string? model = default, - global::Google.Gemini.EmbedContentBatchOutput? output = default, - global::Google.Gemini.EmbedContentBatchStats? batchStats = default, string? displayName = default, string? priority = default, + global::Google.Gemini.EmbedContentBatchStats? batchStats = default, + string? model = default, + global::Google.Gemini.EmbedContentBatchOutput? output = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.EmbedContentBatch { InputConfig = inputConfig, - Model = model, - Output = output, - BatchStats = batchStats, DisplayName = displayName, Priority = priority, + BatchStats = batchStats, + Model = model, + Output = output, }; 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 db118338..a5f4579d 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 @@ -451,11 +451,8 @@ partial void ProcessBatchesUpdateGenerateContentBatchResponseContent( /// /// 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}`. + /// + /// Required. The user-defined name of this 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. @@ -463,8 +460,11 @@ partial void ProcessBatchesUpdateGenerateContentBatchResponseContent( /// /// Stats about the batch. /// - /// - /// Required. The user-defined name of this batch. + /// + /// 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. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -473,22 +473,22 @@ partial void ProcessBatchesUpdateGenerateContentBatchResponseContent( string batchesId, string? updateMask = default, global::Google.Gemini.InputConfig? inputConfig = default, - global::Google.Gemini.GenerateContentBatchOutput? output = default, - string? model = default, + string? displayName = default, string? priority = default, global::Google.Gemini.BatchStats? batchStats = default, - string? displayName = default, + string? model = default, + global::Google.Gemini.GenerateContentBatchOutput? output = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentBatch { InputConfig = inputConfig, - Output = output, - Model = model, + DisplayName = displayName, Priority = priority, BatchStats = batchStats, - DisplayName = displayName, + Model = model, + Output = output, }; return await BatchesUpdateGenerateContentBatchAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CachedContentsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CachedContentsCreate.g.cs index de377966..0955ada3 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 @@ -425,60 +425,60 @@ partial void ProcessCachedContentsCreateResponseContent( /// /// Creates CachedContent resource. /// + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Metadata on the usage of the cached content. + /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` /// /// /// 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. + /// + /// 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. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// + /// Input only. New TTL for this resource, input only. /// /// /// Optional. Input only. Immutable. The content to cache. /// - /// - /// Input only. New TTL for this resource, input only. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. /// /// /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// - /// - /// Metadata on the usage of the cached content. - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task CachedContentsCreateAsync( + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, string? model = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - string? displayName = default, - global::System.Collections.Generic.IList? contents = default, - string? ttl = default, global::Google.Gemini.Content? systemInstruction = default, + string? ttl = default, + global::System.Collections.Generic.IList? contents = default, + string? displayName = default, string? expireTime = default, - global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.CachedContent { + ToolConfig = toolConfig, + UsageMetadata = usageMetadata, Model = model, Tools = tools, - ToolConfig = toolConfig, - DisplayName = displayName, - Contents = contents, - Ttl = ttl, SystemInstruction = systemInstruction, + Ttl = ttl, + Contents = contents, + DisplayName = displayName, ExpireTime = expireTime, - UsageMetadata = usageMetadata, }; 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 60abd304..ffa7f55d 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 @@ -448,62 +448,62 @@ partial void ProcessCachedContentsPatchResponseContent( /// /// /// + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Metadata on the usage of the cached content. + /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` /// /// /// 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. + /// + /// 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. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// + /// Input only. New TTL for this resource, input only. /// /// /// Optional. Input only. Immutable. The content to cache. /// - /// - /// Input only. New TTL for this resource, input only. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. /// /// /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// - /// - /// Metadata on the usage of the cached content. - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task CachedContentsPatchAsync( string cachedContentsId, string? updateMask = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, string? model = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - string? displayName = default, - global::System.Collections.Generic.IList? contents = default, - string? ttl = default, global::Google.Gemini.Content? systemInstruction = default, + string? ttl = default, + global::System.Collections.Generic.IList? contents = default, + string? displayName = default, string? expireTime = default, - global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.CachedContent { + ToolConfig = toolConfig, + UsageMetadata = usageMetadata, Model = model, Tools = tools, - ToolConfig = toolConfig, - DisplayName = displayName, - Contents = contents, - Ttl = ttl, SystemInstruction = systemInstruction, + Ttl = ttl, + Contents = contents, + DisplayName = displayName, ExpireTime = expireTime, - UsageMetadata = usageMetadata, }; return await CachedContentsPatchAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CorporaPermissionsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CorporaPermissionsCreate.g.cs index fe472747..5e53cccf 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CorporaPermissionsCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CorporaPermissionsCreate.g.cs @@ -438,28 +438,28 @@ partial void ProcessCorporaPermissionsCreateResponseContent( /// /// Optional. Immutable. The type of the grantee. /// - /// - /// Required. The role granted by this 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. + /// /// 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 CorporaPermissionsCreateAsync( string corporaId, global::Google.Gemini.PermissionGranteeType? granteeType = default, - global::Google.Gemini.PermissionRole? role = default, string? emailAddress = default, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.Permission { GranteeType = granteeType, - Role = role, EmailAddress = emailAddress, + Role = role, }; return await CorporaPermissionsCreateAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CorporaPermissionsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CorporaPermissionsPatch.g.cs index 1d67f6ca..ed2f0c85 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CorporaPermissionsPatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CorporaPermissionsPatch.g.cs @@ -461,12 +461,12 @@ partial void ProcessCorporaPermissionsPatchResponseContent( /// /// Optional. Immutable. The type of the grantee. /// - /// - /// Required. The role granted by this 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. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// @@ -475,16 +475,16 @@ partial void ProcessCorporaPermissionsPatchResponseContent( string corporaId, string? updateMask = default, global::Google.Gemini.PermissionGranteeType? granteeType = default, - global::Google.Gemini.PermissionRole? role = default, string? emailAddress = default, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.Permission { GranteeType = granteeType, - Role = role, EmailAddress = emailAddress, + Role = role, }; return await CorporaPermissionsPatchAsync( 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 d1887ac1..592fe396 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 @@ -435,66 +435,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. /// /// + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// /// /// Optional. A list of 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}` - /// /// /// 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Optional. The service tier of the request. + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// Optional. The service tier of the request. + /// + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every 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 DynamicGenerateContentAsync( string dynamicId, + global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? safetySettings = default, - string? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, - global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, - string? model = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { + Contents = contents, SafetySettings = safetySettings, - CachedContent = cachedContent, SystemInstruction = systemInstruction, - GenerationConfig = generationConfig, - Contents = contents, - ServiceTier = serviceTier, - ToolConfig = toolConfig, - Tools = tools, - Model = model, + CachedContent = cachedContent, Store = store, + Model = model, + Tools = tools, + ToolConfig = toolConfig, + ServiceTier = serviceTier, + GenerationConfig = generationConfig, }; 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 97299752..284ed4bc 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 @@ -435,66 +435,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`. /// /// + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// /// /// Optional. A list of 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}` - /// /// /// 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Optional. The service tier of the request. + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// Optional. The service tier of the request. + /// + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every 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 DynamicStreamGenerateContentAsync( string dynamicId, + global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? safetySettings = default, - string? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, - global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, - string? model = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { + Contents = contents, SafetySettings = safetySettings, - CachedContent = cachedContent, SystemInstruction = systemInstruction, - GenerationConfig = generationConfig, - Contents = contents, - ServiceTier = serviceTier, - ToolConfig = toolConfig, - Tools = tools, - Model = model, + CachedContent = cachedContent, Store = store, + Model = model, + Tools = tools, + ToolConfig = toolConfig, + ServiceTier = serviceTier, + GenerationConfig = generationConfig, }; 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 f4182d40..a3f7ff4a 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 @@ -376,66 +376,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`. /// /// + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// /// /// Optional. A list of 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}` - /// /// /// 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Optional. The service tier of the request. + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// Optional. The service tier of the request. + /// + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every 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.Collections.Generic.IAsyncEnumerable DynamicStreamGenerateContentAsStreamAsync( string dynamicId, + global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? safetySettings = default, - string? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, - global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, - string? model = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = 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 { + Contents = contents, SafetySettings = safetySettings, - CachedContent = cachedContent, SystemInstruction = systemInstruction, - GenerationConfig = generationConfig, - Contents = contents, - ServiceTier = serviceTier, - ToolConfig = toolConfig, - Tools = tools, - Model = model, + CachedContent = cachedContent, Store = store, + Model = model, + Tools = tools, + ToolConfig = toolConfig, + ServiceTier = serviceTier, + GenerationConfig = generationConfig, }; 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 7dac3545..9f8368aa 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 @@ -425,25 +425,25 @@ partial void ProcessFileSearchStoresCreateResponseContent( /// /// Creates an empty `FileSearchStore`. /// - /// - /// 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" /// + /// + /// 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. + /// /// 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? embeddingModel = default, string? displayName = default, + string? embeddingModel = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.FileSearchStore { - EmbeddingModel = embeddingModel, DisplayName = displayName, + EmbeddingModel = embeddingModel, }; 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 a0d6436c..ecbb3a1f 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 @@ -435,31 +435,31 @@ partial void ProcessFileSearchStoresImportFileResponseContent( /// Imports a `File` from File Service to a `FileSearchStore`. /// /// - /// - /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto - /// /// /// Custom metadata to be associated with the file. /// /// /// Required. The name of the `File` to import. Example: `files/abc-123` /// + /// + /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto + /// /// 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, global::System.Collections.Generic.IList? customMetadata = default, string? fileName = default, + global::Google.Gemini.ChunkingConfig? chunkingConfig = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.ImportFileRequest { - ChunkingConfig = chunkingConfig, CustomMetadata = customMetadata, FileName = fileName, + ChunkingConfig = chunkingConfig, }; return await FileSearchStoresImportFileAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsCountTokens.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsCountTokens.g.cs index fee650dd..e1d939a4 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsCountTokens.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsCountTokens.g.cs @@ -435,26 +435,26 @@ partial void ProcessModelsCountTokensResponseContent( /// 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. /// /// - /// - /// Optional. The input given to the model as a prompt. This field is ignored when `generate_content_request` is set. - /// /// /// Request to generate a completion from the model. /// + /// + /// Optional. The input given to the model as a prompt. This field is ignored when `generate_content_request` is set. + /// /// 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 ModelsCountTokensAsync( string modelsId, - global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.GenerateContentRequest? generateContentRequest = default, + global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.CountTokensRequest { - Contents = contents, GenerateContentRequest = generateContentRequest, + Contents = contents, }; return await ModelsCountTokensAsync( 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 0c05e1f5..c4e0cb91 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 @@ -437,31 +437,31 @@ partial void ProcessModelsEmbedContentResponseContent( /// Generates a text embedding vector from the input `Content` using the specified [Gemini Embedding model](https://ai.google.dev/gemini-api/docs/models/gemini#text-embedding). /// /// - /// - /// 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}` /// /// /// 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. /// + /// + /// Configurations for the EmbedContent request. + /// /// 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.EmbedContentConfig? embedContentConfig = default, string? model = default, global::Google.Gemini.Content? content = default, + global::Google.Gemini.EmbedContentConfig? embedContentConfig = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.EmbedContentRequest { - EmbedContentConfig = embedContentConfig, Model = model, Content = content, + EmbedContentConfig = embedContentConfig, }; 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 075e6719..2cd48438 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 @@ -435,66 +435,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. /// /// + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// /// /// Optional. A list of 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}` - /// /// /// 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Optional. The service tier of the request. + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// Optional. The service tier of the request. + /// + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every 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 ModelsGenerateContentAsync( string modelsId, + global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? safetySettings = default, - string? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, - global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, - string? model = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { + Contents = contents, SafetySettings = safetySettings, - CachedContent = cachedContent, SystemInstruction = systemInstruction, - GenerationConfig = generationConfig, - Contents = contents, - ServiceTier = serviceTier, - ToolConfig = toolConfig, - Tools = tools, - Model = model, + CachedContent = cachedContent, Store = store, + Model = model, + Tools = tools, + ToolConfig = toolConfig, + ServiceTier = serviceTier, + GenerationConfig = generationConfig, }; 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 a3b75809..cf9b44d8 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 @@ -435,66 +435,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`. /// /// + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// /// /// Optional. A list of 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}` - /// /// /// 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Optional. The service tier of the request. + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// Optional. The service tier of the request. + /// + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every 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 ModelsStreamGenerateContentAsync( string modelsId, + global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? safetySettings = default, - string? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, - global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, - string? model = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { + Contents = contents, SafetySettings = safetySettings, - CachedContent = cachedContent, SystemInstruction = systemInstruction, - GenerationConfig = generationConfig, - Contents = contents, - ServiceTier = serviceTier, - ToolConfig = toolConfig, - Tools = tools, - Model = model, + CachedContent = cachedContent, Store = store, + Model = model, + Tools = tools, + ToolConfig = toolConfig, + ServiceTier = serviceTier, + GenerationConfig = generationConfig, }; 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 d34221ec..af433667 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 @@ -376,66 +376,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`. /// /// + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// /// /// Optional. A list of 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}` - /// /// /// 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Optional. The service tier of the request. + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// Optional. The service tier of the request. + /// + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every 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.Collections.Generic.IAsyncEnumerable ModelsStreamGenerateContentAsStreamAsync( string modelsId, + global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? safetySettings = default, - string? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, - global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, - string? model = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = 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 { + Contents = contents, SafetySettings = safetySettings, - CachedContent = cachedContent, SystemInstruction = systemInstruction, - GenerationConfig = generationConfig, - Contents = contents, - ServiceTier = serviceTier, - ToolConfig = toolConfig, - Tools = tools, - Model = model, + CachedContent = cachedContent, Store = store, + Model = model, + Tools = tools, + ToolConfig = toolConfig, + ServiceTier = serviceTier, + GenerationConfig = generationConfig, }; 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 c11364fd..38423358 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 @@ -438,61 +438,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` - /// - /// - /// Optional. A short description of this 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. 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. - /// - /// - /// Tuning tasks that create tuned models. - /// /// /// 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. List of project numbers that have read access to the tuned 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. List of project numbers that have read access to the tuned model. + /// + /// Tuning tasks that create tuned models. + /// + /// + /// 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. /// /// /// Tuned model as a source for training a new model. /// + /// + /// Optional. A short description of this model. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task TunedModelsCreateAsync( string? tunedModelId = default, - string? baseModel = default, - string? description = default, float? topP = default, - float? temperature = default, - global::Google.Gemini.TuningTask? tuningTask = default, int? topK = default, - string? displayName = default, global::System.Collections.Generic.IList? readerProjectNumbers = default, + string? baseModel = default, + string? displayName = default, + global::Google.Gemini.TuningTask? tuningTask = default, + float? temperature = default, global::Google.Gemini.TunedModelSource? tunedModelSource = default, + string? description = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.TunedModel { - BaseModel = baseModel, - Description = description, TopP = topP, - Temperature = temperature, - TuningTask = tuningTask, TopK = topK, - DisplayName = displayName, ReaderProjectNumbers = readerProjectNumbers, + BaseModel = baseModel, + DisplayName = displayName, + TuningTask = tuningTask, + Temperature = temperature, TunedModelSource = tunedModelSource, + Description = description, }; 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 ed5d174b..ca0131b8 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 @@ -435,66 +435,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. /// /// + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// /// /// Optional. A list of 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}` - /// /// /// 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Optional. The service tier of the request. + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// Optional. The service tier of the request. + /// + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every 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 TunedModelsGenerateContentAsync( string tunedModelsId, + global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? safetySettings = default, - string? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, - global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, - string? model = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { + Contents = contents, SafetySettings = safetySettings, - CachedContent = cachedContent, SystemInstruction = systemInstruction, - GenerationConfig = generationConfig, - Contents = contents, - ServiceTier = serviceTier, - ToolConfig = toolConfig, - Tools = tools, - Model = model, + CachedContent = cachedContent, Store = store, + Model = model, + Tools = tools, + ToolConfig = toolConfig, + ServiceTier = serviceTier, + GenerationConfig = generationConfig, }; 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 6a2a98af..90c8b6bb 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 @@ -448,62 +448,62 @@ partial void ProcessTunedModelsPatchResponseContent( /// /// /// - /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` - /// - /// - /// Optional. A short description of this 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. 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. - /// - /// - /// Tuning tasks that create tuned models. - /// /// /// 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. List of project numbers that have read access to the tuned 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. List of project numbers that have read access to the tuned model. + /// + /// Tuning tasks that create tuned models. + /// + /// + /// 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. /// /// /// Tuned model as a source for training a new model. /// + /// + /// Optional. A short description of this 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 TunedModelsPatchAsync( string tunedModelsId, string? updateMask = default, - string? baseModel = default, - string? description = default, float? topP = default, - float? temperature = default, - global::Google.Gemini.TuningTask? tuningTask = default, int? topK = default, - string? displayName = default, global::System.Collections.Generic.IList? readerProjectNumbers = default, + string? baseModel = default, + string? displayName = default, + global::Google.Gemini.TuningTask? tuningTask = default, + float? temperature = default, global::Google.Gemini.TunedModelSource? tunedModelSource = default, + string? description = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.TunedModel { - BaseModel = baseModel, - Description = description, TopP = topP, - Temperature = temperature, - TuningTask = tuningTask, TopK = topK, - DisplayName = displayName, ReaderProjectNumbers = readerProjectNumbers, + BaseModel = baseModel, + DisplayName = displayName, + TuningTask = tuningTask, + Temperature = temperature, TunedModelSource = tunedModelSource, + Description = description, }; return await TunedModelsPatchAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPermissionsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPermissionsCreate.g.cs index afe70489..9e0209cf 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPermissionsCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPermissionsCreate.g.cs @@ -438,28 +438,28 @@ partial void ProcessTunedModelsPermissionsCreateResponseContent( /// /// Optional. Immutable. The type of the grantee. /// - /// - /// Required. The role granted by this 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. + /// /// 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 TunedModelsPermissionsCreateAsync( string tunedModelsId, global::Google.Gemini.PermissionGranteeType? granteeType = default, - global::Google.Gemini.PermissionRole? role = default, string? emailAddress = default, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.Permission { GranteeType = granteeType, - Role = role, EmailAddress = emailAddress, + Role = role, }; return await TunedModelsPermissionsCreateAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPermissionsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPermissionsPatch.g.cs index 6e969712..2e627ccb 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPermissionsPatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPermissionsPatch.g.cs @@ -461,12 +461,12 @@ partial void ProcessTunedModelsPermissionsPatchResponseContent( /// /// Optional. Immutable. The type of the grantee. /// - /// - /// Required. The role granted by this 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. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// @@ -475,16 +475,16 @@ partial void ProcessTunedModelsPermissionsPatchResponseContent( string permissionsId, string? updateMask = default, global::Google.Gemini.PermissionGranteeType? granteeType = default, - global::Google.Gemini.PermissionRole? role = default, string? emailAddress = default, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.Permission { GranteeType = granteeType, - Role = role, EmailAddress = emailAddress, + Role = role, }; return await TunedModelsPermissionsPatchAsync( 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 7af571c6..703862ec 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 @@ -435,66 +435,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`. /// /// + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// /// /// Optional. A list of 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}` - /// /// /// 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Optional. The service tier of the request. + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// Optional. The service tier of the request. + /// + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every 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 TunedModelsStreamGenerateContentAsync( string tunedModelsId, + global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? safetySettings = default, - string? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, - global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, - string? model = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { + Contents = contents, SafetySettings = safetySettings, - CachedContent = cachedContent, SystemInstruction = systemInstruction, - GenerationConfig = generationConfig, - Contents = contents, - ServiceTier = serviceTier, - ToolConfig = toolConfig, - Tools = tools, - Model = model, + CachedContent = cachedContent, Store = store, + Model = model, + Tools = tools, + ToolConfig = toolConfig, + ServiceTier = serviceTier, + GenerationConfig = generationConfig, }; 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 ffadd83d..30f6ccb4 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 @@ -376,66 +376,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`. /// /// + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// /// /// Optional. A list of 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}` - /// /// /// 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Optional. The service tier of the request. + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// Optional. The service tier of the request. + /// + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every 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.Collections.Generic.IAsyncEnumerable TunedModelsStreamGenerateContentAsStreamAsync( string tunedModelsId, + global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? safetySettings = default, - string? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, - global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, - string? model = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = 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 { + Contents = contents, SafetySettings = safetySettings, - CachedContent = cachedContent, SystemInstruction = systemInstruction, - GenerationConfig = generationConfig, - Contents = contents, - ServiceTier = serviceTier, - ToolConfig = toolConfig, - Tools = tools, - Model = model, + CachedContent = cachedContent, Store = store, + Model = model, + Tools = tools, + ToolConfig = toolConfig, + ServiceTier = serviceTier, + GenerationConfig = generationConfig, }; 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 a4aa4934..883e4c17 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 @@ -44,20 +44,20 @@ public partial interface IGeminiClient /// /// Configures the input to the batch request. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// 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. + /// + /// 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. /// - /// - /// Required. The user-defined name of this batch. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// - /// - /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. + /// + /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -66,11 +66,11 @@ public partial interface IGeminiClient string batchesId, string? updateMask = default, global::Google.Gemini.InputEmbedContentConfig? inputConfig = default, - string? model = default, - global::Google.Gemini.EmbedContentBatchOutput? output = default, - global::Google.Gemini.EmbedContentBatchStats? batchStats = default, string? displayName = default, string? priority = default, + global::Google.Gemini.EmbedContentBatchStats? batchStats = default, + string? model = default, + global::Google.Gemini.EmbedContentBatchOutput? output = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.BatchesUpdateGenerateContentBatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.BatchesUpdateGenerateContentBatch.g.cs index 592e5ff6..456a933a 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 @@ -44,11 +44,8 @@ public partial interface IGeminiClient /// /// 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}`. + /// + /// Required. The user-defined name of this 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. @@ -56,8 +53,11 @@ public partial interface IGeminiClient /// /// Stats about the batch. /// - /// - /// Required. The user-defined name of this batch. + /// + /// 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. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -66,11 +66,11 @@ public partial interface IGeminiClient string batchesId, string? updateMask = default, global::Google.Gemini.InputConfig? inputConfig = default, - global::Google.Gemini.GenerateContentBatchOutput? output = default, - string? model = default, + string? displayName = default, string? priority = default, global::Google.Gemini.BatchStats? batchStats = default, - string? displayName = default, + string? model = default, + global::Google.Gemini.GenerateContentBatchOutput? output = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsCreate.g.cs index 8457e582..68680c8e 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,46 +31,46 @@ public partial interface IGeminiClient /// /// Creates CachedContent resource. /// + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Metadata on the usage of the cached content. + /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` /// /// /// 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. + /// + /// 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. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// + /// Input only. New TTL for this resource, input only. /// /// /// Optional. Input only. Immutable. The content to cache. /// - /// - /// Input only. New TTL for this resource, input only. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. /// /// /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// - /// - /// Metadata on the usage of the cached content. - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task CachedContentsCreateAsync( + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, string? model = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - string? displayName = default, - global::System.Collections.Generic.IList? contents = default, - string? ttl = default, global::Google.Gemini.Content? systemInstruction = default, + string? ttl = default, + global::System.Collections.Generic.IList? contents = default, + string? displayName = default, string? expireTime = default, - global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = 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 0ced59ee..b438e0fe 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,48 +41,48 @@ public partial interface IGeminiClient /// /// /// + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Metadata on the usage of the cached content. + /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` /// /// /// 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. + /// + /// 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. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// + /// Input only. New TTL for this resource, input only. /// /// /// Optional. Input only. Immutable. The content to cache. /// - /// - /// Input only. New TTL for this resource, input only. - /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. /// /// /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// - /// - /// Metadata on the usage of the cached content. - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task CachedContentsPatchAsync( string cachedContentsId, string? updateMask = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, string? model = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - string? displayName = default, - global::System.Collections.Generic.IList? contents = default, - string? ttl = default, global::Google.Gemini.Content? systemInstruction = default, + string? ttl = default, + global::System.Collections.Generic.IList? contents = default, + string? displayName = default, string? expireTime = default, - global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsCreate.g.cs index 8736c8ac..742c7e66 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsCreate.g.cs @@ -39,20 +39,20 @@ public partial interface IGeminiClient /// /// Optional. Immutable. The type of the grantee. /// - /// - /// Required. The role granted by this 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. + /// /// 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 CorporaPermissionsCreateAsync( string corporaId, global::Google.Gemini.PermissionGranteeType? granteeType = default, - global::Google.Gemini.PermissionRole? role = default, string? emailAddress = default, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsPatch.g.cs index 674f1dfe..b57a43d0 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsPatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsPatch.g.cs @@ -49,12 +49,12 @@ public partial interface IGeminiClient /// /// Optional. Immutable. The type of the grantee. /// - /// - /// Required. The role granted by this 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. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// @@ -63,8 +63,8 @@ public partial interface IGeminiClient string corporaId, string? updateMask = default, global::Google.Gemini.PermissionGranteeType? granteeType = default, - global::Google.Gemini.PermissionRole? role = default, string? emailAddress = default, + global::Google.Gemini.PermissionRole? role = 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 dc560806..2b249f32 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. /// /// + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// /// /// Optional. A list of 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}` - /// /// /// 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Optional. The service tier of the request. + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// Optional. The service tier of the request. + /// + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every 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 DynamicGenerateContentAsync( string dynamicId, + global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? safetySettings = default, - string? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, - global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, - string? model = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = 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 fa32dab8..e625995b 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`. /// /// + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// /// /// Optional. A list of 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}` - /// /// /// 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Optional. The service tier of the request. + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// Optional. The service tier of the request. + /// + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every 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 DynamicStreamGenerateContentAsync( string dynamicId, + global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? safetySettings = default, - string? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, - global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, - string? model = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = 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 bf770996..3eed236c 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`. /// /// + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// /// /// Optional. A list of 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}` - /// /// /// 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Optional. The service tier of the request. + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// Optional. The service tier of the request. + /// + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// 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? contents = default, global::System.Collections.Generic.IList? safetySettings = default, - string? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, - global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, - string? model = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = 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 456dc9c7..9edab07f 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 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" /// + /// + /// 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. + /// /// 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? embeddingModel = default, string? displayName = default, + string? embeddingModel = 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 0b601d4b..e31c28d5 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 @@ -36,23 +36,23 @@ public partial interface IGeminiClient /// Imports a `File` from File Service to a `FileSearchStore`. /// /// - /// - /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto - /// /// /// Custom metadata to be associated with the file. /// /// /// Required. The name of the `File` to import. Example: `files/abc-123` /// + /// + /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto + /// /// 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, global::System.Collections.Generic.IList? customMetadata = default, string? fileName = default, + global::Google.Gemini.ChunkingConfig? chunkingConfig = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsCountTokens.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsCountTokens.g.cs index a6d6ed6c..e386931b 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsCountTokens.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsCountTokens.g.cs @@ -36,19 +36,19 @@ public partial interface IGeminiClient /// 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. /// /// - /// - /// Optional. The input given to the model as a prompt. This field is ignored when `generate_content_request` is set. - /// /// /// Request to generate a completion from the model. /// + /// + /// Optional. The input given to the model as a prompt. This field is ignored when `generate_content_request` is set. + /// /// 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 ModelsCountTokensAsync( string modelsId, - global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.GenerateContentRequest? generateContentRequest = default, + global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsEmbedContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsEmbedContent.g.cs index 39678846..2f5b194e 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 @@ -38,23 +38,23 @@ public partial interface IGeminiClient /// Generates a text embedding vector from the input `Content` using the specified [Gemini Embedding model](https://ai.google.dev/gemini-api/docs/models/gemini#text-embedding). /// /// - /// - /// 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}` /// /// /// 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. /// + /// + /// Configurations for the EmbedContent request. + /// /// 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.EmbedContentConfig? embedContentConfig = default, string? model = default, global::Google.Gemini.Content? content = default, + global::Google.Gemini.EmbedContentConfig? embedContentConfig = 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 d2006c07..4b190183 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. /// /// + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// /// /// Optional. A list of 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}` - /// /// /// 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Optional. The service tier of the request. + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// Optional. The service tier of the request. + /// + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every 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 ModelsGenerateContentAsync( string modelsId, + global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? safetySettings = default, - string? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, - global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, - string? model = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = 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 c45c90d9..a206ee2f 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`. /// /// + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// /// /// Optional. A list of 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}` - /// /// /// 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Optional. The service tier of the request. + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// Optional. The service tier of the request. + /// + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every 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 ModelsStreamGenerateContentAsync( string modelsId, + global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? safetySettings = default, - string? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, - global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, - string? model = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = 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 f27c43a9..87b7712c 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`. /// /// + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// /// /// Optional. A list of 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}` - /// /// /// 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Optional. The service tier of the request. + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// Optional. The service tier of the request. + /// + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// 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? contents = default, global::System.Collections.Generic.IList? safetySettings = default, - string? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, - global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, - string? model = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = 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 705874ef..29a1446c 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` - /// - /// - /// Optional. A short description of this 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. 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. - /// - /// - /// Tuning tasks that create tuned models. - /// /// /// 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. List of project numbers that have read access to the tuned 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. List of project numbers that have read access to the tuned model. + /// + /// Tuning tasks that create tuned models. + /// + /// + /// 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. /// /// /// Tuned model as a source for training a new model. /// + /// + /// Optional. A short description of this model. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task TunedModelsCreateAsync( string? tunedModelId = default, - string? baseModel = default, - string? description = default, float? topP = default, - float? temperature = default, - global::Google.Gemini.TuningTask? tuningTask = default, int? topK = default, - string? displayName = default, global::System.Collections.Generic.IList? readerProjectNumbers = default, + string? baseModel = default, + string? displayName = default, + global::Google.Gemini.TuningTask? tuningTask = default, + float? temperature = default, global::Google.Gemini.TunedModelSource? tunedModelSource = default, + string? description = 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 f80933ec..926e16ee 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. /// /// + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// /// /// Optional. A list of 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}` - /// /// /// 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Optional. The service tier of the request. + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// Optional. The service tier of the request. + /// + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every 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 TunedModelsGenerateContentAsync( string tunedModelsId, + global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? safetySettings = default, - string? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, - global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, - string? model = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = 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 523b6e9b..8e0d14f6 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` - /// - /// - /// Optional. A short description of this 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. 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. - /// - /// - /// Tuning tasks that create tuned models. - /// /// /// 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. List of project numbers that have read access to the tuned 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. List of project numbers that have read access to the tuned model. + /// + /// Tuning tasks that create tuned models. + /// + /// + /// 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. /// /// /// Tuned model as a source for training a new model. /// + /// + /// Optional. A short description of this 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 TunedModelsPatchAsync( string tunedModelsId, string? updateMask = default, - string? baseModel = default, - string? description = default, float? topP = default, - float? temperature = default, - global::Google.Gemini.TuningTask? tuningTask = default, int? topK = default, - string? displayName = default, global::System.Collections.Generic.IList? readerProjectNumbers = default, + string? baseModel = default, + string? displayName = default, + global::Google.Gemini.TuningTask? tuningTask = default, + float? temperature = default, global::Google.Gemini.TunedModelSource? tunedModelSource = default, + string? description = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPermissionsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPermissionsCreate.g.cs index 5c5f33eb..6d247e33 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPermissionsCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPermissionsCreate.g.cs @@ -39,20 +39,20 @@ public partial interface IGeminiClient /// /// Optional. Immutable. The type of the grantee. /// - /// - /// Required. The role granted by this 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. + /// /// 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 TunedModelsPermissionsCreateAsync( string tunedModelsId, global::Google.Gemini.PermissionGranteeType? granteeType = default, - global::Google.Gemini.PermissionRole? role = default, string? emailAddress = default, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPermissionsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPermissionsPatch.g.cs index 9e3910e8..065efa6e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPermissionsPatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPermissionsPatch.g.cs @@ -49,12 +49,12 @@ public partial interface IGeminiClient /// /// Optional. Immutable. The type of the grantee. /// - /// - /// Required. The role granted by this 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. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// @@ -63,8 +63,8 @@ public partial interface IGeminiClient string permissionsId, string? updateMask = default, global::Google.Gemini.PermissionGranteeType? granteeType = default, - global::Google.Gemini.PermissionRole? role = default, string? emailAddress = default, + global::Google.Gemini.PermissionRole? role = 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 bfa63467..11e279c0 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`. /// /// + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// /// /// Optional. A list of 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}` - /// /// /// 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Optional. The service tier of the request. + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// Optional. The service tier of the request. + /// + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every 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 TunedModelsStreamGenerateContentAsync( string tunedModelsId, + global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? safetySettings = default, - string? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, - global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, - string? model = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = 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 691d0455..f3440795 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`. /// /// + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// /// /// Optional. A list of 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}` - /// /// /// 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Optional. The service tier of the request. + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// Optional. The service tier of the request. + /// + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// 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? contents = default, global::System.Collections.Generic.IList? safetySettings = default, - string? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, - global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, - string? model = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = 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 4a6cb5b5..cd102323 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContext.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContext.g.cs @@ -13,477 +13,477 @@ namespace Google.Gemini DefaultIgnoreCondition = global::System.Text.Json.Serialization.JsonIgnoreCondition.WhenWritingNull, Converters = new global::System.Type[] { - typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatMimeTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatMimeTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatAspectRatioJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatAspectRatioNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryNullableJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatImageSizeJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatImageSizeNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusJsonConverter), typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileSourceJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileSourceNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityJsonConverter), + typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.TextResponseFormatMimeTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DocumentStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.TextResponseFormatMimeTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DocumentStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeNullableJsonConverter), + 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.CodeExecutionResultOutcomeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityJsonConverter), - typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionRoleJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionRoleNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ComputerUseDisabledSafetyPolicieJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ComputerUseDisabledSafetyPolicieNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SchemaTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SchemaTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateJsonConverter), typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileSourceJsonConverter), + typeof(global::Google.Gemini.JsonConverters.TextResponseFormatMimeTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileSourceNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.TextResponseFormatMimeTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.TunedModelStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.TunedModelStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeNullableJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.PermissionRoleJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.PermissionRoleNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeJsonConverter), typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonJsonConverter), + typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatMimeTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatMimeTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatDeliveryJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatDeliveryNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DocumentStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DocumentStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierJsonConverter), typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.TunedModelStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.TunedModelStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateNullableJsonConverter), - 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.AudioResponseFormatDeliveryJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatDeliveryNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatMimeTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ComputerUseDisabledSafetyPolicieJsonConverter), - typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatMimeTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ComputerUseDisabledSafetyPolicieNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieJsonConverter), typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SchemaTypeJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.SchemaTypeNullableJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryNullableJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatMimeTypeJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatMimeTypeNullableJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatAspectRatioJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatAspectRatioNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatImageSizeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatImageSizeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateJsonConverter), typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeNullableJsonConverter), + 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.TransferOwnershipRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormat))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormatMimeType), TypeInfoPropertyName = "ImageResponseFormatMimeType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormatAspectRatio), TypeInfoPropertyName = "ImageResponseFormatAspectRatio2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormatDelivery), TypeInfoPropertyName = "ImageResponseFormatDelivery2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormatImageSize), TypeInfoPropertyName = "ImageResponseFormatImageSize2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchOutput))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(string))] - [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.ModelStatus))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatusModelStage), TypeInfoPropertyName = "ModelStatusModelStage2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunk))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Web))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Image))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievedContext))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Maps))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievalMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(float))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(bool))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentConfigTaskType), TypeInfoPropertyName = "EmbedContentConfigTaskType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(int))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleSearchRetrieval))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DynamicRetrievalConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedback))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedbackBlockReason), TypeInfoPropertyName = "PromptFeedbackBlockReason2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetyRating))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SearchEntryPoint))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(byte[]))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [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.InlinedEmbedContentResponses))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecution))] + [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(object))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Hyperparameters))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchGenerateContentRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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::System.Collections.Generic.IList))] [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.InlinedRequests))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedRequest))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CachedContent))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CachedContentUsageMetadata))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Tool))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Content))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CachedContentUsageMetadata))] - [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.Interval))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleMaps))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatchOutput))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbeddingUsageMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModalityTokenCount))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListFilesResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.File))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PlaceAnswerSources))] + [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.UrlMetadataUrlRetrievalStatus), TypeInfoPropertyName = "UrlMetadataUrlRetrievalStatus2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponsePart))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponseScheduling), TypeInfoPropertyName = "FunctionResponseScheduling2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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.WebSearch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetySetting))] - [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.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(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.Operation))] + [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.ReviewSnippet))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.File))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VideoFileMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileState), TypeInfoPropertyName = "FileState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSource), TypeInfoPropertyName = "FileSource2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Status))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ChunkingConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.WhiteSpaceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Empty))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UploadToFileSearchStoreRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(byte[]))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCall))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionDeclaration))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionDeclarationBehavior), TypeInfoPropertyName = "FunctionDeclarationBehavior2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Schema))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TranslationConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(bool))] + [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(double))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(int))] + [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.GroundingAttribution))] + [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.SafetyRating))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlContextMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CandidateFinishReason), TypeInfoPropertyName = "CandidateFinishReason2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CustomLongRunningOperation))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Web))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PrebuiltVoiceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.McpServer))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.StreamableHttpTransport))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TopCandidates))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LogprobsResultCandidate))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Blob))] + [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::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.ModalityTokenCountModality), TypeInfoPropertyName = "ModalityTokenCountModality2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.StringList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CustomLongRunningOperation))] - [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.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.TextResponseFormat))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TextResponseFormatMimeType), TypeInfoPropertyName = "TextResponseFormatMimeType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DynamicRetrievalConfigMode), TypeInfoPropertyName = "DynamicRetrievalConfigMode2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InputEmbedContentConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentRequests))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Model))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(float))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SearchEntryPoint))] + [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.ThinkingConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ThinkingConfigThinkingLevel), TypeInfoPropertyName = "ThinkingConfigThinkingLevel2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingPassageId))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievalMetadata))] + [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.VideoMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(double))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlContext))] + [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.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.GoogleAiGenerativelanguageV1betaSegment))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCallingConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievalConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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.ModelStatus))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatusModelStage), TypeInfoPropertyName = "ModelStatusModelStage2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PlaceAnswerSources))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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.EmbedContentBatchStats))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CitationSource))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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.ToolCall))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCallToolType), TypeInfoPropertyName = "ToolCallToolType2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetySetting))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentRequestServiceTier), TypeInfoPropertyName = "GenerateContentRequestServiceTier2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkStringList))] [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.CodeExecution))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SpeakerVoiceConfig))] - [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.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.Dataset))] + [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::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.TuningExamples))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResult))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResultOutcome), TypeInfoPropertyName = "CodeExecutionResultOutcome2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SemanticRetrieverChunk))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Corpus))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LatLng))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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::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.Permission))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PermissionGranteeType), TypeInfoPropertyName = "PermissionGranteeType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PermissionRole), TypeInfoPropertyName = "PermissionRole2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingPassageId))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LatLng))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponsePart))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponseScheduling), TypeInfoPropertyName = "FunctionResponseScheduling2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.Dictionary))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SchemaType), TypeInfoPropertyName = "SchemaType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponseBlob))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.StringList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningSnapshot))] + [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.CountTokensRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleSearchRetrieval))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlContext))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleMaps))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUseDisabledSafetyPolicie), TypeInfoPropertyName = "ComputerUseDisabledSafetyPolicie2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUseEnvironment), TypeInfoPropertyName = "ComputerUseEnvironment2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentResponse))] - [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.ToolResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponseToolType), TypeInfoPropertyName = "ToolResponseToolType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkStringList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedback))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedbackBlockReason), TypeInfoPropertyName = "PromptFeedbackBlockReason2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AttributionSourceId))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SemanticRetrieverChunk))] [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.GenerateContentResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ThinkingConfig))] - [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.EmbedContentBatchState), TypeInfoPropertyName = "EmbedContentBatchState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InputEmbedContentConfig))] - [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.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.CreateFileResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSource), TypeInfoPropertyName = "FileSource2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VideoFileMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileState), TypeInfoPropertyName = "FileState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetyRatingProbability), TypeInfoPropertyName = "SafetyRatingProbability2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetyRatingCategory), TypeInfoPropertyName = "SafetyRatingCategory2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCallingConfigMode), TypeInfoPropertyName = "FunctionCallingConfigMode2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchState), TypeInfoPropertyName = "EmbedContentBatchState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TextResponseFormat))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TextResponseFormatMimeType), TypeInfoPropertyName = "TextResponseFormatMimeType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModel))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModelState), TypeInfoPropertyName = "TunedModelState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningTask))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModelSource))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSearch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesRequest))] - [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.InlinedRequests))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleSearch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SearchTypes))] - [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::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.Blob))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Candidate))] - [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.GroundingAttribution))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CandidateFinishReason), TypeInfoPropertyName = "CandidateFinishReason2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InputConfig))] - [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.MultiSpeakerVoiceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageConfig))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchEmbedContentsResponse))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ContentEmbedding))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCode))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCodeLanguage), TypeInfoPropertyName = "ExecutableCodeLanguage2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [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::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Permission))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PermissionGranteeType), TypeInfoPropertyName = "PermissionGranteeType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PermissionRole), TypeInfoPropertyName = "PermissionRole2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatchOutput))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Image))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCallingConfigMode), TypeInfoPropertyName = "FunctionCallingConfigMode2")] + [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.ListFilesResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AudioResponseFormat))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AudioResponseFormatMimeType), TypeInfoPropertyName = "AudioResponseFormatMimeType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AudioResponseFormatDelivery), TypeInfoPropertyName = "AudioResponseFormatDelivery2")] + [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.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.BatchGenerateContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InputConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileRequest))] + [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::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TranslationConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponseBlob))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatchState), TypeInfoPropertyName = "GenerateContentBatchState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListGeneratedFilesResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GeneratedFile))] + [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.ModalityTokenCount))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModalityTokenCountModality), TypeInfoPropertyName = "ModalityTokenCountModality2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchStats))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DynamicRetrievalConfig))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileData))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningTask))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Dataset))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Part))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResult))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SpeakerVoiceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Maps))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponseToolType), TypeInfoPropertyName = "ToolResponseToolType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UploadToFileSearchStoreRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ChunkingConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesRequest))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningSnapshot))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCall))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCallToolType), TypeInfoPropertyName = "ToolCallToolType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DocumentState), TypeInfoPropertyName = "DocumentState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.StreamableHttpTransport))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Hyperparameters))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatchState), TypeInfoPropertyName = "GenerateContentBatchState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListModelsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResultOutcome), TypeInfoPropertyName = "CodeExecutionResultOutcome2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunk))] + [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.Dictionary))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SpeechConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UsageMetadataServiceTier), TypeInfoPropertyName = "UsageMetadataServiceTier2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentRequestTaskType), TypeInfoPropertyName = "EmbedContentRequestTaskType2")] - [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.FunctionCall))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CountTokensRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModelState), TypeInfoPropertyName = "TunedModelState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCodeLanguage), TypeInfoPropertyName = "ExecutableCodeLanguage2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Schema))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionDeclarationBehavior), TypeInfoPropertyName = "FunctionDeclarationBehavior2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AudioResponseFormat))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AudioResponseFormatDelivery), TypeInfoPropertyName = "AudioResponseFormatDelivery2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AudioResponseFormatMimeType), TypeInfoPropertyName = "AudioResponseFormatMimeType2")] - [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.ResponseFormatConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.WhiteSpaceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUseDisabledSafetyPolicie), TypeInfoPropertyName = "ComputerUseDisabledSafetyPolicie2")] + [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.CountTokensResponse))] [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.ListCachedContentsResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListCorporaResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SchemaType), TypeInfoPropertyName = "SchemaType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.Dictionary))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormat))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImportFileRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormatDelivery), TypeInfoPropertyName = "ImageResponseFormatDelivery2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormatMimeType), TypeInfoPropertyName = "ImageResponseFormatMimeType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormatAspectRatio), TypeInfoPropertyName = "ImageResponseFormatAspectRatio2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormatImageSize), TypeInfoPropertyName = "ImageResponseFormatImageSize2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GeneratedFile))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ResponseFormatConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfigMediaResolution), TypeInfoPropertyName = "GenerationConfigMediaResolution2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DynamicRetrievalConfigMode), TypeInfoPropertyName = "DynamicRetrievalConfigMode2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GeneratedFileState), TypeInfoPropertyName = "GeneratedFileState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ReviewSnippet))] - [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::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.ListGeneratedFilesResponse))] - [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.IList))] + [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.EmbedContentRequestTaskType), TypeInfoPropertyName = "EmbedContentRequestTaskType2")] + [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::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] 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 0e46aab7..68ab2d0e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContextTypes.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContextTypes.g.cs @@ -28,971 +28,971 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - public global::Google.Gemini.TransferOwnershipRequest? Type0 { get; set; } + public global::Google.Gemini.ImageResponseFormat? Type0 { get; set; } /// /// /// - public string? Type1 { get; set; } + public global::Google.Gemini.ImageResponseFormatMimeType? Type1 { get; set; } /// /// /// - public global::Google.Gemini.ListFileSearchStoresResponse? Type2 { get; set; } + public global::Google.Gemini.ImageResponseFormatAspectRatio? Type2 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type3 { get; set; } + public global::Google.Gemini.ImageResponseFormatDelivery? Type3 { get; set; } /// /// /// - public global::Google.Gemini.FileSearchStore? Type4 { get; set; } + public global::Google.Gemini.ImageResponseFormatImageSize? Type4 { get; set; } /// /// /// - public global::Google.Gemini.ModelStatus? Type5 { get; set; } + public global::Google.Gemini.EmbedContentBatchOutput? Type5 { get; set; } /// /// /// - public global::Google.Gemini.ModelStatusModelStage? Type6 { get; set; } + public string? Type6 { get; set; } /// /// /// - public global::Google.Gemini.GroundingChunk? Type7 { get; set; } + public global::Google.Gemini.InlinedEmbedContentResponses? Type7 { get; set; } /// /// /// - public global::Google.Gemini.Web? Type8 { get; set; } + public global::Google.Gemini.CodeExecution? Type8 { get; set; } /// /// /// - public global::Google.Gemini.Image? Type9 { get; set; } + public global::Google.Gemini.InlinedEmbedContentRequest? Type9 { get; set; } /// /// /// - public global::Google.Gemini.RetrievedContext? Type10 { get; set; } + public global::Google.Gemini.EmbedContentRequest? Type10 { get; set; } /// /// /// - public global::Google.Gemini.Maps? Type11 { get; set; } + public object? Type11 { get; set; } /// /// /// - public global::Google.Gemini.RetrievalMetadata? Type12 { get; set; } + public global::Google.Gemini.ListOperationsResponse? Type12 { get; set; } /// /// /// - public float? Type13 { get; set; } + public global::System.Collections.Generic.IList? Type13 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentConfig? Type14 { get; set; } + public global::Google.Gemini.Operation? Type14 { get; set; } /// /// /// - public bool? Type15 { get; set; } + public global::System.Collections.Generic.IList? Type15 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentConfigTaskType? Type16 { get; set; } + public global::Google.Gemini.AsyncBatchEmbedContentRequest? Type16 { get; set; } /// /// /// - public int? Type17 { get; set; } + public global::Google.Gemini.EmbedContentBatch? Type17 { get; set; } /// /// /// - public global::Google.Gemini.GoogleSearchRetrieval? Type18 { get; set; } + public global::Google.Gemini.InlinedRequests? Type18 { get; set; } /// /// /// - public global::Google.Gemini.DynamicRetrievalConfig? Type19 { get; set; } + public global::System.Collections.Generic.IList? Type19 { get; set; } /// /// /// - public global::Google.Gemini.PromptFeedback? Type20 { get; set; } + public global::Google.Gemini.InlinedRequest? Type20 { get; set; } /// /// /// - public global::Google.Gemini.PromptFeedbackBlockReason? Type21 { get; set; } + public global::Google.Gemini.CachedContent? Type21 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type22 { get; set; } + public global::Google.Gemini.ToolConfig? Type22 { get; set; } /// /// /// - public global::Google.Gemini.SafetyRating? Type23 { get; set; } + public global::Google.Gemini.CachedContentUsageMetadata? Type23 { get; set; } /// /// /// - public global::Google.Gemini.SearchEntryPoint? Type24 { get; set; } + public global::System.Collections.Generic.IList? Type24 { get; set; } /// /// /// - public byte[]? Type25 { get; set; } + public global::Google.Gemini.Tool? Type25 { get; set; } /// /// /// - public global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport? Type26 { get; set; } + public global::Google.Gemini.Content? Type26 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type27 { get; set; } + public global::System.Collections.Generic.IList? Type27 { get; set; } /// /// /// - public global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? Type28 { get; set; } + public global::Google.Gemini.UrlMetadata? Type28 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type29 { get; set; } + public global::Google.Gemini.UrlMetadataUrlRetrievalStatus? Type29 { get; set; } /// /// /// - public global::Google.Gemini.InlinedRequest? Type30 { get; set; } + public global::System.Collections.Generic.IList? Type30 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentRequest? Type31 { get; set; } + public global::Google.Gemini.InlinedEmbedContentResponse? Type31 { get; set; } /// /// /// - public object? Type32 { get; set; } + public global::Google.Gemini.ReviewSnippet? Type32 { get; set; } /// /// /// - public global::Google.Gemini.Hyperparameters? Type33 { get; set; } + public global::Google.Gemini.File? Type33 { get; set; } /// /// /// - public global::Google.Gemini.BatchGenerateContentRequest? Type34 { get; set; } + public global::Google.Gemini.VideoFileMetadata? Type34 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentBatch? Type35 { get; set; } + public global::Google.Gemini.FileState? Type35 { get; set; } /// /// /// - public global::Google.Gemini.AsyncBatchEmbedContentRequest? Type36 { get; set; } + public global::Google.Gemini.FileSource? Type36 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatch? Type37 { get; set; } + public global::Google.Gemini.Status? Type37 { get; set; } /// /// /// - public global::Google.Gemini.CachedContent? Type38 { get; set; } + public byte[]? Type38 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type39 { get; set; } + public global::Google.Gemini.FunctionCall? Type39 { get; set; } /// /// /// - public global::Google.Gemini.Tool? Type40 { get; set; } + public global::Google.Gemini.FunctionDeclaration? Type40 { get; set; } /// /// /// - public global::Google.Gemini.ToolConfig? Type41 { get; set; } + public global::Google.Gemini.FunctionDeclarationBehavior? Type41 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type42 { get; set; } + public global::Google.Gemini.Schema? Type42 { get; set; } /// /// /// - public global::Google.Gemini.Content? Type43 { get; set; } + public global::Google.Gemini.TranslationConfig? Type43 { get; set; } /// /// /// - public global::Google.Gemini.CachedContentUsageMetadata? Type44 { get; set; } + public bool? Type44 { get; set; } /// /// /// - public global::Google.Gemini.InlinedResponses? Type45 { get; set; } + public global::Google.Gemini.Candidate? Type45 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type46 { get; set; } + public global::Google.Gemini.GroundingMetadata? Type46 { get; set; } /// /// /// - public global::Google.Gemini.InlinedResponse? Type47 { get; set; } + public double? Type47 { get; set; } /// /// /// - public global::Google.Gemini.Interval? Type48 { get; set; } + public int? Type48 { get; set; } /// /// /// - public global::Google.Gemini.GoogleMaps? Type49 { get; set; } + public global::Google.Gemini.CitationMetadata? Type49 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentBatchOutput? Type50 { get; set; } + public global::System.Collections.Generic.IList? Type50 { get; set; } /// /// /// - public global::Google.Gemini.EmbeddingUsageMetadata? Type51 { get; set; } + public global::Google.Gemini.GroundingAttribution? Type51 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type52 { get; set; } + public global::Google.Gemini.LogprobsResult? Type52 { get; set; } /// /// /// - public global::Google.Gemini.ModalityTokenCount? Type53 { get; set; } + public global::System.Collections.Generic.IList? Type53 { get; set; } /// /// /// - public global::Google.Gemini.ListFilesResponse? Type54 { get; set; } + public global::Google.Gemini.SafetyRating? Type54 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type55 { get; set; } + public global::Google.Gemini.UrlContextMetadata? Type55 { get; set; } /// /// /// - public global::Google.Gemini.File? Type56 { get; set; } + public global::Google.Gemini.CandidateFinishReason? Type56 { get; set; } /// /// /// - public global::Google.Gemini.PlaceAnswerSources? Type57 { get; set; } + public global::Google.Gemini.CustomLongRunningOperation? Type57 { get; set; } /// /// /// - public global::Google.Gemini.UrlMetadata? Type58 { get; set; } + public global::Google.Gemini.Web? Type58 { get; set; } /// /// /// - public global::Google.Gemini.UrlMetadataUrlRetrievalStatus? Type59 { get; set; } + public global::Google.Gemini.PrebuiltVoiceConfig? Type59 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponse? Type60 { get; set; } + public global::Google.Gemini.McpServer? Type60 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type61 { get; set; } + public global::Google.Gemini.StreamableHttpTransport? Type61 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponsePart? Type62 { get; set; } + public global::Google.Gemini.TopCandidates? Type62 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponseScheduling? Type63 { get; set; } + public global::System.Collections.Generic.IList? Type63 { get; set; } /// /// /// - public global::Google.Gemini.BatchEmbedContentsRequest? Type64 { get; set; } + public global::Google.Gemini.LogprobsResultCandidate? Type64 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type65 { get; set; } + public global::Google.Gemini.Blob? Type65 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentRequest? Type66 { get; set; } + public global::Google.Gemini.Document? Type66 { get; set; } /// /// /// - public global::Google.Gemini.WebSearch? Type67 { get; set; } + public global::Google.Gemini.DocumentState? Type67 { get; set; } /// /// /// - public global::Google.Gemini.SafetySetting? Type68 { get; set; } + public global::System.Collections.Generic.IList? Type68 { get; set; } /// /// /// - public global::Google.Gemini.SafetySettingCategory? Type69 { get; set; } + public global::Google.Gemini.CustomMetadata? Type69 { get; set; } /// /// /// - public global::Google.Gemini.SafetySettingThreshold? Type70 { get; set; } + public global::Google.Gemini.InputEmbedContentConfig? Type70 { get; set; } /// /// /// - public global::Google.Gemini.LogprobsResult? Type71 { get; set; } + public global::Google.Gemini.InlinedEmbedContentRequests? Type71 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type72 { get; set; } + public global::Google.Gemini.GenerateContentRequest? Type72 { get; set; } /// /// /// - public global::Google.Gemini.LogprobsResultCandidate? Type73 { get; set; } + public global::Google.Gemini.Model? Type73 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type74 { get; set; } + public float? Type74 { get; set; } /// /// /// - public global::Google.Gemini.TopCandidates? Type75 { get; set; } + public global::Google.Gemini.SearchEntryPoint? Type75 { get; set; } /// /// /// - public global::Google.Gemini.Operation? Type76 { get; set; } + public global::System.Collections.Generic.IList? Type76 { get; set; } /// /// /// - public global::Google.Gemini.Status? Type77 { get; set; } + public global::Google.Gemini.Interval? Type77 { get; set; } /// /// /// - public global::Google.Gemini.ChunkingConfig? Type78 { get; set; } + public global::Google.Gemini.ThinkingConfig? Type78 { get; set; } /// /// /// - public global::Google.Gemini.WhiteSpaceConfig? Type79 { get; set; } + public global::Google.Gemini.ThinkingConfigThinkingLevel? Type79 { get; set; } /// /// /// - public global::Google.Gemini.Empty? Type80 { get; set; } + public global::Google.Gemini.GroundingPassageId? Type80 { get; set; } /// /// /// - public global::Google.Gemini.UploadToFileSearchStoreRequest? Type81 { get; set; } + public global::Google.Gemini.RetrievalMetadata? Type81 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type82 { get; set; } + public global::Google.Gemini.BatchEmbedContentsRequest? Type82 { get; set; } /// /// /// - public global::Google.Gemini.CustomMetadata? Type83 { get; set; } + public global::System.Collections.Generic.IList? Type83 { get; set; } /// /// /// - public global::Google.Gemini.ModalityTokenCountModality? Type84 { get; set; } + public global::Google.Gemini.VideoMetadata? Type84 { get; set; } /// /// /// - public global::Google.Gemini.StringList? Type85 { get; set; } + public global::Google.Gemini.SafetyRatingCategory? Type85 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type86 { get; set; } + public global::Google.Gemini.SafetyRatingProbability? Type86 { get; set; } /// /// /// - public global::Google.Gemini.CustomLongRunningOperation? Type87 { get; set; } + public global::Google.Gemini.EmbedContentResponse? Type87 { get; set; } /// /// /// - public global::Google.Gemini.ListOperationsResponse? Type88 { get; set; } + public global::Google.Gemini.ContentEmbedding? Type88 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type89 { get; set; } + public global::Google.Gemini.EmbeddingUsageMetadata? Type89 { get; set; } /// /// /// - public global::Google.Gemini.ListTunedModelsResponse? Type90 { get; set; } + public global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? Type90 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type91 { get; set; } + public global::Google.Gemini.TransferOwnershipRequest? Type91 { get; set; } /// /// /// - public global::Google.Gemini.TunedModel? Type92 { get; set; } + public global::Google.Gemini.FunctionCallingConfig? Type92 { get; set; } /// /// /// - public global::Google.Gemini.TextResponseFormat? Type93 { get; set; } + public global::Google.Gemini.RetrievalConfig? Type93 { get; set; } /// /// /// - public global::Google.Gemini.TextResponseFormatMimeType? Type94 { get; set; } + public global::Google.Gemini.ListFileSearchStoresResponse? Type94 { get; set; } /// /// /// - public global::Google.Gemini.DynamicRetrievalConfigMode? Type95 { get; set; } + public global::System.Collections.Generic.IList? Type95 { get; set; } /// /// /// - public global::Google.Gemini.VideoMetadata? Type96 { get; set; } + public global::Google.Gemini.FileSearchStore? Type96 { get; set; } /// /// /// - public double? Type97 { get; set; } + public global::Google.Gemini.ModelStatus? Type97 { get; set; } /// /// /// - public global::Google.Gemini.UrlContext? Type98 { get; set; } + public global::Google.Gemini.ModelStatusModelStage? Type98 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type99 { get; set; } + public global::Google.Gemini.PlaceAnswerSources? Type99 { get; set; } /// /// /// - public global::Google.Gemini.GenerationConfig? Type100 { get; set; } + public global::System.Collections.Generic.IList? Type100 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentRequestServiceTier? Type101 { get; set; } + public global::Google.Gemini.SearchTypes? Type101 { get; set; } /// /// /// - public global::Google.Gemini.ImageSearch? Type102 { get; set; } + public global::Google.Gemini.WebSearch? Type102 { get; set; } /// /// /// - public global::Google.Gemini.VoiceConfig? Type103 { get; set; } + public global::Google.Gemini.ImageSearch? Type103 { get; set; } /// /// /// - public global::Google.Gemini.PrebuiltVoiceConfig? Type104 { get; set; } + public global::Google.Gemini.EmbedContentBatchStats? Type104 { get; set; } /// /// /// - public global::Google.Gemini.CodeExecution? Type105 { get; set; } + public global::Google.Gemini.CitationSource? Type105 { get; set; } /// /// /// - public global::Google.Gemini.SpeakerVoiceConfig? Type106 { get; set; } + public global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport? Type106 { get; set; } /// /// /// - public global::Google.Gemini.RetrievalConfig? Type107 { get; set; } + public global::System.Collections.Generic.IList? Type107 { get; set; } /// /// /// - public global::Google.Gemini.FunctionCallingConfig? Type108 { get; set; } + public global::System.Collections.Generic.IList? Type108 { get; set; } /// /// /// - public global::Google.Gemini.CitationMetadata? Type109 { get; set; } + public global::Google.Gemini.ListCorporaResponse? Type109 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type110 { get; set; } + public global::System.Collections.Generic.IList? Type110 { get; set; } /// /// /// - public global::Google.Gemini.CitationSource? Type111 { get; set; } + public global::Google.Gemini.Corpus? Type111 { get; set; } /// /// /// - public global::Google.Gemini.Dataset? Type112 { get; set; } + public global::Google.Gemini.ToolCall? Type112 { get; set; } /// /// /// - public global::Google.Gemini.TuningExamples? Type113 { get; set; } + public global::Google.Gemini.ToolCallToolType? Type113 { get; set; } /// /// /// - public global::Google.Gemini.CodeExecutionResult? Type114 { get; set; } + public global::System.Collections.Generic.IList? Type114 { get; set; } /// /// /// - public global::Google.Gemini.CodeExecutionResultOutcome? Type115 { get; set; } + public global::Google.Gemini.SafetySetting? Type115 { get; set; } /// /// /// - public global::Google.Gemini.SemanticRetrieverChunk? Type116 { get; set; } + public global::Google.Gemini.GenerateContentRequestServiceTier? Type116 { get; set; } /// /// /// - public global::Google.Gemini.Corpus? Type117 { get; set; } + public global::Google.Gemini.GenerationConfig? Type117 { get; set; } /// /// /// - public global::Google.Gemini.LatLng? Type118 { get; set; } + public global::Google.Gemini.GroundingChunkStringList? Type118 { get; set; } /// /// /// - public global::Google.Gemini.GroundingMetadata? Type119 { get; set; } + public global::Google.Gemini.VoiceConfig? Type119 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type120 { get; set; } + public global::Google.Gemini.SpeechConfig? Type120 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type121 { get; set; } + public global::Google.Gemini.MultiSpeakerVoiceConfig? Type121 { get; set; } /// /// /// - public global::Google.Gemini.ListModelsResponse? Type122 { get; set; } + public global::Google.Gemini.InlinedResponses? Type122 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type123 { get; set; } + public global::System.Collections.Generic.IList? Type123 { get; set; } /// /// /// - public global::Google.Gemini.Model? Type124 { get; set; } + public global::Google.Gemini.InlinedResponse? Type124 { get; set; } /// /// /// - public global::Google.Gemini.TuningExample? Type125 { get; set; } + public global::Google.Gemini.TuningExamples? Type125 { get; set; } /// /// /// - public global::Google.Gemini.Permission? Type126 { get; set; } + public global::System.Collections.Generic.IList? Type126 { get; set; } /// /// /// - public global::Google.Gemini.PermissionGranteeType? Type127 { get; set; } + public global::Google.Gemini.TuningExample? Type127 { get; set; } /// /// /// - public global::Google.Gemini.PermissionRole? Type128 { get; set; } + public global::Google.Gemini.LatLng? Type128 { get; set; } /// /// /// - public global::Google.Gemini.GroundingPassageId? Type129 { get; set; } + public global::Google.Gemini.FunctionResponse? Type129 { get; set; } /// /// /// - public global::Google.Gemini.ComputerUse? Type130 { get; set; } + public global::System.Collections.Generic.IList? Type130 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type131 { get; set; } + public global::Google.Gemini.FunctionResponsePart? Type131 { get; set; } /// /// /// - public global::Google.Gemini.ComputerUseDisabledSafetyPolicie? Type132 { get; set; } + public global::Google.Gemini.FunctionResponseScheduling? Type132 { get; set; } /// /// /// - public global::Google.Gemini.ComputerUseEnvironment? Type133 { get; set; } + public global::System.Collections.Generic.Dictionary? Type133 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentResponse? Type134 { get; set; } + public global::System.Collections.Generic.IList? Type134 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentResponse? Type135 { get; set; } + public global::Google.Gemini.SchemaType? Type135 { get; set; } /// /// /// - public global::Google.Gemini.ListPermissionsResponse? Type136 { get; set; } + public global::Google.Gemini.FunctionResponseBlob? Type136 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type137 { get; set; } + public global::Google.Gemini.StringList? Type137 { get; set; } /// /// /// - public global::Google.Gemini.ToolResponse? Type138 { get; set; } + public global::Google.Gemini.TuningSnapshot? Type138 { get; set; } /// /// /// - public global::Google.Gemini.ToolResponseToolType? Type139 { get; set; } + public global::Google.Gemini.RetrievedContext? Type139 { get; set; } /// /// /// - public global::Google.Gemini.GroundingChunkStringList? Type140 { get; set; } + public global::System.Collections.Generic.IList? Type140 { get; set; } /// /// /// - public global::Google.Gemini.AttributionSourceId? Type141 { get; set; } + public global::Google.Gemini.GroundingChunkCustomMetadata? Type141 { get; set; } /// /// /// - public global::Google.Gemini.ListDocumentsResponse? Type142 { get; set; } + public global::Google.Gemini.CountTokensRequest? Type142 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type143 { get; set; } + public global::Google.Gemini.GoogleSearchRetrieval? Type143 { get; set; } /// /// /// - public global::Google.Gemini.Document? Type144 { get; set; } + public global::System.Collections.Generic.IList? Type144 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentResponse? Type145 { get; set; } + public global::Google.Gemini.GoogleSearch? Type145 { get; set; } /// /// /// - public global::Google.Gemini.ThinkingConfig? Type146 { get; set; } + public global::Google.Gemini.UrlContext? Type146 { get; set; } /// /// /// - public global::Google.Gemini.ThinkingConfigThinkingLevel? Type147 { get; set; } + public global::Google.Gemini.GoogleMaps? Type147 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type148 { get; set; } + public global::System.Collections.Generic.IList? Type148 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatchState? Type149 { get; set; } + public global::Google.Gemini.ComputerUse? Type149 { get; set; } /// /// /// - public global::Google.Gemini.InputEmbedContentConfig? Type150 { get; set; } + public global::Google.Gemini.FileSearch? Type150 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatchOutput? Type151 { get; set; } + public global::Google.Gemini.PromptFeedback? Type151 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatchStats? Type152 { get; set; } + public global::Google.Gemini.PromptFeedbackBlockReason? Type152 { get; set; } /// /// /// - public global::Google.Gemini.CountTokensResponse? Type153 { get; set; } + public global::Google.Gemini.AttributionSourceId? Type153 { get; set; } /// /// /// - public global::Google.Gemini.CreateFileResponse? Type154 { get; set; } + public global::Google.Gemini.SemanticRetrieverChunk? Type154 { get; set; } /// /// /// - public global::Google.Gemini.FileSource? Type155 { get; set; } + public global::Google.Gemini.ListDocumentsResponse? Type155 { get; set; } /// /// /// - public global::Google.Gemini.VideoFileMetadata? Type156 { get; set; } + public global::System.Collections.Generic.IList? Type156 { get; set; } /// /// /// - public global::Google.Gemini.FileState? Type157 { get; set; } + public global::Google.Gemini.RegisterFilesResponse? Type157 { get; set; } /// /// /// - public global::Google.Gemini.SafetyRatingProbability? Type158 { get; set; } + public global::System.Collections.Generic.IList? Type158 { get; set; } /// /// /// - public global::Google.Gemini.SafetyRatingCategory? Type159 { get; set; } + public global::Google.Gemini.CreateFileResponse? Type159 { get; set; } /// /// /// - public global::Google.Gemini.CreateFileRequest? Type160 { get; set; } + public global::Google.Gemini.EmbedContentBatchState? Type160 { get; set; } /// /// /// - public global::Google.Gemini.FunctionCallingConfigMode? Type161 { get; set; } + public global::Google.Gemini.TextResponseFormat? Type161 { get; set; } /// /// /// - public global::Google.Gemini.TunedModelSource? Type162 { get; set; } + public global::Google.Gemini.TextResponseFormatMimeType? Type162 { get; set; } /// /// /// - public global::Google.Gemini.FileSearch? Type163 { get; set; } + public global::Google.Gemini.TunedModel? Type163 { get; set; } /// /// /// - public global::Google.Gemini.RegisterFilesRequest? Type164 { get; set; } + public global::Google.Gemini.TunedModelState? Type164 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentRequests? Type165 { get; set; } + public global::Google.Gemini.TuningTask? Type165 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type166 { get; set; } + public global::Google.Gemini.TunedModelSource? Type166 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentRequest? Type167 { get; set; } + public global::Google.Gemini.ImageConfig? Type167 { get; set; } /// /// /// - public global::Google.Gemini.InlinedRequests? Type168 { get; set; } + public global::Google.Gemini.BatchEmbedContentsResponse? Type168 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type169 { get; set; } + public global::System.Collections.Generic.IList? Type169 { get; set; } /// /// /// - public global::Google.Gemini.GoogleSearch? Type170 { get; set; } + public global::Google.Gemini.ExecutableCode? Type170 { get; set; } /// /// /// - public global::Google.Gemini.SearchTypes? Type171 { get; set; } + public global::Google.Gemini.ExecutableCodeLanguage? Type171 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type172 { get; set; } + public global::System.Collections.Generic.IList? Type172 { get; set; } /// /// /// - public global::Google.Gemini.FunctionDeclaration? Type173 { get; set; } + public global::Google.Gemini.ListTunedModelsResponse? Type173 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type174 { get; set; } + public global::System.Collections.Generic.IList? Type174 { get; set; } /// /// /// - public global::Google.Gemini.McpServer? Type175 { get; set; } + public global::System.Collections.Generic.IList? Type175 { get; set; } /// /// /// - public global::Google.Gemini.Blob? Type176 { get; set; } + public global::Google.Gemini.Permission? Type176 { get; set; } /// /// /// - public global::Google.Gemini.Candidate? Type177 { get; set; } + public global::Google.Gemini.PermissionGranteeType? Type177 { get; set; } /// /// /// - public global::Google.Gemini.UrlContextMetadata? Type178 { get; set; } + public global::Google.Gemini.PermissionRole? Type178 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type179 { get; set; } + public global::Google.Gemini.GenerateContentBatchOutput? Type179 { get; set; } /// /// /// - public global::Google.Gemini.GroundingAttribution? Type180 { get; set; } + public global::Google.Gemini.Image? Type180 { get; set; } /// /// /// - public global::Google.Gemini.CandidateFinishReason? Type181 { get; set; } + public global::Google.Gemini.FunctionCallingConfigMode? Type181 { get; set; } /// /// /// - public global::Google.Gemini.InputConfig? Type182 { get; set; } + public global::Google.Gemini.ListPermissionsResponse? Type182 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentResponses? Type183 { get; set; } + public global::System.Collections.Generic.IList? Type183 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type184 { get; set; } + public global::Google.Gemini.ListFilesResponse? Type184 { get; set; } /// /// /// - public global::Google.Gemini.MultiSpeakerVoiceConfig? Type185 { get; set; } + public global::Google.Gemini.AudioResponseFormat? Type185 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type186 { get; set; } + public global::Google.Gemini.AudioResponseFormatMimeType? Type186 { get; set; } /// /// /// - public global::Google.Gemini.BatchEmbedContentsResponse? Type187 { get; set; } + public global::Google.Gemini.AudioResponseFormatDelivery? Type187 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type188 { get; set; } + public global::Google.Gemini.ListCachedContentsResponse? Type188 { get; set; } /// /// /// - public global::Google.Gemini.ContentEmbedding? Type189 { get; set; } + public global::System.Collections.Generic.IList? Type189 { get; set; } /// /// /// - public global::Google.Gemini.UsageMetadata? Type190 { get; set; } + public global::Google.Gemini.SafetySettingCategory? Type190 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type191 { get; set; } + public global::Google.Gemini.SafetySettingThreshold? Type191 { get; set; } /// /// /// - public global::Google.Gemini.TranslationConfig? Type192 { get; set; } + public global::Google.Gemini.BatchGenerateContentRequest? Type192 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponseBlob? Type193 { get; set; } + public global::Google.Gemini.GenerateContentBatch? Type193 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentBatchState? Type194 { get; set; } + public global::Google.Gemini.InputConfig? Type194 { get; set; } /// /// /// - public global::Google.Gemini.BatchStats? Type195 { get; set; } + public global::Google.Gemini.CreateFileRequest? Type195 { get; set; } /// /// /// - public global::Google.Gemini.FileData? Type196 { get; set; } + public global::Google.Gemini.GenerateContentResponse? Type196 { get; set; } /// /// /// - public global::Google.Gemini.TuningTask? Type197 { get; set; } + public global::Google.Gemini.UsageMetadata? Type197 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type198 { get; set; } + public global::System.Collections.Generic.IList? Type198 { get; set; } /// /// /// - public global::Google.Gemini.TuningSnapshot? Type199 { get; set; } + public global::Google.Gemini.ListGeneratedFilesResponse? Type199 { get; set; } /// /// /// - public global::Google.Gemini.ToolCall? Type200 { get; set; } + public global::System.Collections.Generic.IList? Type200 { get; set; } /// /// /// - public global::Google.Gemini.ToolCallToolType? Type201 { get; set; } + public global::Google.Gemini.GeneratedFile? Type201 { get; set; } /// /// /// - public global::Google.Gemini.DocumentState? Type202 { get; set; } + public global::Google.Gemini.UsageMetadataServiceTier? Type202 { get; set; } /// /// /// - public global::Google.Gemini.StreamableHttpTransport? Type203 { get; set; } + public global::System.Collections.Generic.IList? Type203 { get; set; } /// /// /// - public global::System.Collections.Generic.Dictionary? Type204 { get; set; } + public global::Google.Gemini.ModalityTokenCount? Type204 { get; set; } /// /// /// - public global::Google.Gemini.SpeechConfig? Type205 { get; set; } + public global::Google.Gemini.TransferOwnershipResponse? Type205 { get; set; } /// /// /// - public global::Google.Gemini.UsageMetadataServiceTier? Type206 { get; set; } + public global::Google.Gemini.ModalityTokenCountModality? Type206 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentRequestTaskType? Type207 { get; set; } + public global::Google.Gemini.BatchStats? Type207 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type208 { get; set; } + public global::Google.Gemini.DynamicRetrievalConfig? Type208 { get; set; } /// /// /// - public global::Google.Gemini.Part? Type209 { get; set; } + public global::Google.Gemini.FileData? Type209 { get; set; } /// /// /// - public global::Google.Gemini.ExecutableCode? Type210 { get; set; } + public global::Google.Gemini.Dataset? Type210 { get; set; } /// /// /// - public global::Google.Gemini.FunctionCall? Type211 { get; set; } + public global::Google.Gemini.Part? Type211 { get; set; } /// /// /// - public global::Google.Gemini.CountTokensRequest? Type212 { get; set; } + public global::Google.Gemini.ToolResponse? Type212 { get; set; } /// /// /// - public global::Google.Gemini.TunedModelState? Type213 { get; set; } + public global::Google.Gemini.CodeExecutionResult? Type213 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type214 { get; set; } + public global::Google.Gemini.SpeakerVoiceConfig? Type214 { get; set; } /// /// /// - public global::Google.Gemini.ExecutableCodeLanguage? Type215 { get; set; } + public global::Google.Gemini.Maps? Type215 { get; set; } /// /// /// - public global::Google.Gemini.Schema? Type216 { get; set; } + public global::Google.Gemini.ToolResponseToolType? Type216 { get; set; } /// /// /// - public global::Google.Gemini.FunctionDeclarationBehavior? Type217 { get; set; } + public global::Google.Gemini.UploadToFileSearchStoreRequest? Type217 { get; set; } /// /// /// - public global::Google.Gemini.AudioResponseFormat? Type218 { get; set; } + public global::Google.Gemini.ChunkingConfig? Type218 { get; set; } /// /// /// - public global::Google.Gemini.AudioResponseFormatDelivery? Type219 { get; set; } + public global::Google.Gemini.RegisterFilesRequest? Type219 { get; set; } /// /// /// - public global::Google.Gemini.AudioResponseFormatMimeType? Type220 { get; set; } + public global::System.Collections.Generic.IList? Type220 { get; set; } /// /// /// - public global::Google.Gemini.ImageConfig? Type221 { get; set; } + public global::Google.Gemini.Hyperparameters? Type221 { get; set; } /// /// /// - public global::Google.Gemini.GenerationConfigMediaResolution? Type222 { get; set; } + public global::Google.Gemini.GenerateContentBatchState? Type222 { get; set; } /// /// /// - public global::Google.Gemini.ResponseFormatConfig? Type223 { get; set; } + public global::System.Collections.Generic.IList? Type223 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type224 { get; set; } + public global::Google.Gemini.ListModelsResponse? Type224 { get; set; } /// /// /// - public global::Google.Gemini.GenerationConfigResponseModalitie? Type225 { get; set; } + public global::System.Collections.Generic.IList? Type225 { get; set; } /// /// /// - public global::Google.Gemini.ListCachedContentsResponse? Type226 { get; set; } + public global::Google.Gemini.CodeExecutionResultOutcome? Type226 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type227 { get; set; } + public global::Google.Gemini.GroundingChunk? Type227 { get; set; } /// /// /// - public global::Google.Gemini.RegisterFilesResponse? Type228 { get; set; } + public global::Google.Gemini.EmbedContentConfig? Type228 { get; set; } /// /// /// - public global::Google.Gemini.ListCorporaResponse? Type229 { get; set; } + public global::Google.Gemini.EmbedContentConfigTaskType? Type229 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type230 { get; set; } + public global::System.Collections.Generic.Dictionary? Type230 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type231 { get; set; } + public global::Google.Gemini.WhiteSpaceConfig? Type231 { get; set; } /// /// /// - public global::Google.Gemini.SchemaType? Type232 { get; set; } + public global::System.Collections.Generic.IList? Type232 { get; set; } /// /// /// - public global::System.Collections.Generic.Dictionary? Type233 { get; set; } + public global::Google.Gemini.ComputerUseDisabledSafetyPolicie? Type233 { get; set; } /// /// /// - public global::Google.Gemini.ImageResponseFormat? Type234 { get; set; } + public global::Google.Gemini.ComputerUseEnvironment? Type234 { get; set; } /// /// /// - public global::Google.Gemini.ImportFileRequest? Type235 { get; set; } + public global::System.Collections.Generic.IList? Type235 { get; set; } /// /// /// - public global::Google.Gemini.ImageResponseFormatDelivery? Type236 { get; set; } + public global::Google.Gemini.CountTokensResponse? Type236 { get; set; } /// /// /// - public global::Google.Gemini.ImageResponseFormatMimeType? Type237 { get; set; } + public global::System.Collections.Generic.IList? Type237 { get; set; } /// /// /// - public global::Google.Gemini.ImageResponseFormatAspectRatio? Type238 { get; set; } + public global::Google.Gemini.GenerationConfigResponseModalitie? Type238 { get; set; } /// /// /// - public global::Google.Gemini.ImageResponseFormatImageSize? Type239 { get; set; } + public global::Google.Gemini.ResponseFormatConfig? Type239 { get; set; } /// /// /// - public global::Google.Gemini.TransferOwnershipResponse? Type240 { get; set; } + public global::Google.Gemini.GenerationConfigMediaResolution? Type240 { get; set; } /// /// /// - public global::Google.Gemini.GeneratedFile? Type241 { get; set; } + public global::Google.Gemini.DynamicRetrievalConfigMode? Type241 { get; set; } /// /// /// @@ -1000,100 +1000,100 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - public global::Google.Gemini.ReviewSnippet? Type243 { get; set; } + public global::System.Collections.Generic.IList? Type243 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type244 { get; set; } + public global::System.Collections.Generic.IList? Type244 { get; set; } /// /// /// - public global::Google.Gemini.GroundingChunkCustomMetadata? Type245 { get; set; } + public global::Google.Gemini.Empty? Type245 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type246 { get; set; } + public global::Google.Gemini.EmbedContentRequestTaskType? Type246 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type247 { get; set; } + public global::System.Collections.Generic.IList? Type247 { get; set; } /// /// /// - public global::Google.Gemini.ListGeneratedFilesResponse? Type248 { get; set; } + public global::Google.Gemini.ImportFileRequest? Type248 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type249 { get; set; } + public global::System.Collections.Generic.IList? Type249 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType0 { get; set; } + public global::System.Collections.Generic.List? ListType0 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType1 { get; set; } + public global::System.Collections.Generic.List? ListType1 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType2 { get; set; } + public global::System.Collections.Generic.List? ListType2 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType3 { get; set; } + public global::System.Collections.Generic.List? ListType3 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType4 { get; set; } + public global::System.Collections.Generic.List? ListType4 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType5 { get; set; } + public global::System.Collections.Generic.List? ListType5 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType6 { get; set; } + public global::System.Collections.Generic.List? ListType6 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType7 { get; set; } + public global::System.Collections.Generic.List? ListType7 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType8 { get; set; } + public global::System.Collections.Generic.List? ListType8 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType9 { get; set; } + public global::System.Collections.Generic.List? ListType9 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType10 { get; set; } + public global::System.Collections.Generic.List? ListType10 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType11 { get; set; } + public global::System.Collections.Generic.List? ListType11 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType12 { get; set; } + public global::System.Collections.Generic.List? ListType12 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType13 { get; set; } + public global::System.Collections.Generic.List? ListType13 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType14 { get; set; } + public global::System.Collections.Generic.List? ListType14 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType15 { get; set; } + public global::System.Collections.Generic.List? ListType15 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType16 { get; set; } + public global::System.Collections.Generic.List? ListType16 { get; set; } /// /// /// @@ -1101,114 +1101,114 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - 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; } /// /// /// - public global::System.Collections.Generic.List? ListType39 { get; set; } + public global::System.Collections.Generic.List? ListType39 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType40 { get; set; } + public global::System.Collections.Generic.List? ListType40 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType41 { get; set; } + public global::System.Collections.Generic.List? ListType41 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType42 { get; set; } + public global::System.Collections.Generic.List? ListType42 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType43 { get; set; } + public global::System.Collections.Generic.List? ListType43 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType44 { get; set; } + public global::System.Collections.Generic.List? ListType44 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType45 { get; set; } + public global::System.Collections.Generic.List? ListType45 { get; set; } } } \ No newline at end of file diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.AttributionSourceId.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.AttributionSourceId.g.cs index 31aabb54..5f9a1bf9 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.AttributionSourceId.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.AttributionSourceId.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class AttributionSourceId { - /// - /// Identifier for a part within a `GroundingPassage`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("groundingPassage")] - public global::Google.Gemini.GroundingPassageId? GroundingPassage { get; set; } - /// /// Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`. /// [global::System.Text.Json.Serialization.JsonPropertyName("semanticRetrieverChunk")] public global::Google.Gemini.SemanticRetrieverChunk? SemanticRetrieverChunk { get; set; } + /// + /// Identifier for a part within a `GroundingPassage`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("groundingPassage")] + public global::Google.Gemini.GroundingPassageId? GroundingPassage { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class AttributionSourceId /// /// Initializes a new instance of the class. /// - /// - /// Identifier for a part within a `GroundingPassage`. - /// /// /// Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`. /// + /// + /// Identifier for a part within a `GroundingPassage`. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public AttributionSourceId( - global::Google.Gemini.GroundingPassageId? groundingPassage, - global::Google.Gemini.SemanticRetrieverChunk? semanticRetrieverChunk) + global::Google.Gemini.SemanticRetrieverChunk? semanticRetrieverChunk, + global::Google.Gemini.GroundingPassageId? groundingPassage) { - this.GroundingPassage = groundingPassage; this.SemanticRetrieverChunk = semanticRetrieverChunk; + this.GroundingPassage = groundingPassage; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.AudioResponseFormat.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.AudioResponseFormat.g.cs index d6fde989..db3bf7ac 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.AudioResponseFormat.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.AudioResponseFormat.g.cs @@ -8,13 +8,6 @@ namespace Google.Gemini /// public sealed partial class AudioResponseFormat { - /// - /// Optional. The delivery mode for the audio output. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("delivery")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatDeliveryJsonConverter))] - public global::Google.Gemini.AudioResponseFormatDelivery? Delivery { get; set; } - /// /// Optional. Sample rate in Hz. /// @@ -34,6 +27,13 @@ public sealed partial class AudioResponseFormat [global::System.Text.Json.Serialization.JsonPropertyName("bitRate")] public int? BitRate { get; set; } + /// + /// Optional. The delivery mode for the audio output. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("delivery")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatDeliveryJsonConverter))] + public global::Google.Gemini.AudioResponseFormatDelivery? Delivery { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -43,9 +43,6 @@ public sealed partial class AudioResponseFormat /// /// Initializes a new instance of the class. /// - /// - /// Optional. The delivery mode for the audio output. - /// /// /// Optional. Sample rate in Hz. /// @@ -55,19 +52,22 @@ public sealed partial class AudioResponseFormat /// /// Optional. Bit rate in bits per second (bps). Only applicable for compressed formats (MP3, Opus). /// + /// + /// Optional. The delivery mode for the audio output. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public AudioResponseFormat( - global::Google.Gemini.AudioResponseFormatDelivery? delivery, int? sampleRate, global::Google.Gemini.AudioResponseFormatMimeType? mimeType, - int? bitRate) + int? bitRate, + global::Google.Gemini.AudioResponseFormatDelivery? delivery) { - this.Delivery = delivery; this.SampleRate = sampleRate; this.MimeType = mimeType; this.BitRate = bitRate; + this.Delivery = delivery; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchEmbedContentsResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchEmbedContentsResponse.g.cs index 7db4b5ba..1bd6145a 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchEmbedContentsResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchEmbedContentsResponse.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class BatchEmbedContentsResponse { - /// - /// Metadata on the usage of the embedding request. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] - public global::Google.Gemini.EmbeddingUsageMetadata? UsageMetadata { get; set; } - /// /// Output only. The embeddings for each request, in the same order as provided in the batch request.
/// Included only in responses @@ -21,6 +15,12 @@ public sealed partial class BatchEmbedContentsResponse [global::System.Text.Json.Serialization.JsonPropertyName("embeddings")] public global::System.Collections.Generic.IList? Embeddings { get; set; } + /// + /// Metadata on the usage of the embedding request. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] + public global::Google.Gemini.EmbeddingUsageMetadata? UsageMetadata { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,22 +30,22 @@ public sealed partial class BatchEmbedContentsResponse /// /// Initializes a new instance of the class. /// - /// - /// Metadata on the usage of the embedding request. - /// /// /// Output only. The embeddings for each request, in the same order as provided in the batch request.
/// Included only in responses /// + /// + /// Metadata on the usage of the embedding request. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public BatchEmbedContentsResponse( - global::Google.Gemini.EmbeddingUsageMetadata? usageMetadata, - global::System.Collections.Generic.IList? embeddings) + global::System.Collections.Generic.IList? embeddings, + global::Google.Gemini.EmbeddingUsageMetadata? usageMetadata) { - this.UsageMetadata = usageMetadata; this.Embeddings = embeddings; + this.UsageMetadata = usageMetadata; } /// 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 6b4d1340..ca17c6b2 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 @@ -16,18 +16,18 @@ public sealed partial class BatchStats public string? SuccessfulRequestCount { get; set; } /// - /// Output only. The number of requests in the batch.
+ /// Output only. The number of requests that failed to be processed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("requestCount")] - public string? RequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("failedRequestCount")] + public string? FailedRequestCount { get; set; } /// - /// Output only. The number of requests that 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.
@@ -49,14 +49,14 @@ public sealed partial class BatchStats /// Output only. The number of requests that were successfully processed.
/// Included only in responses /// - /// - /// Output only. The number of requests in the batch.
- /// Included only in responses - /// /// /// Output only. The number of requests that failed to be processed.
/// Included only in responses /// + /// + /// Output only. The number of requests in the batch.
+ /// Included only in responses + /// /// /// Output only. The number of requests that are still pending processing.
/// Included only in responses @@ -66,13 +66,13 @@ public sealed partial class BatchStats #endif public BatchStats( string? successfulRequestCount, - string? requestCount, string? failedRequestCount, + string? requestCount, string? pendingRequestCount) { this.SuccessfulRequestCount = successfulRequestCount; - this.RequestCount = requestCount; this.FailedRequestCount = failedRequestCount; + this.RequestCount = requestCount; this.PendingRequestCount = pendingRequestCount; } 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 59b9d3c8..0cd27d85 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,6 +8,18 @@ namespace Google.Gemini ///
public sealed partial class CachedContent { + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("toolConfig")] + public global::Google.Gemini.ToolConfig? ToolConfig { get; set; } + + /// + /// Metadata on the usage of the cached content. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] + public global::Google.Gemini.CachedContentUsageMetadata? UsageMetadata { get; set; } + /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` /// @@ -20,12 +32,6 @@ public sealed partial class CachedContent [global::System.Text.Json.Serialization.JsonPropertyName("tools")] public global::System.Collections.Generic.IList? Tools { get; set; } - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// - [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 @@ -34,22 +40,11 @@ public sealed partial class CachedContent public string? UpdateTime { get; set; } /// - /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } - - /// - /// Optional. Input only. Immutable. The content to cache. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("contents")] - public global::System.Collections.Generic.IList? Contents { get; set; } - - /// - /// Input only. New TTL for this resource, input only. + /// Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("ttl")] - public string? Ttl { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { 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. @@ -58,17 +53,16 @@ public sealed partial class CachedContent public global::Google.Gemini.Content? SystemInstruction { 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. + /// Optional. Input only. Immutable. The content to cache. /// - [global::System.Text.Json.Serialization.JsonPropertyName("expireTime")] - public string? ExpireTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("contents")] + public global::System.Collections.Generic.IList? Contents { get; set; } /// /// Output only. Creation time of the cache entry.
@@ -78,10 +72,16 @@ public sealed partial class CachedContent public string? CreateTime { get; set; } /// - /// Metadata on the usage of the cached content. + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. /// - [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] - public global::Google.Gemini.CachedContentUsageMetadata? UsageMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { 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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("expireTime")] + public string? ExpireTime { 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. /// + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Metadata on the usage of the cached content. + /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` /// /// /// 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. - /// /// /// Output only. When the cache entry was last updated in UTC time.
/// Included only in responses /// - /// - /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. - /// - /// - /// Optional. Input only. Immutable. The content to cache. - /// - /// - /// Input only. New TTL for this resource, input only. + /// + /// Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`
+ /// 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. 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. /// - /// - /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. + /// + /// Optional. Input only. Immutable. The content to cache. /// /// /// Output only. Creation time of the cache entry.
/// Included only in responses /// - /// - /// Metadata on the usage of the cached content. + /// + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// + /// + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CachedContent( + global::Google.Gemini.ToolConfig? toolConfig, + global::Google.Gemini.CachedContentUsageMetadata? usageMetadata, string? model, global::System.Collections.Generic.IList? tools, - global::Google.Gemini.ToolConfig? toolConfig, string? updateTime, - string? displayName, - global::System.Collections.Generic.IList? contents, - string? ttl, - global::Google.Gemini.Content? systemInstruction, string? name, - string? expireTime, + global::Google.Gemini.Content? systemInstruction, + string? ttl, + global::System.Collections.Generic.IList? contents, string? createTime, - global::Google.Gemini.CachedContentUsageMetadata? usageMetadata) + string? displayName, + string? expireTime) { + this.ToolConfig = toolConfig; + this.UsageMetadata = usageMetadata; this.Model = model; this.Tools = tools; - this.ToolConfig = toolConfig; this.UpdateTime = updateTime; - this.DisplayName = displayName; - this.Contents = contents; - this.Ttl = ttl; - this.SystemInstruction = systemInstruction; this.Name = name; - this.ExpireTime = expireTime; + this.SystemInstruction = systemInstruction; + this.Ttl = ttl; + this.Contents = contents; this.CreateTime = createTime; - this.UsageMetadata = usageMetadata; + this.DisplayName = displayName; + this.ExpireTime = expireTime; } /// 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 2db6869b..5c4ce803 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 @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class Candidate { - /// - /// A collection of source attributions for a piece of content. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("citationMetadata")] - public global::Google.Gemini.CitationMetadata? CitationMetadata { get; set; } - /// /// Metadata returned to client when grounding is enabled. /// @@ -21,32 +15,44 @@ public sealed partial class Candidate public global::Google.Gemini.GroundingMetadata? GroundingMetadata { get; set; } /// - /// Metadata related to url context retrieval tool. + /// Output only. Average log probability score of the candidate.
+ /// 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("avgLogprobs")] + public double? AvgLogprobs { get; set; } /// - /// Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.
+ /// 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("groundingAttributions")] - public global::System.Collections.Generic.IList? GroundingAttributions { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("finishMessage")] + public string? FinishMessage { get; set; } /// - /// Output only. Average log probability score of the candidate.
+ /// Output only. Index of the candidate in the list of response candidates.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("avgLogprobs")] - public double? AvgLogprobs { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("index")] + public int? Index { get; set; } /// - /// Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.
+ /// A collection of source attributions for a piece of content. + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("citationMetadata")] + public global::Google.Gemini.CitationMetadata? CitationMetadata { get; set; } + + /// + /// Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("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("groundingAttributions")] + public global::System.Collections.Generic.IList? GroundingAttributions { get; set; } + + /// + /// Logprobs Result + /// + [global::System.Text.Json.Serialization.JsonPropertyName("logprobsResult")] + public global::Google.Gemini.LogprobsResult? LogprobsResult { get; set; } /// /// List of ratings for the safety of a response candidate. There is at most one rating per category. @@ -55,18 +61,17 @@ public sealed partial class Candidate public global::System.Collections.Generic.IList? SafetyRatings { get; set; } /// - /// Output only. Index of the candidate in the list of response candidates.
+ /// Output only. Token count for this candidate.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("index")] - public int? Index { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("tokenCount")] + public int? TokenCount { get; set; } /// - /// Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.
- /// Included only in responses + /// Metadata related to url context retrieval tool. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("finishMessage")] - public string? FinishMessage { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("urlContextMetadata")] + public global::Google.Gemini.UrlContextMetadata? UrlContextMetadata { 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. @@ -75,17 +80,12 @@ public sealed partial class Candidate public global::Google.Gemini.Content? Content { get; set; } /// - /// Logprobs Result - /// - [global::System.Text.Json.Serialization.JsonPropertyName("logprobsResult")] - public global::Google.Gemini.LogprobsResult? LogprobsResult { get; set; } - - /// - /// Output only. Token count for this 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 ///
- [global::System.Text.Json.Serialization.JsonPropertyName("tokenCount")] - public int? TokenCount { 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; } /// /// Additional properties that are not explicitly defined in the schema @@ -96,77 +96,77 @@ public sealed partial class Candidate /// /// Initializes a new instance of the class. /// - /// - /// A collection of source attributions for a piece of content. - /// /// /// Metadata returned to client when grounding is enabled. /// - /// - /// Metadata related to url context retrieval tool. - /// - /// - /// Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.
- /// Included only in responses - /// /// /// Output only. Average log probability score of the candidate.
/// Included only in responses /// - /// - /// Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.
+ /// + /// 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 /// - /// - /// List of ratings for the safety of a response candidate. There is at most one rating per category. - /// /// /// Output only. Index of the candidate in the list of response candidates.
/// 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 + /// + /// A collection of source attributions for a piece of content. /// - /// - /// 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. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.
+ /// Included only in responses /// /// /// Logprobs Result /// + /// + /// List of ratings for the safety of a response candidate. There is at most one rating per category. + /// /// /// Output only. Token count for this candidate.
/// Included only in responses /// + /// + /// Metadata related to url context retrieval tool. + /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.
+ /// Included only in responses + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Candidate( - global::Google.Gemini.CitationMetadata? citationMetadata, global::Google.Gemini.GroundingMetadata? groundingMetadata, - global::Google.Gemini.UrlContextMetadata? urlContextMetadata, - global::System.Collections.Generic.IList? groundingAttributions, double? avgLogprobs, - global::Google.Gemini.CandidateFinishReason? finishReason, - global::System.Collections.Generic.IList? safetyRatings, - int? index, string? finishMessage, - global::Google.Gemini.Content? content, + int? index, + global::Google.Gemini.CitationMetadata? citationMetadata, + global::System.Collections.Generic.IList? groundingAttributions, global::Google.Gemini.LogprobsResult? logprobsResult, - int? tokenCount) + global::System.Collections.Generic.IList? safetyRatings, + int? tokenCount, + global::Google.Gemini.UrlContextMetadata? urlContextMetadata, + global::Google.Gemini.Content? content, + global::Google.Gemini.CandidateFinishReason? finishReason) { - this.CitationMetadata = citationMetadata; this.GroundingMetadata = groundingMetadata; - this.UrlContextMetadata = urlContextMetadata; - this.GroundingAttributions = groundingAttributions; this.AvgLogprobs = avgLogprobs; - this.FinishReason = finishReason; - this.SafetyRatings = safetyRatings; - this.Index = index; this.FinishMessage = finishMessage; - this.Content = content; + this.Index = index; + this.CitationMetadata = citationMetadata; + this.GroundingAttributions = groundingAttributions; this.LogprobsResult = logprobsResult; + this.SafetyRatings = safetyRatings; this.TokenCount = tokenCount; + this.UrlContextMetadata = urlContextMetadata; + this.Content = content; + this.FinishReason = finishReason; } /// 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 c06cc88c..f12c165b 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,16 +9,16 @@ 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. URI that is attributed as a source for a portion of the text. /// - [global::System.Text.Json.Serialization.JsonPropertyName("startIndex")] - public int? StartIndex { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("uri")] + public string? Uri { get; set; } /// - /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("license")] - public string? License { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("startIndex")] + public int? StartIndex { get; set; } /// /// Optional. End of the attributed segment, exclusive. @@ -27,10 +27,10 @@ public sealed partial class CitationSource public int? EndIndex { get; set; } /// - /// Optional. URI that is attributed as a source for a portion of the text. + /// 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("uri")] - public string? Uri { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("license")] + public string? License { 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. URI that is attributed as a source for a portion of the text. + /// /// /// Optional. Start of segment of the response that is attributed to this source. Index indicates the start of the segment, measured in bytes. /// - /// - /// Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations. - /// /// /// Optional. End of the attributed segment, exclusive. /// - /// - /// Optional. URI that is attributed as a source for a portion of the text. + /// + /// Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CitationSource( + string? uri, int? startIndex, - string? license, int? endIndex, - string? uri) + string? license) { + this.Uri = uri; this.StartIndex = startIndex; - this.License = license; this.EndIndex = endIndex; - this.Uri = uri; + this.License = license; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CodeExecutionResult.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CodeExecutionResult.g.cs index 11556e1a..857028fb 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 @@ -14,6 +14,12 @@ public sealed partial class CodeExecutionResult [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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("output")] + public string? Output { get; set; } + /// /// Required. Outcome of the code execution. /// @@ -21,12 +27,6 @@ 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. Contains stdout when code execution is successful, stderr or other description otherwise. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("output")] - public string? Output { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -39,23 +39,23 @@ 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. /// - /// - /// Required. Outcome of the code execution. - /// /// /// Optional. Contains stdout when code execution is successful, stderr or other description otherwise. /// + /// + /// Required. Outcome of the code execution. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CodeExecutionResult( string? id, - global::Google.Gemini.CodeExecutionResultOutcome? outcome, - string? output) + string? output, + global::Google.Gemini.CodeExecutionResultOutcome? outcome) { this.Id = id; - this.Outcome = outcome; this.Output = output; + this.Outcome = outcome; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ComputerUse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ComputerUse.g.cs index fcd092d0..dbc49ecf 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 @@ -9,10 +9,10 @@ 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. + /// Optional. Whether enable the prompt injection detection check on computer-use request. /// - [global::System.Text.Json.Serialization.JsonPropertyName("excludedPredefinedFunctions")] - public global::System.Collections.Generic.IList? ExcludedPredefinedFunctions { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("enablePromptInjectionDetection")] + public bool? EnablePromptInjectionDetection { get; set; } /// /// Optional. Disabled safety policies for computer use. @@ -28,10 +28,10 @@ public sealed partial class ComputerUse public global::Google.Gemini.ComputerUseEnvironment? Environment { get; set; } /// - /// Optional. Whether enable the prompt injection detection check on computer-use request. + /// 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("enablePromptInjectionDetection")] - public bool? EnablePromptInjectionDetection { get; set; } + [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 @@ -42,8 +42,8 @@ public sealed partial class ComputerUse /// /// Initializes a new instance of the class. /// - /// - /// 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. + /// + /// Optional. Whether enable the prompt injection detection check on computer-use request. /// /// /// Optional. Disabled safety policies for computer use. @@ -51,22 +51,22 @@ public sealed partial class ComputerUse /// /// Required. The environment being operated. /// - /// - /// Optional. Whether enable the prompt injection detection check on computer-use request. + /// + /// 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. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ComputerUse( - global::System.Collections.Generic.IList? excludedPredefinedFunctions, + bool? enablePromptInjectionDetection, global::System.Collections.Generic.IList? disabledSafetyPolicies, global::Google.Gemini.ComputerUseEnvironment? environment, - bool? enablePromptInjectionDetection) + global::System.Collections.Generic.IList? excludedPredefinedFunctions) { - this.ExcludedPredefinedFunctions = excludedPredefinedFunctions; + this.EnablePromptInjectionDetection = enablePromptInjectionDetection; this.DisabledSafetyPolicies = disabledSafetyPolicies; this.Environment = environment; - this.EnablePromptInjectionDetection = enablePromptInjectionDetection; + this.ExcludedPredefinedFunctions = excludedPredefinedFunctions; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ContentEmbedding.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ContentEmbedding.g.cs index 941fe884..2381f72d 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ContentEmbedding.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ContentEmbedding.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ContentEmbedding { - /// - /// This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048]). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("shape")] - public global::System.Collections.Generic.IList? Shape { get; set; } - /// /// The embedding values. This is for 3P users only and will not be populated for 1P calls. /// [global::System.Text.Json.Serialization.JsonPropertyName("values")] public global::System.Collections.Generic.IList? Values { get; set; } + /// + /// This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048]). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("shape")] + public global::System.Collections.Generic.IList? Shape { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class ContentEmbedding /// /// Initializes a new instance of the class. /// - /// - /// This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048]). - /// /// /// The embedding values. This is for 3P users only and will not be populated for 1P calls. /// + /// + /// This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048]). + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ContentEmbedding( - global::System.Collections.Generic.IList? shape, - global::System.Collections.Generic.IList? values) + global::System.Collections.Generic.IList? values, + global::System.Collections.Generic.IList? shape) { - this.Shape = shape; this.Values = values; + this.Shape = shape; } /// 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 3f482ef3..7cdce421 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Corpus.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Corpus.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class Corpus { - /// - /// 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" - /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } - /// /// Output only. The Timestamp of when the `Corpus` was created.
/// Included only in responses @@ -28,6 +22,12 @@ public sealed partial class Corpus [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } + /// + /// Optional. The human-readable display name for the `Corpus`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" + /// + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } + /// /// Output only. The Timestamp of when the `Corpus` was last updated.
/// Included only in responses @@ -44,9 +44,6 @@ public sealed partial class Corpus /// /// Initializes a new instance of the class. /// - /// - /// Optional. The human-readable display name for the `Corpus`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" - /// /// /// Output only. The Timestamp of when the `Corpus` was created.
/// Included only in responses @@ -55,6 +52,9 @@ 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 /// + /// + /// Optional. The human-readable display name for the `Corpus`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" + /// /// /// Output only. The Timestamp of when the `Corpus` was last updated.
/// Included only in responses @@ -63,14 +63,14 @@ public sealed partial class Corpus [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Corpus( - string? displayName, string? createTime, string? name, + string? displayName, string? updateTime) { - this.DisplayName = displayName; this.CreateTime = createTime; this.Name = name; + this.DisplayName = displayName; this.UpdateTime = updateTime; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CountTokensRequest.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CountTokensRequest.g.cs index 263ea346..b3630d1d 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CountTokensRequest.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CountTokensRequest.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini ///
public sealed partial class CountTokensRequest { - /// - /// Optional. The input given to the model as a prompt. This field is ignored when `generate_content_request` is set. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("contents")] - public global::System.Collections.Generic.IList? Contents { get; set; } - /// /// Request to generate a completion from the model. /// [global::System.Text.Json.Serialization.JsonPropertyName("generateContentRequest")] public global::Google.Gemini.GenerateContentRequest? GenerateContentRequest { get; set; } + /// + /// Optional. The input given to the model as a prompt. This field is ignored when `generate_content_request` is set. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("contents")] + public global::System.Collections.Generic.IList? Contents { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class CountTokensRequest /// /// Initializes a new instance of the class. /// - /// - /// Optional. The input given to the model as a prompt. This field is ignored when `generate_content_request` is set. - /// /// /// Request to generate a completion from the model. /// + /// + /// Optional. The input given to the model as a prompt. This field is ignored when `generate_content_request` is set. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CountTokensRequest( - global::System.Collections.Generic.IList? contents, - global::Google.Gemini.GenerateContentRequest? generateContentRequest) + global::Google.Gemini.GenerateContentRequest? generateContentRequest, + global::System.Collections.Generic.IList? contents) { - this.Contents = contents; this.GenerateContentRequest = generateContentRequest; + this.Contents = contents; } /// 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 01ccff25..def5d1e7 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CountTokensResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CountTokensResponse.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class CountTokensResponse { + /// + /// 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 request input.
/// Included only in responses @@ -15,18 +21,6 @@ public sealed partial class CountTokensResponse [global::System.Text.Json.Serialization.JsonPropertyName("promptTokensDetails")] public global::System.Collections.Generic.IList? PromptTokensDetails { get; set; } - /// - /// The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("totalTokens")] - public int? TotalTokens { get; set; } - - /// - /// 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 @@ -34,6 +28,12 @@ public sealed partial class CountTokensResponse [global::System.Text.Json.Serialization.JsonPropertyName("cacheTokensDetails")] public global::System.Collections.Generic.IList? CacheTokensDetails { get; set; } + /// + /// The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("totalTokens")] + public int? TotalTokens { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -43,33 +43,33 @@ 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 request input.
/// Included only in responses /// - /// - /// The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative. - /// - /// - /// Number of tokens in the cached part of the prompt (the cached content). - /// /// /// Output only. List of modalities that were processed in the cached content.
/// Included only in responses /// + /// + /// The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CountTokensResponse( - global::System.Collections.Generic.IList? promptTokensDetails, - int? totalTokens, int? cachedContentTokenCount, - global::System.Collections.Generic.IList? cacheTokensDetails) + global::System.Collections.Generic.IList? promptTokensDetails, + global::System.Collections.Generic.IList? cacheTokensDetails, + int? totalTokens) { - this.PromptTokensDetails = promptTokensDetails; - this.TotalTokens = totalTokens; this.CachedContentTokenCount = cachedContentTokenCount; + this.PromptTokensDetails = promptTokensDetails; this.CacheTokensDetails = cacheTokensDetails; + this.TotalTokens = totalTokens; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomLongRunningOperation.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomLongRunningOperation.g.cs index 61ebda56..59f16ec1 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 @@ -14,30 +14,30 @@ public sealed partial class CustomLongRunningOperation [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. - /// - [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). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("error")] - 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}`. /// [global::System.Text.Json.Serialization.JsonPropertyName("name")] 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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("done")] + public bool? Done { get; set; } + /// /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. /// [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] public object? Metadata { get; set; } + /// + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("error")] + public global::Google.Gemini.Status? Error { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -50,33 +50,33 @@ public sealed partial class CustomLongRunningOperation /// /// 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. - /// - /// - /// 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. + /// /// /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. /// + /// + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CustomLongRunningOperation( object? response, - bool? done, - global::Google.Gemini.Status? error, string? name, - object? metadata) + bool? done, + object? metadata, + global::Google.Gemini.Status? error) { this.Response = response; - this.Done = done; - this.Error = error; this.Name = name; + this.Done = done; this.Metadata = metadata; + this.Error = error; } /// 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 77f1ef02..996fb034 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 @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class CustomMetadata { - /// - /// Required. The key of the metadata to store. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("key")] - public string? Key { get; set; } - /// /// The string value of the metadata to store. /// [global::System.Text.Json.Serialization.JsonPropertyName("stringValue")] public string? StringValue { get; set; } + /// + /// Required. The key of the metadata to store. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("key")] + public string? Key { get; set; } + /// /// User provided string values assigned to a single metadata key. /// @@ -41,12 +41,12 @@ public sealed partial class CustomMetadata /// /// Initializes a new instance of the class. /// - /// - /// Required. The key of the metadata to store. - /// /// /// The string value of the metadata to store. /// + /// + /// Required. The key of the metadata to store. + /// /// /// User provided string values assigned to a single metadata key. /// @@ -57,13 +57,13 @@ public sealed partial class CustomMetadata [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CustomMetadata( - string? key, string? stringValue, + string? key, global::Google.Gemini.StringList? stringListValue, float? numericValue) { - this.Key = key; this.StringValue = stringValue; + this.Key = key; this.StringListValue = stringListValue; 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 e207e5d2..36789c8f 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 @@ -8,6 +8,13 @@ namespace Google.Gemini /// public sealed partial class Document { + /// + /// 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; } + /// /// Output only. Current state of the `Document`.
/// Included only in responses @@ -17,11 +24,17 @@ public sealed partial class Document public global::Google.Gemini.DocumentState? State { get; set; } /// - /// Output only. The size of raw bytes ingested into the 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" + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } + + /// + /// 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.
@@ -37,17 +50,11 @@ public sealed partial class Document public string? Name { get; set; } /// - /// Output only. The Timestamp of when the `Document` was last updated.
+ /// Output only. The size of raw bytes ingested into the Document.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } - - /// - /// Optional. The human-readable display name for the `Document`. The display name must be no more than 512 characters in length, including spaces. Example: "Semantic Retriever Documentation" - /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] + public string? SizeBytes { get; set; } /// /// Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`. @@ -55,13 +62,6 @@ public sealed partial class Document [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] public global::System.Collections.Generic.IList? CustomMetadata { get; set; } - /// - /// Output only. The Timestamp of when the `Document` was created.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -71,12 +71,19 @@ public sealed partial class Document /// /// Initializes a new instance of the class. /// + /// + /// Output only. The Timestamp of when the `Document` was created.
+ /// Included only in responses + /// /// /// Output only. Current state of the `Document`.
/// Included only in responses /// - /// - /// Output only. The size of raw bytes ingested into the 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" + /// + /// + /// Output only. The Timestamp of when the `Document` was last updated.
/// Included only in responses /// /// @@ -86,41 +93,34 @@ public sealed partial class Document /// /// 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.
+ /// + /// 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" - /// /// /// Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`. /// - /// - /// Output only. The Timestamp of when the `Document` was created.
- /// Included only in responses - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Document( + string? createTime, global::Google.Gemini.DocumentState? state, - string? sizeBytes, + string? displayName, + string? updateTime, string? mimeType, string? name, - string? updateTime, - string? displayName, - global::System.Collections.Generic.IList? customMetadata, - string? createTime) + string? sizeBytes, + global::System.Collections.Generic.IList? customMetadata) { + this.CreateTime = createTime; this.State = state; - this.SizeBytes = sizeBytes; + this.DisplayName = displayName; + this.UpdateTime = updateTime; this.MimeType = mimeType; this.Name = name; - this.UpdateTime = updateTime; - this.DisplayName = displayName; + this.SizeBytes = sizeBytes; this.CustomMetadata = customMetadata; - 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 50150469..80c74ef8 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,19 +9,16 @@ namespace Google.Gemini public sealed partial class EmbedContentBatch { /// - /// Output only. The state of the batch.
- /// Included only in responses + /// Configures the input to the batch request. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("state")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateJsonConverter))] - public global::Google.Gemini.EmbedContentBatchState? State { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("inputConfig")] + public global::Google.Gemini.InputEmbedContentConfig? 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; } /// /// Output only. The time at which the batch was created.
@@ -31,22 +28,23 @@ public sealed partial class EmbedContentBatch public string? CreateTime { get; set; } /// - /// Configures the input to the batch request. + /// 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("inputConfig")] - public global::Google.Gemini.InputEmbedContentConfig? InputConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("priority")] + public string? Priority { get; set; } /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("model")] - public string? Model { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// - /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. + /// Stats about the batch. /// - [global::System.Text.Json.Serialization.JsonPropertyName("output")] - public global::Google.Gemini.EmbedContentBatchOutput? Output { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("batchStats")] + public global::Google.Gemini.EmbedContentBatchStats? BatchStats { get; set; } /// /// Output only. The time at which the batch was last updated.
@@ -56,29 +54,31 @@ public sealed partial class EmbedContentBatch public string? UpdateTime { get; set; } /// - /// Stats about the batch. + /// Output only. The time at which the batch processing completed.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("batchStats")] - public global::Google.Gemini.EmbedContentBatchStats? BatchStats { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] + public string? EndTime { get; set; } /// - /// Required. The user-defined name of this batch. + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("model")] + public string? Model { get; set; } /// - /// Output only. The time at which the batch processing completed.
+ /// Output only. The state of the batch.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] - public string? EndTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("state")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateJsonConverter))] + public global::Google.Gemini.EmbedContentBatchState? State { get; set; } /// - /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. + /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. /// - [global::System.Text.Json.Serialization.JsonPropertyName("priority")] - public string? Priority { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("output")] + public global::Google.Gemini.EmbedContentBatchOutput? Output { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -89,71 +89,71 @@ public sealed partial class EmbedContentBatch /// /// Initializes a new instance of the class. /// - /// - /// Output only. The state of the batch.
- /// Included only in responses + /// + /// 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. /// /// /// Output only. The time at which the batch was created.
/// Included only in responses /// - /// - /// Configures the input to the batch request. - /// - /// - /// 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. + /// + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// - /// - /// Output only. The time at which the batch was last updated.
+ /// + /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
/// Included only in responses /// /// /// Stats about the batch. /// - /// - /// Required. The user-defined name of this batch. + /// + /// Output only. The time at which the batch was last updated.
+ /// Included only in responses /// /// /// Output only. The time at which the batch processing completed.
/// Included only in responses /// - /// - /// 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. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Output only. The state of the batch.
+ /// Included only in responses + /// + /// + /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentBatch( - global::Google.Gemini.EmbedContentBatchState? state, - string? name, - string? createTime, global::Google.Gemini.InputEmbedContentConfig? inputConfig, - string? model, - global::Google.Gemini.EmbedContentBatchOutput? output, - string? updateTime, - global::Google.Gemini.EmbedContentBatchStats? batchStats, string? displayName, + string? createTime, + string? priority, + string? name, + global::Google.Gemini.EmbedContentBatchStats? batchStats, + string? updateTime, string? endTime, - string? priority) + string? model, + global::Google.Gemini.EmbedContentBatchState? state, + global::Google.Gemini.EmbedContentBatchOutput? output) { - this.State = state; - this.Name = name; - this.CreateTime = createTime; this.InputConfig = inputConfig; - this.Model = model; - this.Output = output; - this.UpdateTime = updateTime; - this.BatchStats = batchStats; this.DisplayName = displayName; - this.EndTime = endTime; + this.CreateTime = createTime; this.Priority = priority; + this.Name = name; + this.BatchStats = batchStats; + this.UpdateTime = updateTime; + this.EndTime = endTime; + this.Model = model; + this.State = state; + this.Output = output; } /// 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 30cdb5ae..97b3e201 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 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; } /// - /// Output only. The number of requests that failed to be processed.
+ /// Output only. The number of requests that were successfully processed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("failedRequestCount")] - public string? FailedRequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("successfulRequestCount")] + public string? SuccessfulRequestCount { get; set; } /// - /// Output only. The number of requests that are still pending processing.
+ /// Output only. The number of requests that failed to be processed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("pendingRequestCount")] - public string? PendingRequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("failedRequestCount")] + public string? FailedRequestCount { get; set; } /// - /// Output only. The number of requests that were successfully processed.
+ /// Output only. The number of requests in the batch.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("successfulRequestCount")] - public string? SuccessfulRequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("requestCount")] + public string? RequestCount { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -45,14 +45,6 @@ public sealed partial class EmbedContentBatchStats /// /// Initializes a new instance of the class. /// - /// - /// Output only. The number of requests in the batch.
- /// Included only in responses - /// - /// - /// Output only. The number of requests that failed to be processed.
- /// Included only in responses - /// /// /// Output only. The number of requests that are still pending processing.
/// Included only in responses @@ -61,19 +53,27 @@ public sealed partial class EmbedContentBatchStats /// 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 + /// + /// + /// Output only. The number of requests in the batch.
+ /// Included only in responses + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentBatchStats( - string? requestCount, - string? failedRequestCount, string? pendingRequestCount, - string? successfulRequestCount) + string? successfulRequestCount, + string? failedRequestCount, + string? requestCount) { - this.RequestCount = requestCount; - this.FailedRequestCount = failedRequestCount; this.PendingRequestCount = pendingRequestCount; this.SuccessfulRequestCount = successfulRequestCount; + this.FailedRequestCount = failedRequestCount; + 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 f4ceea8b..075d15f3 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. Whether to silently truncate the input content if it's longer than the maximum sequence length. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("autoTruncate")] - public bool? AutoTruncate { get; set; } - - /// - /// Optional. Whether to enable OCR for document content. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("documentOcr")] - public bool? DocumentOcr { get; set; } - /// /// Optional. The title for the text. /// @@ -33,6 +21,18 @@ public sealed partial class EmbedContentConfig [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeJsonConverter))] public global::Google.Gemini.EmbedContentConfigTaskType? TaskType { get; set; } + /// + /// Optional. Whether to enable OCR for document content. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("documentOcr")] + public bool? DocumentOcr { get; set; } + + /// + /// Optional. Whether to silently truncate the input content if it's longer than the maximum sequence length. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("autoTruncate")] + public bool? AutoTruncate { get; set; } + /// /// Optional. Reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. /// @@ -54,18 +54,18 @@ public sealed partial class EmbedContentConfig /// /// Initializes a new instance of the class. /// - /// - /// Optional. Whether to silently truncate the input content if it's longer than the maximum sequence length. - /// - /// - /// Optional. Whether to enable OCR for document content. - /// /// /// Optional. The title for the text. /// /// /// Optional. The task type of the embedding. /// + /// + /// Optional. Whether to enable OCR for document content. + /// + /// + /// Optional. Whether to silently truncate the input content if it's longer than the maximum sequence length. + /// /// /// Optional. Reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. /// @@ -76,17 +76,17 @@ public sealed partial class EmbedContentConfig [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentConfig( - bool? autoTruncate, - bool? documentOcr, string? title, global::Google.Gemini.EmbedContentConfigTaskType? taskType, + bool? documentOcr, + bool? autoTruncate, int? outputDimensionality, bool? audioTrackExtraction) { - this.AutoTruncate = autoTruncate; - this.DocumentOcr = documentOcr; this.Title = title; this.TaskType = taskType; + this.DocumentOcr = documentOcr; + this.AutoTruncate = autoTruncate; this.OutputDimensionality = outputDimensionality; this.AudioTrackExtraction = audioTrackExtraction; } 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 04b426ef..b0cfa19b 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 @@ -11,10 +11,11 @@ namespace Google.Gemini public sealed partial class EmbedContentRequest { /// - /// 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; } /// /// 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}` @@ -22,6 +23,12 @@ public sealed partial class EmbedContentRequest [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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("content")] + public global::Google.Gemini.Content? Content { 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`). /// @@ -30,19 +37,6 @@ public sealed partial class EmbedContentRequest [global::System.Obsolete("This property marked as deprecated.")] public global::Google.Gemini.EmbedContentRequestTaskType? TaskType { 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`). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("outputDimensionality")] - [global::System.Obsolete("This property marked as deprecated.")] - public int? OutputDimensionality { get; set; } - - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("content")] - public global::Google.Gemini.Content? Content { get; set; } - /// /// Optional. 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. /// @@ -50,6 +44,12 @@ public sealed partial class EmbedContentRequest [global::System.Obsolete("This property marked as deprecated.")] public string? Title { get; set; } + /// + /// Configurations for the EmbedContent request. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("embedContentConfig")] + public global::Google.Gemini.EmbedContentConfig? EmbedContentConfig { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -59,26 +59,26 @@ public sealed partial class EmbedContentRequest /// /// Initializes a new instance of the class. /// - /// - /// 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}` /// /// /// 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. /// + /// + /// Configurations for the EmbedContent request. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentRequest( - global::Google.Gemini.EmbedContentConfig? embedContentConfig, string? model, - global::Google.Gemini.Content? content) + global::Google.Gemini.Content? content, + global::Google.Gemini.EmbedContentConfig? embedContentConfig) { - this.EmbedContentConfig = embedContentConfig; this.Model = model; this.Content = content; + this.EmbedContentConfig = embedContentConfig; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentResponse.g.cs index ced79a0c..6b1b3f35 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentResponse.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class EmbedContentResponse { - /// - /// Metadata on the usage of the embedding request. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] - public global::Google.Gemini.EmbeddingUsageMetadata? UsageMetadata { get; set; } - /// /// A list of floats representing an embedding. /// [global::System.Text.Json.Serialization.JsonPropertyName("embedding")] public global::Google.Gemini.ContentEmbedding? Embedding { get; set; } + /// + /// Metadata on the usage of the embedding request. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] + public global::Google.Gemini.EmbeddingUsageMetadata? UsageMetadata { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class EmbedContentResponse /// /// Initializes a new instance of the class. /// - /// - /// Metadata on the usage of the embedding request. - /// /// /// A list of floats representing an embedding. /// + /// + /// Metadata on the usage of the embedding request. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentResponse( - global::Google.Gemini.EmbeddingUsageMetadata? usageMetadata, - global::Google.Gemini.ContentEmbedding? embedding) + global::Google.Gemini.ContentEmbedding? embedding, + global::Google.Gemini.EmbeddingUsageMetadata? usageMetadata) { - this.UsageMetadata = usageMetadata; this.Embedding = embedding; + this.UsageMetadata = usageMetadata; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbeddingUsageMetadata.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbeddingUsageMetadata.g.cs index ecd1c5d4..20f3b809 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbeddingUsageMetadata.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbeddingUsageMetadata.g.cs @@ -9,18 +9,18 @@ namespace Google.Gemini public sealed partial class EmbeddingUsageMetadata { /// - /// Output only. List of modalities that were processed in the request input.
+ /// Output only. Number of tokens in the prompt.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("promptTokenDetails")] - public global::System.Collections.Generic.IList? PromptTokenDetails { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("promptTokenCount")] + public int? PromptTokenCount { get; set; } /// - /// Output only. Number of tokens in the prompt.
+ /// Output only. List of modalities that were processed in the request input.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("promptTokenCount")] - public int? PromptTokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("promptTokenDetails")] + public global::System.Collections.Generic.IList? PromptTokenDetails { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -31,23 +31,23 @@ public sealed partial class EmbeddingUsageMetadata /// /// Initializes a new instance of the class. /// - /// - /// Output only. List of modalities that were processed in the request input.
- /// Included only in responses - /// /// /// Output only. Number of tokens in the prompt.
/// Included only in responses /// + /// + /// Output only. List of modalities that were processed in the request input.
+ /// Included only in responses + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbeddingUsageMetadata( - global::System.Collections.Generic.IList? promptTokenDetails, - int? promptTokenCount) + int? promptTokenCount, + global::System.Collections.Generic.IList? promptTokenDetails) { - this.PromptTokenDetails = promptTokenDetails; this.PromptTokenCount = promptTokenCount; + this.PromptTokenDetails = promptTokenDetails; } /// 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 358665ad..9af6f777 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 @@ -14,6 +14,12 @@ public sealed partial class ExecutableCode [global::System.Text.Json.Serialization.JsonPropertyName("id")] public string? Id { get; set; } + /// + /// Required. The code to be executed. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("code")] + public string? Code { get; set; } + /// /// Required. Programming language of the `code`. /// @@ -21,12 +27,6 @@ public sealed partial class ExecutableCode [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageJsonConverter))] public global::Google.Gemini.ExecutableCodeLanguage? Language { get; set; } - /// - /// Required. The code to be executed. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("code")] - public string? Code { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -39,23 +39,23 @@ public sealed partial class ExecutableCode /// /// 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. /// + /// + /// Required. Programming language of the `code`. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ExecutableCode( string? id, - global::Google.Gemini.ExecutableCodeLanguage? language, - string? code) + string? code, + global::Google.Gemini.ExecutableCodeLanguage? language) { this.Id = id; - this.Language = language; this.Code = code; + this.Language = language; } /// 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 8eac22e1..59336479 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,24 +9,25 @@ namespace Google.Gemini public sealed partial class File { /// - /// Output only. The timestamp of when the `File` was created.
+ /// Output only. The timestamp of when the `File` 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; } /// - /// 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` + /// Metadata for a video `File`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("videoMetadata")] + public global::Google.Gemini.VideoFileMetadata? VideoMetadata { get; set; } /// - /// Source of the File. + /// Output only. Processing state of the File.
+ /// 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("state")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FileStateJsonConverter))] + public global::Google.Gemini.FileState? State { get; set; } /// /// Output only. The download uri of the `File`.
@@ -36,30 +37,38 @@ public sealed partial class File public string? DownloadUri { 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. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.
+ /// Output only. Size of the file in bytes.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("expirationTime")] - public string? ExpirationTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] + public string? SizeBytes { 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` was last updated.
+ /// Source of the File. + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("source")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FileSourceJsonConverter))] + public global::Google.Gemini.FileSource? Source { get; set; } + + /// + /// 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("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("expirationTime")] + public string? ExpirationTime { 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). @@ -68,19 +77,18 @@ public sealed partial class File public global::Google.Gemini.Status? Error { get; set; } /// - /// Output only. Processing state of the File.
+ /// Output only. SHA-256 hash of the uploaded bytes.
/// 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("sha256Hash")] + public byte[]? Sha256Hash { get; set; } /// - /// Output only. Size of the file in bytes.
+ /// Output only. MIME type of the file.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] - public string? SizeBytes { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] + public string? MimeType { get; set; } /// /// Output only. The uri of the `File`.
@@ -90,18 +98,10 @@ public sealed partial class File public string? Uri { get; set; } /// - /// 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. MIME type 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" ///
- [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] - public string? MimeType { 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. The timestamp of when the `File` was created.
+ /// + /// Output only. The timestamp of when the `File` was last updated.
/// 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` + /// + /// Metadata for a video `File`. /// - /// - /// Source of the File. + /// + /// Output only. Processing state of the File.
+ /// Included only in responses /// /// /// Output only. The download uri of the `File`.
/// Included only in responses /// - /// - /// 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. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.
+ /// + /// Output only. Size of the file in bytes.
/// 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` was created.
+ /// Included only in responses /// - /// - /// Output only. The timestamp of when the `File` was last updated.
+ /// + /// Source 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 /// /// /// 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. Processing state of the File.
+ /// + /// Output only. SHA-256 hash of the uploaded bytes.
/// Included only in responses /// - /// - /// Output only. Size of the file in bytes.
+ /// + /// Output only. MIME type of the file.
/// Included only in responses /// /// /// Output only. The uri of the `File`.
/// Included only in responses /// - /// - /// Output only. SHA-256 hash of the uploaded bytes.
- /// Included only in responses - /// - /// - /// Output only. MIME type 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( - string? createTime, + string? updateTime, + global::Google.Gemini.VideoFileMetadata? videoMetadata, + global::Google.Gemini.FileState? state, + string? downloadUri, string? name, + string? sizeBytes, + string? createTime, global::Google.Gemini.FileSource? source, - string? downloadUri, - global::Google.Gemini.VideoFileMetadata? videoMetadata, string? expirationTime, - string? displayName, - string? updateTime, global::Google.Gemini.Status? error, - global::Google.Gemini.FileState? state, - string? sizeBytes, - string? uri, byte[]? sha256Hash, - string? mimeType) + string? mimeType, + string? uri, + string? displayName) { - this.CreateTime = createTime; + this.UpdateTime = updateTime; + this.VideoMetadata = videoMetadata; + this.State = state; + this.DownloadUri = downloadUri; this.Name = name; + this.SizeBytes = sizeBytes; + this.CreateTime = createTime; this.Source = source; - this.DownloadUri = downloadUri; - this.VideoMetadata = videoMetadata; this.ExpirationTime = expirationTime; - this.DisplayName = displayName; - this.UpdateTime = updateTime; this.Error = error; - this.State = state; - this.SizeBytes = sizeBytes; - this.Uri = uri; this.Sha256Hash = sha256Hash; this.MimeType = mimeType; + this.Uri = uri; + this.DisplayName = displayName; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileSearch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileSearch.g.cs index 0cb34874..a5f4c4de 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileSearch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileSearch.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class FileSearch { + /// + /// Required. The names of the file_search_stores to retrieve from. Example: `fileSearchStores/my-file-search-store-123` + /// + [global::System.Text.Json.Serialization.JsonPropertyName("fileSearchStoreNames")] + public global::System.Collections.Generic.IList? FileSearchStoreNames { get; set; } + /// /// Optional. Metadata filter to apply to the semantic retrieval documents and chunks. /// @@ -20,12 +26,6 @@ public sealed partial class FileSearch [global::System.Text.Json.Serialization.JsonPropertyName("topK")] public int? TopK { get; set; } - /// - /// Required. The names of the file_search_stores to retrieve from. Example: `fileSearchStores/my-file-search-store-123` - /// - [global::System.Text.Json.Serialization.JsonPropertyName("fileSearchStoreNames")] - public global::System.Collections.Generic.IList? FileSearchStoreNames { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class FileSearch /// /// Initializes a new instance of the class. /// + /// + /// Required. The names of the file_search_stores to retrieve from. Example: `fileSearchStores/my-file-search-store-123` + /// /// /// Optional. Metadata filter to apply to the semantic retrieval documents and chunks. /// /// /// Optional. The number of semantic retrieval chunks to retrieve. /// - /// - /// Required. The names of the file_search_stores to retrieve from. Example: `fileSearchStores/my-file-search-store-123` - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FileSearch( + global::System.Collections.Generic.IList? fileSearchStoreNames, string? metadataFilter, - int? topK, - global::System.Collections.Generic.IList? fileSearchStoreNames) + int? topK) { + this.FileSearchStoreNames = fileSearchStoreNames; this.MetadataFilter = metadataFilter; this.TopK = topK; - this.FileSearchStoreNames = fileSearchStoreNames; } /// 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 85df09a5..b1abb3be 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileSearchStore.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileSearchStore.g.cs @@ -9,18 +9,11 @@ namespace Google.Gemini public sealed partial class FileSearchStore { /// - /// 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.
+ /// 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("failedDocumentsCount")] - public string? FailedDocumentsCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { 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`.
@@ -30,11 +23,17 @@ public sealed partial class FileSearchStore 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.
+ /// Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } + + /// + /// Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("activeDocumentsCount")] + public string? ActiveDocumentsCount { get; set; } /// /// Output only. The Timestamp of when the `FileSearchStore` was created.
@@ -44,17 +43,24 @@ public sealed partial class FileSearchStore public string? CreateTime { 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 number of documents in the `FileSearchStore` that have failed processing.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("embeddingModel")] - public string? EmbeddingModel { 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.
+ /// Output only. The number of documents in the `FileSearchStore` that are being processed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("activeDocumentsCount")] - public string? ActiveDocumentsCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("pendingDocumentsCount")] + public string? PendingDocumentsCount { 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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("embeddingModel")] + public string? EmbeddingModel { get; set; } /// /// Output only. The Timestamp of when the `FileSearchStore` was last updated.
@@ -63,12 +69,6 @@ public sealed partial class FileSearchStore [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] public string? UpdateTime { get; set; } - /// - /// Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" - /// - [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. 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.
+ /// + /// 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 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.
+ /// + /// Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" + /// + /// + /// Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.
/// Included only in responses /// /// /// Output only. The Timestamp of when the `FileSearchStore` was created.
/// 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 number of documents in the `FileSearchStore` that have failed processing.
+ /// Included only in responses /// - /// - /// Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.
+ /// + /// Output only. The number of documents in the `FileSearchStore` that are being processed.
/// 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 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" - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FileSearchStore( - string? pendingDocumentsCount, - string? failedDocumentsCount, - string? sizeBytes, string? name, + string? sizeBytes, + string? displayName, + string? activeDocumentsCount, string? createTime, + string? failedDocumentsCount, + string? pendingDocumentsCount, string? embeddingModel, - string? activeDocumentsCount, - string? updateTime, - string? displayName) + string? updateTime) { - this.PendingDocumentsCount = pendingDocumentsCount; - this.FailedDocumentsCount = failedDocumentsCount; - this.SizeBytes = sizeBytes; this.Name = name; + this.SizeBytes = sizeBytes; + this.DisplayName = displayName; + this.ActiveDocumentsCount = activeDocumentsCount; this.CreateTime = createTime; + this.FailedDocumentsCount = failedDocumentsCount; + this.PendingDocumentsCount = pendingDocumentsCount; this.EmbeddingModel = embeddingModel; - this.ActiveDocumentsCount = activeDocumentsCount; this.UpdateTime = updateTime; - 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 aeca76b6..f039747f 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 @@ -14,18 +14,18 @@ public sealed partial class FunctionCall [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { 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; } + /// + /// Optional. The function parameters and values in JSON object format. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("args")] + public object? Args { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -38,23 +38,23 @@ public sealed partial class FunctionCall /// /// 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. 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`. /// + /// + /// Optional. The function parameters and values in JSON object format. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionCall( string? name, - object? args, - string? id) + string? id, + object? args) { this.Name = name; - this.Args = args; this.Id = id; + this.Args = args; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionDeclaration.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionDeclaration.g.cs index 4f39172a..e7397d45 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 @@ -15,16 +15,10 @@ public sealed partial class FunctionDeclaration public string? Name { get; set; } /// - /// Optional. Describes the output from this function in JSON Schema format. The value specified by the schema is the response value of the function. This field is mutually exclusive with `response`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseJsonSchema")] - public object? ResponseJsonSchema { get; set; } - - /// - /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). + /// Required. A brief description of the function. /// - [global::System.Text.Json.Serialization.JsonPropertyName("parameters")] - public global::Google.Gemini.Schema? Parameters { 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. @@ -39,18 +33,24 @@ public sealed partial class FunctionDeclaration [global::System.Text.Json.Serialization.JsonPropertyName("response")] public global::Google.Gemini.Schema? Response { get; set; } - /// - /// Required. A brief description of the function. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("description")] - public string? Description { 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; } + /// + /// 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("responseJsonSchema")] + public object? ResponseJsonSchema { get; set; } + + /// + /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("parameters")] + public global::Google.Gemini.Schema? Parameters { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -63,11 +63,8 @@ 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`. - /// - /// - /// 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. /// /// /// Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method. @@ -75,31 +72,34 @@ public sealed partial class FunctionDeclaration /// /// 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. - /// /// /// Optional. Describes the parameters to the function in JSON Schema format. The schema must describe an object where the properties are the parameters to the function. For example: ``` { "type": "object", "properties": { "name": { "type": "string" }, "age": { "type": "integer" } }, "additionalProperties": false, "required": ["name", "age"], "propertyOrdering": ["name", "age"] } ``` This field is mutually exclusive with `parameters`. /// + /// + /// Optional. Describes the output from this function in JSON Schema format. The value specified by the schema is the response value of the function. This field is mutually exclusive with `response`. + /// + /// + /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionDeclaration( string? name, - object? responseJsonSchema, - global::Google.Gemini.Schema? parameters, + string? description, global::Google.Gemini.FunctionDeclarationBehavior? behavior, global::Google.Gemini.Schema? response, - string? description, - object? parametersJsonSchema) + object? parametersJsonSchema, + object? responseJsonSchema, + global::Google.Gemini.Schema? parameters) { this.Name = name; - this.ResponseJsonSchema = responseJsonSchema; - this.Parameters = parameters; + this.Description = description; this.Behavior = behavior; this.Response = response; - this.Description = description; this.ParametersJsonSchema = parametersJsonSchema; + this.ResponseJsonSchema = responseJsonSchema; + this.Parameters = parameters; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponse.g.cs index 4b1d3f36..e880840e 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,24 +8,30 @@ namespace Google.Gemini /// public sealed partial class FunctionResponse { - /// - /// Optional. Signals that function call continues, and more responses will be returned, turning the function call into a generator. Is only applicable to NON_BLOCKING function calls, is ignored otherwise. If set to false, future responses will not be considered. It is allowed to return empty `response` with `will_continue=False` to signal that the function call is finished. This may still trigger the model generation. To avoid triggering the generation and finish the function call, additionally set `scheduling` to `SILENT`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("willContinue")] - public bool? WillContinue { get; set; } - /// /// Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types. /// [global::System.Text.Json.Serialization.JsonPropertyName("parts")] public global::System.Collections.Generic.IList? Parts { 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`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("willContinue")] + public bool? WillContinue { get; set; } + /// /// Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128. /// [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. Multimedia can be included by using a subobject containing a single "$ref" key whose value is the `inline_data.display_name` of a `FunctionResponsePart` holding the multimedia. See https://ai.google.dev/gemini-api/docs/function-calling#multimodal. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("response")] + public object? Response { get; set; } + /// /// 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. /// @@ -33,12 +39,6 @@ public sealed partial class FunctionResponse [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingJsonConverter))] public global::Google.Gemini.FunctionResponseScheduling? Scheduling { get; set; } - /// - /// Required. The function response in JSON object format. Callers can use any keys of their choice that fit the function's syntax to return the function output, e.g. "output", "result", etc. In particular, if the function call failed to execute, the response can have an "error" key to return error details to the model. Multimedia can be included by using a subobject containing a single "$ref" key whose value is the `inline_data.display_name` of a `FunctionResponsePart` holding the multimedia. See https://ai.google.dev/gemini-api/docs/function-calling#multimodal. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("response")] - public object? Response { get; set; } - /// /// Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`. /// @@ -54,21 +54,21 @@ public sealed partial class FunctionResponse /// /// Initializes a new instance of the class. /// - /// - /// Optional. Signals that function call continues, and more responses will be returned, turning the function call into a generator. Is only applicable to NON_BLOCKING function calls, is ignored otherwise. If set to false, future responses will not be considered. It is allowed to return empty `response` with `will_continue=False` to signal that the function call is finished. This may still trigger the model generation. To avoid triggering the generation and finish the function call, additionally set `scheduling` to `SILENT`. - /// /// /// Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types. /// + /// + /// Optional. Signals that function call continues, and more responses will be returned, turning the function call into a generator. Is only applicable to NON_BLOCKING function calls, is ignored otherwise. If set to false, future responses will not be considered. It is allowed to return empty `response` with `will_continue=False` to signal that the function call is finished. This may still trigger the model generation. To avoid triggering the generation and finish the function call, additionally set `scheduling` to `SILENT`. + /// /// /// Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128. /// - /// - /// Optional. Specifies how the response should be scheduled in the conversation. Only applicable to NON_BLOCKING function calls, is ignored otherwise. Defaults to WHEN_IDLE. - /// /// /// Required. The function response in JSON object format. Callers can use any keys of their choice that fit the function's syntax to return the function output, e.g. "output", "result", etc. In particular, if the function call failed to execute, the response can have an "error" key to return error details to the model. Multimedia can be included by using a subobject containing a single "$ref" key whose value is the `inline_data.display_name` of a `FunctionResponsePart` holding the multimedia. See https://ai.google.dev/gemini-api/docs/function-calling#multimodal. /// + /// + /// 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. + /// /// /// Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`. /// @@ -76,18 +76,18 @@ public sealed partial class FunctionResponse [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionResponse( - bool? willContinue, global::System.Collections.Generic.IList? parts, + bool? willContinue, string? name, - global::Google.Gemini.FunctionResponseScheduling? scheduling, object? response, + global::Google.Gemini.FunctionResponseScheduling? scheduling, string? id) { - this.WillContinue = willContinue; this.Parts = parts; + this.WillContinue = willContinue; this.Name = name; - this.Scheduling = scheduling; this.Response = response; + this.Scheduling = scheduling; this.Id = id; } 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 3b3a1c25..b3132ac0 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 @@ -8,14 +8,6 @@ namespace Google.Gemini /// public sealed partial class GenerateContentBatch { - /// - /// Output only. The state of the batch.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("state")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateJsonConverter))] - public global::Google.Gemini.GenerateContentBatchState? State { get; set; } - /// /// Configures the input to the batch request. /// @@ -23,11 +15,10 @@ public sealed partial class GenerateContentBatch 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; } /// /// Output only. The time at which the batch was created.
@@ -36,18 +27,6 @@ public sealed partial class GenerateContentBatch [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] public string? CreateTime { 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; } - - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("model")] - public string? Model { get; set; } - /// /// Optional. 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. /// @@ -55,11 +34,11 @@ public sealed partial class GenerateContentBatch public string? Priority { get; set; } /// - /// Output only. The time at which the batch was last updated.
+ /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// /// Stats about the batch. @@ -68,10 +47,11 @@ public sealed partial class GenerateContentBatch public global::Google.Gemini.BatchStats? BatchStats { get; set; } /// - /// Required. The user-defined name of this batch. + /// Output only. The time at which the batch 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; } /// /// Output only. The time at which the batch processing completed.
@@ -80,6 +60,26 @@ public sealed partial class GenerateContentBatch [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] public string? EndTime { get; set; } + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("model")] + public string? Model { get; set; } + + /// + /// Output only. The state of the batch.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("state")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateJsonConverter))] + public global::Google.Gemini.GenerateContentBatchState? State { 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; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -89,71 +89,71 @@ public sealed partial class GenerateContentBatch /// /// Initializes a new instance of the class. /// - /// - /// Output only. The state of the batch.
- /// Included only in responses - /// /// /// 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. /// /// /// Output only. The time at which the batch was created.
/// Included only in responses /// - /// - /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. - /// - /// - /// 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. The time at which the batch was last updated.
+ /// + /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
/// Included only in responses /// /// /// Stats about the batch. /// - /// - /// Required. The user-defined name of this batch. + /// + /// Output only. The time at which the batch was last updated.
+ /// Included only in responses /// /// /// Output only. The time at which the batch processing completed.
/// Included only in responses /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Output only. The state of the batch.
+ /// Included only in responses + /// + /// + /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerateContentBatch( - global::Google.Gemini.GenerateContentBatchState? state, global::Google.Gemini.InputConfig? inputConfig, - string? name, + string? displayName, string? createTime, - global::Google.Gemini.GenerateContentBatchOutput? output, - string? model, string? priority, - string? updateTime, + string? name, global::Google.Gemini.BatchStats? batchStats, - string? displayName, - string? endTime) + string? updateTime, + string? endTime, + string? model, + global::Google.Gemini.GenerateContentBatchState? state, + global::Google.Gemini.GenerateContentBatchOutput? output) { - this.State = state; this.InputConfig = inputConfig; - this.Name = name; + this.DisplayName = displayName; this.CreateTime = createTime; - this.Output = output; - this.Model = model; this.Priority = priority; - this.UpdateTime = updateTime; + this.Name = name; this.BatchStats = batchStats; - this.DisplayName = displayName; + this.UpdateTime = updateTime; this.EndTime = endTime; + this.Model = model; + this.State = state; + this.Output = output; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatchOutput.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatchOutput.g.cs index bb020165..c34eb311 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatchOutput.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatchOutput.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class GenerateContentBatchOutput { + /// + /// The responses to the requests in the batch. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("inlinedResponses")] + public global::Google.Gemini.InlinedResponses? InlinedResponses { get; set; } + /// /// Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `GenerateContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests.
/// Included only in responses @@ -15,12 +21,6 @@ public sealed partial class GenerateContentBatchOutput [global::System.Text.Json.Serialization.JsonPropertyName("responsesFile")] public string? ResponsesFile { get; set; } - /// - /// The responses to the requests in the batch. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("inlinedResponses")] - public global::Google.Gemini.InlinedResponses? InlinedResponses { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,22 +30,22 @@ public sealed partial class GenerateContentBatchOutput /// /// Initializes a new instance of the class. /// + /// + /// The responses to the requests in the batch. + /// /// /// Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `GenerateContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests.
/// Included only in responses /// - /// - /// The responses to the requests in the batch. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerateContentBatchOutput( - string? responsesFile, - global::Google.Gemini.InlinedResponses? inlinedResponses) + global::Google.Gemini.InlinedResponses? inlinedResponses, + string? responsesFile) { - this.ResponsesFile = responsesFile; this.InlinedResponses = inlinedResponses; + this.ResponsesFile = responsesFile; } /// 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 d852489f..545273b6 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,16 +9,16 @@ namespace Google.Gemini public sealed partial class GenerateContentRequest { /// - /// 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. + /// 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("safetySettings")] - public global::System.Collections.Generic.IList? SafetySettings { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("contents")] + public global::System.Collections.Generic.IList? Contents { get; set; } /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// 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("cachedContent")] - public string? CachedContent { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("safetySettings")] + public global::System.Collections.Generic.IList? SafetySettings { 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. @@ -27,29 +27,22 @@ public sealed partial class GenerateContentRequest public global::Google.Gemini.Content? SystemInstruction { get; set; } /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("generationConfig")] - public global::Google.Gemini.GenerationConfig? GenerationConfig { 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. 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("contents")] - public global::System.Collections.Generic.IList? Contents { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("cachedContent")] + public string? CachedContent { get; set; } /// - /// Optional. The service tier of the 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("serviceTier")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierJsonConverter))] - public global::Google.Gemini.GenerateContentRequestServiceTier? ServiceTier { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("store")] + public bool? Store { get; set; } /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("toolConfig")] - public global::Google.Gemini.ToolConfig? ToolConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("model")] + public string? Model { get; set; } /// /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. @@ -58,16 +51,23 @@ public sealed partial class GenerateContentRequest public global::System.Collections.Generic.IList? Tools { 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. The service tier of the request. /// - [global::System.Text.Json.Serialization.JsonPropertyName("store")] - public bool? Store { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("serviceTier")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierJsonConverter))] + public global::Google.Gemini.GenerateContentRequestServiceTier? ServiceTier { get; set; } + + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("generationConfig")] + public global::Google.Gemini.GenerationConfig? GenerationConfig { 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. /// + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// /// /// Optional. A list of 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}` - /// /// /// 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. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - /// - /// Optional. The service tier of the request. + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// Optional. The service tier of the request. + /// + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerateContentRequest( + global::System.Collections.Generic.IList? contents, global::System.Collections.Generic.IList? safetySettings, - string? cachedContent, global::Google.Gemini.Content? systemInstruction, - global::Google.Gemini.GenerationConfig? generationConfig, - global::System.Collections.Generic.IList? contents, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier, - global::Google.Gemini.ToolConfig? toolConfig, - global::System.Collections.Generic.IList? tools, + string? cachedContent, + bool? store, string? model, - bool? store) + global::System.Collections.Generic.IList? tools, + global::Google.Gemini.ToolConfig? toolConfig, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier, + global::Google.Gemini.GenerationConfig? generationConfig) { + this.Contents = contents; this.SafetySettings = safetySettings; - this.CachedContent = cachedContent; this.SystemInstruction = systemInstruction; - this.GenerationConfig = generationConfig; - this.Contents = contents; - this.ServiceTier = serviceTier; - this.ToolConfig = toolConfig; - this.Tools = tools; - this.Model = model; + this.CachedContent = cachedContent; this.Store = store; + this.Model = model; + this.Tools = tools; + this.ToolConfig = toolConfig; + this.ServiceTier = serviceTier; + this.GenerationConfig = generationConfig; } /// 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 c2622b76..591fbcbd 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentResponse.g.cs @@ -15,11 +15,10 @@ public sealed partial class GenerateContentResponse public global::Google.Gemini.UsageMetadata? UsageMetadata { get; set; } /// - /// 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. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("responseId")] - public string? ResponseId { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("modelStatus")] + public global::Google.Gemini.ModelStatus? ModelStatus { get; set; } /// /// A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`. @@ -28,16 +27,17 @@ public sealed partial class GenerateContentResponse public global::Google.Gemini.PromptFeedback? PromptFeedback { get; set; } /// - /// Candidate responses from the model. + /// Output only. response_id is used to identify each response.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("candidates")] - public global::System.Collections.Generic.IList? Candidates { get; set; } + [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. + /// Candidate responses from the model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("modelStatus")] - public global::Google.Gemini.ModelStatus? ModelStatus { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("candidates")] + public global::System.Collections.Generic.IList? Candidates { get; set; } /// /// Output only. The model version used to generate the response.
@@ -58,19 +58,19 @@ public sealed partial class GenerateContentResponse /// /// 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. /// /// /// A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`. /// + /// + /// Output only. response_id is used to identify each response.
+ /// Included only in responses + /// /// /// Candidate responses from the model. /// - /// - /// The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable. - /// /// /// Output only. The model version used to generate the response.
/// Included only in responses @@ -80,17 +80,17 @@ public sealed partial class GenerateContentResponse #endif public GenerateContentResponse( global::Google.Gemini.UsageMetadata? usageMetadata, - string? responseId, + global::Google.Gemini.ModelStatus? modelStatus, global::Google.Gemini.PromptFeedback? promptFeedback, + string? responseId, global::System.Collections.Generic.IList? candidates, - global::Google.Gemini.ModelStatus? modelStatus, string? modelVersion) { this.UsageMetadata = usageMetadata; - this.ResponseId = responseId; + this.ModelStatus = modelStatus; this.PromptFeedback = promptFeedback; + this.ResponseId = responseId; this.Candidates = candidates; - this.ModelStatus = modelStatus; this.ModelVersion = modelVersion; } 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 892e937f..c9275d59 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 @@ -14,6 +14,14 @@ public sealed partial class GeneratedFile [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } + /// + /// Output only. The state of the GeneratedFile.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("state")] + [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). /// @@ -26,14 +34,6 @@ public sealed partial class GeneratedFile [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] public string? MimeType { get; set; } - /// - /// Output only. The state of the GeneratedFile.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("state")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateJsonConverter))] - public global::Google.Gemini.GeneratedFileState? State { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -46,29 +46,29 @@ public sealed partial class GeneratedFile /// /// Identifier. The name of the generated file. Example: `generatedFiles/abc-123` /// + /// + /// 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. /// - /// - /// Output only. The state of the GeneratedFile.
- /// Included only in responses - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GeneratedFile( string? name, + global::Google.Gemini.GeneratedFileState? state, global::Google.Gemini.Status? error, - string? mimeType, - global::Google.Gemini.GeneratedFileState? state) + string? mimeType) { this.Name = name; + this.State = state; this.Error = error; this.MimeType = mimeType; - this.State = state; } /// 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 55ad0f34..67bf63cf 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,16 +9,16 @@ namespace Google.Gemini public sealed partial class GenerationConfig { /// - /// Optional. The maximum number of tokens to include in a response candidate. Note: The default value varies by model, see the `Model.output_token_limit` attribute of the `Model` returned from the `getModel` function. + /// Config for thinking features. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxOutputTokens")] - public int? MaxOutputTokens { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("thinkingConfig")] + public global::Google.Gemini.ThinkingConfig? ThinkingConfig { 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. 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("frequencyPenalty")] - public float? FrequencyPenalty { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("presencePenalty")] + public float? PresencePenalty { 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. @@ -27,34 +27,34 @@ public sealed partial class GenerationConfig public int? TopK { get; set; } /// - /// Optional. An internal detail. Use `responseJsonSchema` rather than this field. + /// Optional. Enables enhanced civic answers. It may not be available for all models. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseJsonSchema")] - public object? ResponseJsonSchema { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("enableEnhancedCivicAnswers")] + public bool? EnableEnhancedCivicAnswers { get; set; } /// - /// Optional. Controls the randomness of the output. Note: The default value varies by model, see the `Model.temperature` attribute of the `Model` returned from the `getModel` function. Values can range from [0.0, 2.0]. + /// Optional. The maximum number of tokens to 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("temperature")] - public float? Temperature { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxOutputTokens")] + public int? MaxOutputTokens { 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. 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("responseSchema")] - public global::Google.Gemini.Schema? ResponseSchema { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topP")] + public float? TopP { 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. If true, export the logprobs results in response. + /// Optional. The requested modalities of the response. Represents the set of modalities that the model can return, and should be expected in the response. This is an exact match to the modalities of the response. A model may have multiple combinations of supported modalities. If the requested modalities do not match any of the supported combinations, an error will be returned. An empty list is equivalent to requesting only text. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseLogprobs")] - public bool? ResponseLogprobs { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseModalities")] + public global::System.Collections.Generic.IList? ResponseModalities { get; set; } /// /// Optional. Seed used in decoding. If not set, the request uses a randomly generated seed. @@ -63,83 +63,83 @@ public sealed partial class GenerationConfig public int? Seed { get; set; } /// - /// Optional. The set of character sequences (up to 5) that will stop output generation. If specified, the API will stop at the first appearance of a `stop_sequence`. The stop sequence will not be included as part of the response. + /// Optional. 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("stopSequences")] - public global::System.Collections.Generic.IList? StopSequences { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("logprobs")] + public int? Logprobs { get; set; } /// - /// Config for image generation features. + /// Configuration for the response output format. This is a flat object where each optional sub-field configures a specific output modality. /// - [global::System.Text.Json.Serialization.JsonPropertyName("imageConfig")] - public global::Google.Gemini.ImageConfig? ImageConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseFormat")] + public global::Google.Gemini.ResponseFormatConfig? ResponseFormat { get; set; } /// - /// Optional. If specified, the media resolution specified will be used. + /// Optional. An internal detail. Use `responseJsonSchema` rather than this field. /// - [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("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. + /// Config for speech generation and transcription. /// - [global::System.Text.Json.Serialization.JsonPropertyName("presencePenalty")] - public float? PresencePenalty { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("speechConfig")] + public global::Google.Gemini.SpeechConfig? SpeechConfig { get; set; } /// - /// Optional. MIME type of the generated candidate text. Supported MIME types are: `text/plain`: (default) Text output. `application/json`: JSON response in the response candidates. `text/x.enum`: ENUM as a string response in the response candidates. Refer to the [docs](https://ai.google.dev/gemini-api/docs/prompting_with_media#plain_text_formats) for a list of all supported text MIME types. + /// 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("responseMimeType")] - public string? ResponseMimeType { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("frequencyPenalty")] + public float? FrequencyPenalty { get; set; } /// - /// Configuration for the response output format. This is a flat object where each optional sub-field configures a specific output modality. + /// 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("responseFormat")] - public global::Google.Gemini.ResponseFormatConfig? ResponseFormat { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] + public float? Temperature { get; set; } /// - /// Optional. Enables enhanced civic answers. It may not be available for all models. + /// 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("enableEnhancedCivicAnswers")] - public bool? EnableEnhancedCivicAnswers { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("stopSequences")] + public global::System.Collections.Generic.IList? StopSequences { get; set; } /// - /// Config for thinking 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). /// - [global::System.Text.Json.Serialization.JsonPropertyName("thinkingConfig")] - public global::Google.Gemini.ThinkingConfig? ThinkingConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseSchema")] + public global::Google.Gemini.Schema? ResponseSchema { 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) + /// Config for translation features. /// - [global::System.Text.Json.Serialization.JsonPropertyName("candidateCount")] - public int? CandidateCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("translationConfig")] + public global::Google.Gemini.TranslationConfig? TranslationConfig { 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. 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("topP")] - public float? TopP { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseMimeType")] + public string? ResponseMimeType { 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. + /// Config for image generation features. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseModalities")] - public global::System.Collections.Generic.IList? ResponseModalities { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("imageConfig")] + public global::Google.Gemini.ImageConfig? ImageConfig { get; set; } /// - /// Config for translation features. + /// Optional. If true, export the logprobs results in response. /// - [global::System.Text.Json.Serialization.JsonPropertyName("translationConfig")] - public global::Google.Gemini.TranslationConfig? TranslationConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseLogprobs")] + public bool? ResponseLogprobs { get; set; } /// - /// Config for speech generation and transcription. + /// Optional. If specified, the media resolution specified will be used. /// - [global::System.Text.Json.Serialization.JsonPropertyName("speechConfig")] - public global::Google.Gemini.SpeechConfig? SpeechConfig { 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; } /// /// Additional properties that are not explicitly defined in the schema @@ -150,121 +150,121 @@ public sealed partial class GenerationConfig /// /// Initializes a new instance of the class. /// - /// - /// Optional. The maximum number of tokens to include in a response candidate. Note: The default value varies by model, see the `Model.output_token_limit` attribute of the `Model` returned from the `getModel` function. + /// + /// Config for thinking features. /// - /// - /// 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. 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 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. An internal detail. Use `responseJsonSchema` rather than this field. + /// + /// Optional. Enables enhanced civic answers. It may not be available for all models. /// - /// - /// Optional. Controls the randomness of the output. Note: The default value varies by model, see the `Model.temperature` attribute of the `Model` returned from the `getModel` function. Values can range from [0.0, 2.0]. + /// + /// Optional. The maximum number of tokens to 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. /// - /// - /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). + /// + /// Optional. The 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. 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. If true, export the logprobs results in response. + /// + /// Optional. The requested modalities of the response. Represents the set of modalities that the model can return, and should be expected in the response. This is an exact match to the modalities of the response. A model may have multiple combinations of supported modalities. If the requested modalities do not match any of the supported combinations, an error will be returned. An empty list is equivalent to requesting only text. /// /// /// Optional. Seed used in decoding. If not set, the request uses a randomly generated seed. /// - /// - /// 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 image generation features. - /// - /// - /// Optional. If specified, the media resolution specified will be used. - /// - /// - /// 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. 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. 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]. /// /// /// Configuration for the response output format. This is a flat object where each optional sub-field configures a specific output modality. /// - /// - /// Optional. Enables enhanced civic answers. It may not be available for all models. + /// + /// Optional. An internal detail. Use `responseJsonSchema` rather than this field. /// - /// - /// Config for thinking features. + /// + /// Config for speech generation and transcription. /// - /// - /// 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. 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. Controls the randomness of the output. Note: The default value varies by model, see the `Model.temperature` attribute of the `Model` returned from the `getModel` function. Values can range from [0.0, 2.0]. /// - /// - /// Optional. The 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 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. + /// + /// + /// 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 translation features. /// - /// - /// 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. + /// + /// + /// Config for image generation features. + /// + /// + /// Optional. If true, export the logprobs results in response. + /// + /// + /// Optional. If specified, the media resolution specified will be used. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerationConfig( - int? maxOutputTokens, - float? frequencyPenalty, - int? topK, - object? responseJsonSchema, - float? temperature, - global::Google.Gemini.Schema? responseSchema, - int? logprobs, - bool? responseLogprobs, - int? seed, - global::System.Collections.Generic.IList? stopSequences, - global::Google.Gemini.ImageConfig? imageConfig, - global::Google.Gemini.GenerationConfigMediaResolution? mediaResolution, + global::Google.Gemini.ThinkingConfig? thinkingConfig, float? presencePenalty, - string? responseMimeType, - global::Google.Gemini.ResponseFormatConfig? responseFormat, + int? topK, bool? enableEnhancedCivicAnswers, - global::Google.Gemini.ThinkingConfig? thinkingConfig, - int? candidateCount, + int? maxOutputTokens, float? topP, + int? candidateCount, global::System.Collections.Generic.IList? responseModalities, + int? seed, + int? logprobs, + global::Google.Gemini.ResponseFormatConfig? responseFormat, + object? responseJsonSchema, + global::Google.Gemini.SpeechConfig? speechConfig, + float? frequencyPenalty, + float? temperature, + global::System.Collections.Generic.IList? stopSequences, + global::Google.Gemini.Schema? responseSchema, global::Google.Gemini.TranslationConfig? translationConfig, - global::Google.Gemini.SpeechConfig? speechConfig) + string? responseMimeType, + global::Google.Gemini.ImageConfig? imageConfig, + bool? responseLogprobs, + global::Google.Gemini.GenerationConfigMediaResolution? mediaResolution) { - this.MaxOutputTokens = maxOutputTokens; - this.FrequencyPenalty = frequencyPenalty; + this.ThinkingConfig = thinkingConfig; + this.PresencePenalty = presencePenalty; this.TopK = topK; + this.EnableEnhancedCivicAnswers = enableEnhancedCivicAnswers; + this.MaxOutputTokens = maxOutputTokens; + this.TopP = topP; + this.CandidateCount = candidateCount; + this.ResponseModalities = responseModalities; + this.Seed = seed; + this.Logprobs = logprobs; + this.ResponseFormat = responseFormat; this.ResponseJsonSchema = responseJsonSchema; + this.SpeechConfig = speechConfig; + this.FrequencyPenalty = frequencyPenalty; this.Temperature = temperature; - this.ResponseSchema = responseSchema; - this.Logprobs = logprobs; - this.ResponseLogprobs = responseLogprobs; - this.Seed = seed; this.StopSequences = stopSequences; + this.ResponseSchema = responseSchema; + this.TranslationConfig = translationConfig; + this.ResponseMimeType = responseMimeType; this.ImageConfig = imageConfig; + this.ResponseLogprobs = responseLogprobs; this.MediaResolution = mediaResolution; - this.PresencePenalty = presencePenalty; - this.ResponseMimeType = responseMimeType; - this.ResponseFormat = responseFormat; - this.EnableEnhancedCivicAnswers = enableEnhancedCivicAnswers; - this.ThinkingConfig = thinkingConfig; - this.CandidateCount = candidateCount; - this.TopP = topP; - this.ResponseModalities = responseModalities; - this.TranslationConfig = translationConfig; - this.SpeechConfig = speechConfig; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaGroundingSupport.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaGroundingSupport.g.cs index 1fd716a3..851ce0ae 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaGroundingSupport.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaGroundingSupport.g.cs @@ -8,13 +8,6 @@ namespace Google.Gemini /// public sealed partial class GoogleAiGenerativelanguageV1betaGroundingSupport { - /// - /// Output only. Indices into the `parts` field of the candidate's content. These indices specify which rendered parts are associated with this support source.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("renderedParts")] - public global::System.Collections.Generic.IList? RenderedParts { get; set; } - /// /// Segment of the content. /// @@ -27,6 +20,13 @@ public sealed partial class GoogleAiGenerativelanguageV1betaGroundingSupport [global::System.Text.Json.Serialization.JsonPropertyName("groundingChunkIndices")] public global::System.Collections.Generic.IList? GroundingChunkIndices { get; set; } + /// + /// Output only. Indices into the `parts` field of the candidate's content. These indices specify which rendered parts are associated with this support source.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("renderedParts")] + public global::System.Collections.Generic.IList? RenderedParts { get; set; } + /// /// Optional. Confidence score of the support references. Ranges from 0 to 1. 1 is the most confident. This list must have the same size as the grounding_chunk_indices. /// @@ -42,16 +42,16 @@ public sealed partial class GoogleAiGenerativelanguageV1betaGroundingSupport /// /// Initializes a new instance of the class. /// - /// - /// Output only. Indices into the `parts` field of the candidate's content. These indices specify which rendered parts are associated with this support source.
- /// Included only in responses - /// /// /// Segment of the content. /// /// /// Optional. A list of indices (into 'grounding_chunk' in `response.candidate.grounding_metadata`) specifying the citations associated with the claim. For instance [1,3,4] means that grounding_chunk[1], grounding_chunk[3], grounding_chunk[4] are the retrieved content attributed to the claim. If the response is streaming, the grounding_chunk_indices refer to the indices across all responses. It is the client's responsibility to accumulate the grounding chunks from all responses (while maintaining the same order). /// + /// + /// Output only. Indices into the `parts` field of the candidate's content. These indices specify which rendered parts are associated with this support source.
+ /// Included only in responses + /// /// /// 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. /// @@ -59,14 +59,14 @@ public sealed partial class GoogleAiGenerativelanguageV1betaGroundingSupport [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GoogleAiGenerativelanguageV1betaGroundingSupport( - global::System.Collections.Generic.IList? renderedParts, global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? segment, global::System.Collections.Generic.IList? groundingChunkIndices, + global::System.Collections.Generic.IList? renderedParts, global::System.Collections.Generic.IList? confidenceScores) { - this.RenderedParts = renderedParts; this.Segment = segment; this.GroundingChunkIndices = groundingChunkIndices; + this.RenderedParts = renderedParts; this.ConfidenceScores = confidenceScores; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaSegment.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaSegment.g.cs index 98615ea6..b3feedae 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaSegment.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaSegment.g.cs @@ -14,18 +14,18 @@ public sealed partial class GoogleAiGenerativelanguageV1betaSegment [global::System.Text.Json.Serialization.JsonPropertyName("partIndex")] public int? PartIndex { get; set; } - /// - /// End index in the given Part, measured in bytes. Offset from the start of the Part, exclusive, starting at zero. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("endIndex")] - public int? EndIndex { get; set; } - /// /// Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero. /// [global::System.Text.Json.Serialization.JsonPropertyName("startIndex")] public int? StartIndex { get; set; } + /// + /// End index in the given Part, measured in bytes. Offset from the start of the Part, exclusive, starting at zero. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("endIndex")] + public int? EndIndex { get; set; } + /// /// The text corresponding to the segment from the response. /// @@ -44,12 +44,12 @@ public sealed partial class GoogleAiGenerativelanguageV1betaSegment /// /// The index of a Part object within its parent Content object. /// - /// - /// End index in the given Part, measured in bytes. Offset from the start of the Part, exclusive, starting at zero. - /// /// /// Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero. /// + /// + /// End index in the given Part, measured in bytes. Offset from the start of the Part, exclusive, starting at zero. + /// /// /// The text corresponding to the segment from the response. /// @@ -58,13 +58,13 @@ public sealed partial class GoogleAiGenerativelanguageV1betaSegment #endif public GoogleAiGenerativelanguageV1betaSegment( int? partIndex, - int? endIndex, int? startIndex, + int? endIndex, string? text) { this.PartIndex = partIndex; - this.EndIndex = endIndex; this.StartIndex = startIndex; + this.EndIndex = endIndex; this.Text = text; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunk.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunk.g.cs index 13e510e2..d679dfec 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunk.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunk.g.cs @@ -8,30 +8,30 @@ namespace Google.Gemini ///
public sealed partial class GroundingChunk { - /// - /// Chunk from the web. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("web")] - public global::Google.Gemini.Web? Web { get; set; } - /// /// Chunk from image search. /// [global::System.Text.Json.Serialization.JsonPropertyName("image")] public global::Google.Gemini.Image? Image { get; set; } - /// - /// Chunk from context retrieved by the file search tool. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("retrievedContext")] - public global::Google.Gemini.RetrievedContext? RetrievedContext { get; set; } - /// /// A grounding chunk from Google Maps. A Maps chunk corresponds to a single place. /// [global::System.Text.Json.Serialization.JsonPropertyName("maps")] public global::Google.Gemini.Maps? Maps { get; set; } + /// + /// Chunk from the web. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("web")] + public global::Google.Gemini.Web? Web { get; set; } + + /// + /// Chunk from context retrieved by the file search tool. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("retrievedContext")] + public global::Google.Gemini.RetrievedContext? RetrievedContext { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -41,31 +41,31 @@ public sealed partial class GroundingChunk /// /// Initializes a new instance of the class. /// - /// - /// Chunk from the web. - /// /// /// Chunk from image search. /// - /// - /// Chunk from context retrieved by the file search tool. - /// /// /// A grounding chunk from Google Maps. A Maps chunk corresponds to a single place. /// + /// + /// Chunk from the web. + /// + /// + /// Chunk from context retrieved by the file search tool. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingChunk( - global::Google.Gemini.Web? web, global::Google.Gemini.Image? image, - global::Google.Gemini.RetrievedContext? retrievedContext, - global::Google.Gemini.Maps? maps) + global::Google.Gemini.Maps? maps, + global::Google.Gemini.Web? web, + global::Google.Gemini.RetrievedContext? retrievedContext) { - this.Web = web; this.Image = image; - this.RetrievedContext = retrievedContext; this.Maps = maps; + this.Web = web; + this.RetrievedContext = retrievedContext; } /// 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 833e31c1..f78a27bc 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,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class GroundingChunkCustomMetadata { - /// - /// The key of the metadata. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("key")] - public string? Key { get; set; } - /// /// Optional. The string value of the metadata. /// [global::System.Text.Json.Serialization.JsonPropertyName("stringValue")] public string? StringValue { get; set; } + /// + /// The key of the metadata. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("key")] + public string? Key { get; set; } + /// /// A list of string values. /// @@ -41,12 +41,12 @@ public sealed partial class GroundingChunkCustomMetadata /// /// Initializes a new instance of the class. /// - /// - /// The key of the metadata. - /// /// /// Optional. The string value of the metadata. /// + /// + /// The key of the metadata. + /// /// /// A list of string values. /// @@ -57,13 +57,13 @@ public sealed partial class GroundingChunkCustomMetadata [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingChunkCustomMetadata( - string? key, string? stringValue, + string? key, global::Google.Gemini.GroundingChunkStringList? stringListValue, float? numericValue) { - this.Key = key; this.StringValue = stringValue; + this.Key = key; this.StringListValue = stringListValue; this.NumericValue = numericValue; } 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 20d578b8..a628e6f3 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 @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class GroundingMetadata { /// - /// 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. + /// Image search queries used for grounding. /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleMapsWidgetContextToken")] - public string? GoogleMapsWidgetContextToken { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("imageSearchQueries")] + public global::System.Collections.Generic.IList? ImageSearchQueries { get; set; } /// /// Google search entry point. @@ -21,16 +21,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; } - - /// - /// List of grounding support. + /// Optional. Resource name of the Google Maps widget context token that can be used with the PlacesContextElement widget in order to render contextual data. Only populated in the case that grounding with Google Maps is enabled. /// - [global::System.Text.Json.Serialization.JsonPropertyName("groundingSupports")] - public global::System.Collections.Generic.IList? GroundingSupports { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("googleMapsWidgetContextToken")] + public string? GoogleMapsWidgetContextToken { 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. @@ -38,6 +32,12 @@ public sealed partial class GroundingMetadata [global::System.Text.Json.Serialization.JsonPropertyName("groundingChunks")] public global::System.Collections.Generic.IList? GroundingChunks { get; set; } + /// + /// List of grounding support. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("groundingSupports")] + public global::System.Collections.Generic.IList? GroundingSupports { get; set; } + /// /// Metadata related to retrieval in the grounding flow. /// @@ -45,10 +45,10 @@ public sealed partial class GroundingMetadata public global::Google.Gemini.RetrievalMetadata? RetrievalMetadata { get; set; } /// - /// Image search queries used for grounding. + /// Web search queries for the following-up web search. /// - [global::System.Text.Json.Serialization.JsonPropertyName("imageSearchQueries")] - public global::System.Collections.Generic.IList? ImageSearchQueries { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("webSearchQueries")] + public global::System.Collections.Generic.IList? WebSearchQueries { 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. /// - /// - /// 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. + /// + /// Image search queries used for grounding. /// /// /// Google search entry point. /// - /// - /// Web search queries for the following-up web search. - /// - /// - /// List of grounding support. + /// + /// 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. /// /// /// 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. /// + /// + /// List of grounding support. + /// /// /// Metadata related to retrieval in the grounding flow. /// - /// - /// Image search queries used for grounding. + /// + /// Web search queries for the following-up web search. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingMetadata( - string? googleMapsWidgetContextToken, + global::System.Collections.Generic.IList? imageSearchQueries, global::Google.Gemini.SearchEntryPoint? searchEntryPoint, - global::System.Collections.Generic.IList? webSearchQueries, - global::System.Collections.Generic.IList? groundingSupports, + string? googleMapsWidgetContextToken, global::System.Collections.Generic.IList? groundingChunks, + global::System.Collections.Generic.IList? groundingSupports, global::Google.Gemini.RetrievalMetadata? retrievalMetadata, - global::System.Collections.Generic.IList? imageSearchQueries) + global::System.Collections.Generic.IList? webSearchQueries) { - this.GoogleMapsWidgetContextToken = googleMapsWidgetContextToken; + this.ImageSearchQueries = imageSearchQueries; this.SearchEntryPoint = searchEntryPoint; - this.WebSearchQueries = webSearchQueries; - this.GroundingSupports = groundingSupports; + this.GoogleMapsWidgetContextToken = googleMapsWidgetContextToken; this.GroundingChunks = groundingChunks; + this.GroundingSupports = groundingSupports; this.RetrievalMetadata = retrievalMetadata; - this.ImageSearchQueries = imageSearchQueries; + this.WebSearchQueries = webSearchQueries; } /// 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 48efee39..dea3592a 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 { - /// - /// Immutable. The batch size hyperparameter for tuning. If not set, a default of 4 or 16 will be used based on the number of training examples. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("batchSize")] - public int? BatchSize { get; set; } - /// /// Optional. Immutable. The learning rate hyperparameter for tuning. If not set, a default of 0.001 or 0.0002 will be calculated based on the number of training examples. /// @@ -32,6 +26,12 @@ public sealed partial class Hyperparameters [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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("batchSize")] + public int? BatchSize { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -41,9 +41,6 @@ public sealed partial class Hyperparameters /// /// Initializes a new instance of the class. /// - /// - /// Immutable. The batch size hyperparameter for tuning. If not set, a default of 4 or 16 will be used based on the number of training examples. - /// /// /// Optional. Immutable. The learning rate hyperparameter for tuning. If not set, a default of 0.001 or 0.0002 will be calculated based on the number of training examples. /// @@ -53,19 +50,22 @@ 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. /// + /// + /// Immutable. The batch size hyperparameter for tuning. If not set, a default of 4 or 16 will be used based on the number of training examples. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Hyperparameters( - int? batchSize, float? learningRate, int? epochCount, - float? learningRateMultiplier) + float? learningRateMultiplier, + int? batchSize) { - this.BatchSize = batchSize; this.LearningRate = learningRate; this.EpochCount = epochCount; this.LearningRateMultiplier = learningRateMultiplier; + this.BatchSize = batchSize; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Image.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Image.g.cs index 1b465d5c..c92b6eea 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,10 +9,10 @@ namespace Google.Gemini public sealed partial class Image { /// - /// 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 title of the web page that the image is from. @@ -20,18 +20,18 @@ public sealed partial class Image [global::System.Text.Json.Serialization.JsonPropertyName("title")] public string? Title { get; set; } - /// - /// The web page URI for attribution. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("sourceUri")] - public string? SourceUri { get; set; } - /// /// The image asset URL. /// [global::System.Text.Json.Serialization.JsonPropertyName("imageUri")] public string? ImageUri { get; set; } + /// + /// The root domain of the web page that the image is from, e.g. "example.com". + /// + [global::System.Text.Json.Serialization.JsonPropertyName("domain")] + public string? Domain { 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 web page URI for attribution. /// /// /// The title of the web page that the image is from. /// - /// - /// The web page URI for attribution. - /// /// /// The image asset URL. /// + /// + /// The root domain of the web page that the image is from, e.g. "example.com". + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Image( - string? domain, - string? title, string? sourceUri, - string? imageUri) + string? title, + string? imageUri, + string? domain) { - this.Domain = domain; - this.Title = title; this.SourceUri = sourceUri; + this.Title = title; this.ImageUri = imageUri; + this.Domain = domain; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImageResponseFormat.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImageResponseFormat.g.cs index 7dba850b..38e8ad79 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImageResponseFormat.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImageResponseFormat.g.cs @@ -8,13 +8,6 @@ namespace Google.Gemini /// public sealed partial class ImageResponseFormat { - /// - /// Optional. The delivery mode for the image output. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("delivery")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryJsonConverter))] - public global::Google.Gemini.ImageResponseFormatDelivery? Delivery { get; set; } - /// /// Optional. The MIME type of the image output. /// @@ -29,6 +22,13 @@ public sealed partial class ImageResponseFormat [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatAspectRatioJsonConverter))] public global::Google.Gemini.ImageResponseFormatAspectRatio? AspectRatio { get; set; } + /// + /// Optional. The delivery mode for the image output. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("delivery")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryJsonConverter))] + public global::Google.Gemini.ImageResponseFormatDelivery? Delivery { get; set; } + /// /// Optional. The size of the image output. /// @@ -45,15 +45,15 @@ public sealed partial class ImageResponseFormat /// /// Initializes a new instance of the class. /// - /// - /// Optional. The delivery mode for the image output. - /// /// /// Optional. The MIME type of the image output. /// /// /// Optional. The aspect ratio for the image output. /// + /// + /// Optional. The delivery mode for the image output. + /// /// /// Optional. The size of the image output. /// @@ -61,14 +61,14 @@ public sealed partial class ImageResponseFormat [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ImageResponseFormat( - global::Google.Gemini.ImageResponseFormatDelivery? delivery, global::Google.Gemini.ImageResponseFormatMimeType? mimeType, global::Google.Gemini.ImageResponseFormatAspectRatio? aspectRatio, + global::Google.Gemini.ImageResponseFormatDelivery? delivery, global::Google.Gemini.ImageResponseFormatImageSize? imageSize) { - this.Delivery = delivery; this.MimeType = mimeType; this.AspectRatio = aspectRatio; + this.Delivery = delivery; 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 b8060008..b5598045 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImportFileRequest.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImportFileRequest.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class ImportFileRequest { - /// - /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto - /// - [global::System.Text.Json.Serialization.JsonPropertyName("chunkingConfig")] - public global::Google.Gemini.ChunkingConfig? ChunkingConfig { get; set; } - /// /// Custom metadata to be associated with the file. /// @@ -26,6 +20,12 @@ public sealed partial class ImportFileRequest [global::System.Text.Json.Serialization.JsonPropertyName("fileName")] public string? FileName { 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 + /// + [global::System.Text.Json.Serialization.JsonPropertyName("chunkingConfig")] + public global::Google.Gemini.ChunkingConfig? ChunkingConfig { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class ImportFileRequest /// /// Initializes a new instance of the class. /// - /// - /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto - /// /// /// Custom metadata to be associated with the file. /// /// /// Required. The name of the `File` to import. Example: `files/abc-123` /// + /// + /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ImportFileRequest( - global::Google.Gemini.ChunkingConfig? chunkingConfig, global::System.Collections.Generic.IList? customMetadata, - string? fileName) + string? fileName, + global::Google.Gemini.ChunkingConfig? chunkingConfig) { - this.ChunkingConfig = chunkingConfig; this.CustomMetadata = customMetadata; this.FileName = fileName; + this.ChunkingConfig = chunkingConfig; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Interval.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Interval.g.cs index 5ce34e69..afe10fd0 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Interval.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Interval.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class Interval { - /// - /// Optional. Inclusive start of the interval. If specified, a Timestamp matching this interval will have to be the same or after the start. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("startTime")] - public string? StartTime { get; set; } - /// /// Optional. Exclusive end of the interval. If specified, a Timestamp matching this interval will have to be before the end. /// [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] public string? EndTime { get; set; } + /// + /// Optional. Inclusive start of the interval. If specified, a Timestamp matching this interval will have to be the same or after the start. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("startTime")] + public string? StartTime { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class Interval /// /// Initializes a new instance of the class. /// - /// - /// Optional. Inclusive start of the interval. If specified, a Timestamp matching this interval will have to be the same or after the start. - /// /// /// Optional. Exclusive end of the interval. If specified, a Timestamp matching this interval will have to be before the end. /// + /// + /// Optional. Inclusive start of the interval. If specified, a Timestamp matching this interval will have to be the same or after the start. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Interval( - string? startTime, - string? endTime) + string? endTime, + string? startTime) { - this.StartTime = startTime; this.EndTime = endTime; + this.StartTime = startTime; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LatLng.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LatLng.g.cs index 9a1d2d1e..8c9f6ab6 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LatLng.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LatLng.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class LatLng { - /// - /// The longitude in degrees. It must be in the range [-180.0, +180.0]. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("longitude")] - public double? Longitude { get; set; } - /// /// The latitude in degrees. It must be in the range [-90.0, +90.0]. /// [global::System.Text.Json.Serialization.JsonPropertyName("latitude")] public double? Latitude { get; set; } + /// + /// The longitude in degrees. It must be in the range [-180.0, +180.0]. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("longitude")] + public double? Longitude { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class LatLng /// /// Initializes a new instance of the class. /// - /// - /// The longitude in degrees. It must be in the range [-180.0, +180.0]. - /// /// /// The latitude in degrees. It must be in the range [-90.0, +90.0]. /// + /// + /// The longitude in degrees. It must be in the range [-180.0, +180.0]. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public LatLng( - double? longitude, - double? latitude) + double? latitude, + double? longitude) { - this.Longitude = longitude; this.Latitude = latitude; + this.Longitude = longitude; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListDocumentsResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListDocumentsResponse.g.cs index 305a1062..ba11d1ec 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListDocumentsResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListDocumentsResponse.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ListDocumentsResponse { - /// - /// 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 `Document`s. /// [global::System.Text.Json.Serialization.JsonPropertyName("documents")] public global::System.Collections.Generic.IList? Documents { 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 ListDocumentsResponse /// /// Initializes a new instance of the class. /// - /// - /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. - /// /// /// The returned `Document`s. /// + /// + /// 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 ListDocumentsResponse( - string? nextPageToken, - global::System.Collections.Generic.IList? documents) + global::System.Collections.Generic.IList? documents, + string? nextPageToken) { - this.NextPageToken = nextPageToken; this.Documents = documents; + this.NextPageToken = nextPageToken; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFilesResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFilesResponse.g.cs index 31720695..56d16d70 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 d4af5350..76ed7050 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 { - /// - /// 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; } + /// + /// 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 ListModelsResponse /// /// Initializes a new instance of the class. /// - /// - /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. - /// /// /// The returned 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. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListModelsResponse( - string? nextPageToken, - global::System.Collections.Generic.IList? models) + global::System.Collections.Generic.IList? models, + string? nextPageToken) { - this.NextPageToken = nextPageToken; this.Models = models; + this.NextPageToken = nextPageToken; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListOperationsResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListOperationsResponse.g.cs index b6386440..9f0d9512 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListOperationsResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListOperationsResponse.g.cs @@ -14,18 +14,18 @@ public sealed partial class ListOperationsResponse [global::System.Text.Json.Serialization.JsonPropertyName("operations")] public global::System.Collections.Generic.IList? Operations { get; set; } - /// - /// The standard List next-page token. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] - public string? NextPageToken { get; set; } - /// /// 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. /// [global::System.Text.Json.Serialization.JsonPropertyName("unreachable")] public global::System.Collections.Generic.IList? Unreachable { get; set; } + /// + /// The standard List next-page token. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] + public string? NextPageToken { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -38,23 +38,23 @@ public sealed partial class ListOperationsResponse /// /// A list of operations that matches the specified filter in the request. /// - /// - /// The standard List next-page token. - /// /// /// Unordered list. Unreachable resources. Populated when the request sets `ListOperationsRequest.return_partial_success` and reads across collections. For example, when attempting to list all resources across all supported locations. /// + /// + /// The standard List next-page token. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListOperationsResponse( global::System.Collections.Generic.IList? operations, - string? nextPageToken, - global::System.Collections.Generic.IList? unreachable) + global::System.Collections.Generic.IList? unreachable, + string? nextPageToken) { this.Operations = operations; - this.NextPageToken = nextPageToken; this.Unreachable = unreachable; + this.NextPageToken = nextPageToken; } /// 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 fb6d6f43..800f4e39 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.LogprobsResultCandidate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResultCandidate.g.cs index 757bdf73..6154061d 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResultCandidate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResultCandidate.g.cs @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class LogprobsResultCandidate { /// - /// The candidate’s token string value. + /// The candidate’s token id value. /// - [global::System.Text.Json.Serialization.JsonPropertyName("token")] - public string? Token { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("tokenId")] + public int? TokenId { get; set; } /// /// The candidate's log probability. @@ -21,10 +21,10 @@ public sealed partial class LogprobsResultCandidate public float? LogProbability { get; set; } /// - /// The candidate’s token id value. + /// The candidate’s token string value. /// - [global::System.Text.Json.Serialization.JsonPropertyName("tokenId")] - public int? TokenId { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("token")] + public string? Token { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -35,26 +35,26 @@ public sealed partial class LogprobsResultCandidate /// /// Initializes a new instance of the class. /// - /// - /// The candidate’s token string value. + /// + /// The candidate’s token id value. /// /// /// The candidate's log probability. /// - /// - /// The candidate’s token id value. + /// + /// The candidate’s token string value. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public LogprobsResultCandidate( - string? token, + int? tokenId, float? logProbability, - int? tokenId) + string? token) { - this.Token = token; - this.LogProbability = logProbability; this.TokenId = tokenId; + this.LogProbability = logProbability; + this.Token = token; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Maps.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Maps.g.cs index f49fabd6..af1f9c8e 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 @@ -14,18 +14,6 @@ public sealed partial class Maps [global::System.Text.Json.Serialization.JsonPropertyName("title")] public string? Title { get; set; } - /// - /// Text description of the place answer. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("text")] - public string? Text { get; set; } - - /// - /// URI reference of the place. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("uri")] - public string? Uri { get; set; } - /// /// The ID of the place, in `places/{place_id}` format. A user can use this ID to look up that place. /// @@ -38,6 +26,18 @@ public sealed partial class Maps [global::System.Text.Json.Serialization.JsonPropertyName("placeAnswerSources")] public global::Google.Gemini.PlaceAnswerSources? PlaceAnswerSources { get; set; } + /// + /// URI reference of the place. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("uri")] + public string? Uri { get; set; } + + /// + /// Text description of the place answer. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("text")] + public string? Text { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -50,33 +50,33 @@ public sealed partial class Maps /// /// Title of the place. /// - /// - /// Text description of the place answer. - /// - /// - /// 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. /// /// /// 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. /// + /// + /// URI reference of the place. + /// + /// + /// Text description of the place answer. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Maps( string? title, - string? text, - string? uri, string? placeId, - global::Google.Gemini.PlaceAnswerSources? placeAnswerSources) + global::Google.Gemini.PlaceAnswerSources? placeAnswerSources, + string? uri, + string? text) { this.Title = title; - this.Text = text; - this.Uri = uri; this.PlaceId = placeId; this.PlaceAnswerSources = placeAnswerSources; + this.Uri = uri; + this.Text = text; } /// 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 197f4054..c294428e 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 { - /// - /// 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; } + /// + /// The name of the MCPServer. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { 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. /// - /// - /// The name of the MCPServer. - /// /// /// A transport that can stream HTTP requests and responses. Next ID: 6 /// + /// + /// The name of the MCPServer. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public McpServer( - string? name, - global::Google.Gemini.StreamableHttpTransport? streamableHttpTransport) + global::Google.Gemini.StreamableHttpTransport? streamableHttpTransport, + string? name) { - this.Name = name; this.StreamableHttpTransport = streamableHttpTransport; + this.Name = name; } /// 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 d5bff801..6a90f2cd 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 5906b21c..ec46236b 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Model.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Model.g.cs @@ -9,28 +9,28 @@ namespace Google.Gemini public sealed partial class Model { /// - /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) + /// 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("version")] - public string? Version { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] + public float? Temperature { get; set; } /// - /// Maximum number of input tokens allowed for this model. + /// Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` /// - [global::System.Text.Json.Serialization.JsonPropertyName("inputTokenLimit")] - public int? InputTokenLimit { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("baseModelId")] + public string? BaseModelId { get; set; } /// - /// For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model. + /// The maximum temperature this model can use. /// - [global::System.Text.Json.Serialization.JsonPropertyName("topP")] - public float? TopP { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxTemperature")] + public float? MaxTemperature { get; set; } /// - /// Maximum number of output tokens available for this model. + /// A short description of the model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("outputTokenLimit")] - public int? OutputTokenLimit { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("description")] + public string? Description { get; set; } /// /// The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`. @@ -38,12 +38,6 @@ public sealed partial class Model [global::System.Text.Json.Serialization.JsonPropertyName("supportedGenerationMethods")] public global::System.Collections.Generic.IList? SupportedGenerationMethods { get; set; } - /// - /// A short description of the model. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("description")] - public string? Description { 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. /// @@ -57,34 +51,40 @@ public sealed partial class Model public bool? Thinking { get; set; } /// - /// Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` + /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) /// - [global::System.Text.Json.Serialization.JsonPropertyName("baseModelId")] - public string? BaseModelId { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("version")] + public string? Version { 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. + /// 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("temperature")] - public float? Temperature { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topK")] + public int? TopK { 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` + /// Maximum number of input tokens allowed for this model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("inputTokenLimit")] + public int? InputTokenLimit { get; set; } /// - /// The maximum temperature this model can use. + /// 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("maxTemperature")] - public float? MaxTemperature { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topP")] + public float? TopP { 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. + /// Maximum number of output tokens available for this model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("topK")] - public int? TopK { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("outputTokenLimit")] + public int? OutputTokenLimit { 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; } /// /// 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 version number of the model. This represents the major version (`1.0` or `1.5`) + /// + /// 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. /// - /// - /// 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` /// - /// - /// For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model. + /// + /// The maximum temperature this model can use. /// - /// - /// Maximum number of output tokens available for this model. + /// + /// A short description of the model. /// /// /// The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`. /// - /// - /// A short description of the model. - /// /// /// The human-readable name of the model. E.g. "Gemini 1.5 Flash". The name can be up to 128 characters long and can consist of any UTF-8 characters. /// /// /// Whether the model supports thinking. /// - /// - /// Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` + /// + /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) /// - /// - /// 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. + /// + /// 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 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. /// - /// - /// The maximum temperature this model can use. + /// + /// 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. /// - /// - /// For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. If empty, indicates the model doesn't use top-k sampling, and `top_k` isn't allowed as a generation parameter. + /// + /// Maximum number of output tokens available for this model. + /// + /// + /// Required. The resource name of the `Model`. Refer to [Model variants](https://ai.google.dev/gemini-api/docs/models/gemini#model-variations) for all allowed values. Format: `models/{model}` with a `{model}` naming convention of: * "{base_model_id}-{version}" Examples: * `models/gemini-1.5-flash-001` /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Model( + float? temperature, + string? baseModelId, + float? maxTemperature, + string? description, + global::System.Collections.Generic.IList? supportedGenerationMethods, + string? displayName, + bool? thinking, string? version, + int? topK, int? inputTokenLimit, float? topP, int? outputTokenLimit, - global::System.Collections.Generic.IList? supportedGenerationMethods, - string? description, - string? displayName, - bool? thinking, - string? baseModelId, - float? temperature, - string? name, - float? maxTemperature, - int? topK) + string? name) { + this.Temperature = temperature; + this.BaseModelId = baseModelId; + this.MaxTemperature = maxTemperature; + this.Description = description; + this.SupportedGenerationMethods = supportedGenerationMethods; + this.DisplayName = displayName; + this.Thinking = thinking; this.Version = version; + this.TopK = topK; this.InputTokenLimit = inputTokenLimit; this.TopP = topP; this.OutputTokenLimit = outputTokenLimit; - this.SupportedGenerationMethods = supportedGenerationMethods; - this.Description = description; - this.DisplayName = displayName; - this.Thinking = thinking; - this.BaseModelId = baseModelId; - this.Temperature = temperature; this.Name = name; - this.MaxTemperature = maxTemperature; - this.TopK = topK; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ModelStatus.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ModelStatus.g.cs index e5ba4a30..75612d76 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ModelStatus.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ModelStatus.g.cs @@ -15,18 +15,18 @@ public sealed partial class ModelStatus [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageJsonConverter))] public global::Google.Gemini.ModelStatusModelStage? ModelStage { get; set; } - /// - /// A message explaining the model status. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("message")] - public string? Message { get; set; } - /// /// The time at which the model will be retired. /// [global::System.Text.Json.Serialization.JsonPropertyName("retirementTime")] public string? RetirementTime { get; set; } + /// + /// A message explaining the model status. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("message")] + public string? Message { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -39,23 +39,23 @@ public sealed partial class ModelStatus /// /// The stage of the underlying model. /// - /// - /// A message explaining the model status. - /// /// /// The time at which the model will be retired. /// + /// + /// A message explaining the model status. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ModelStatus( global::Google.Gemini.ModelStatusModelStage? modelStage, - string? message, - string? retirementTime) + string? retirementTime, + string? message) { this.ModelStage = modelStage; - this.Message = message; this.RetirementTime = retirementTime; + this.Message = message; } /// 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 dc3e8f3d..3e9f64bd 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,16 @@ namespace Google.Gemini public sealed partial class Operation { /// - /// 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). + /// 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("error")] - public global::Google.Gemini.Status? Error { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] + public object? Metadata { get; set; } + + /// + /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + 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. @@ -27,16 +33,10 @@ public sealed partial class Operation public object? Response { get; set; } /// - /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } - - /// - /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// - [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] - public object? Metadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("error")] + public global::Google.Gemini.Status? Error { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -47,8 +47,11 @@ public sealed partial class Operation /// /// 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). + /// + /// 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 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. @@ -56,27 +59,24 @@ public sealed partial class Operation /// /// The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. /// - /// - /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. - /// - /// - /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. + /// + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Operation( - global::Google.Gemini.Status? error, + object? metadata, + string? name, bool? done, object? response, - string? name, - object? metadata) + global::Google.Gemini.Status? error) { - this.Error = error; + this.Metadata = metadata; + this.Name = name; this.Done = done; this.Response = response; - this.Name = name; - this.Metadata = metadata; + this.Error = error; } /// 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 88648fcb..097c27da 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,22 +11,28 @@ namespace Google.Gemini public sealed partial class Part { /// - /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. + /// 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("codeExecutionResult")] - public global::Google.Gemini.CodeExecutionResult? CodeExecutionResult { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("partMetadata")] + public object? PartMetadata { get; set; } /// - /// URI based data. + /// The output from a server-side `ToolCall` execution. This message contains the results of a tool invocation that was initiated by a `ToolCall` from the model. The client should pass this `ToolResponse` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolCall`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("fileData")] - public global::Google.Gemini.FileData? FileData { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("toolResponse")] + public global::Google.Gemini.ToolResponse? ToolResponse { 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. + /// Optional. An opaque signature for the thought so it can be reused in subsequent requests. /// - [global::System.Text.Json.Serialization.JsonPropertyName("partMetadata")] - public object? PartMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("thoughtSignature")] + public byte[]? ThoughtSignature { get; set; } + + /// + /// URI based data. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("fileData")] + public global::Google.Gemini.FileData? FileData { get; set; } /// /// Inline text. @@ -41,22 +47,17 @@ public sealed partial class Part public global::Google.Gemini.FunctionResponse? FunctionResponse { get; set; } /// - /// Raw media bytes. Text should not be sent as raw bytes, use the 'text' field. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("inlineData")] - public global::Google.Gemini.Blob? InlineData { get; set; } - - /// - /// The output from a server-side `ToolCall` execution. This message contains the results of a tool invocation that was initiated by a `ToolCall` from the model. The client should pass this `ToolResponse` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolCall`. + /// Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content. /// - [global::System.Text.Json.Serialization.JsonPropertyName("toolResponse")] - public global::Google.Gemini.ToolResponse? ToolResponse { 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; } /// - /// 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; } /// /// 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`. @@ -65,29 +66,28 @@ public sealed partial class Part public global::Google.Gemini.ToolCall? ToolCall { get; set; } /// - /// Optional. An opaque signature for the thought so it can be reused in subsequent requests. + /// Raw media bytes. Text should not be sent as raw bytes, use the 'text' field. /// - [global::System.Text.Json.Serialization.JsonPropertyName("thoughtSignature")] - public byte[]? ThoughtSignature { 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. + /// 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("videoMetadata")] - [global::System.Obsolete("This property marked as deprecated.")] - public global::Google.Gemini.VideoMetadata? VideoMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("executableCode")] + public global::Google.Gemini.ExecutableCode? ExecutableCode { get; set; } /// - /// Optional. Indicates if the part is thought from the model. + /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. /// - [global::System.Text.Json.Serialization.JsonPropertyName("thought")] - public bool? Thought { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("codeExecutionResult")] + public global::Google.Gemini.CodeExecutionResult? CodeExecutionResult { get; set; } /// - /// A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values. + /// Optional. Indicates if the part is thought from the model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("functionCall")] - public global::Google.Gemini.FunctionCall? FunctionCall { 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,71 +98,71 @@ public sealed partial class Part /// /// Initializes a new instance of the class. /// - /// - /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. + /// + /// 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. + /// + /// + /// 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. An opaque signature for the thought so it can be reused in subsequent requests. /// /// /// 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. - /// /// /// 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. /// + /// + /// A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values. + /// + /// + /// 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. /// - /// - /// 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. /// - /// - /// A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`. - /// - /// - /// Optional. An opaque signature for the thought so it can be reused in subsequent requests. + /// + /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. /// /// /// Optional. Indicates if the part is thought from the model. /// - /// - /// A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Part( - global::Google.Gemini.CodeExecutionResult? codeExecutionResult, - global::Google.Gemini.FileData? fileData, object? partMetadata, + global::Google.Gemini.ToolResponse? toolResponse, + byte[]? thoughtSignature, + global::Google.Gemini.FileData? fileData, string? text, global::Google.Gemini.FunctionResponse? functionResponse, + global::Google.Gemini.FunctionCall? functionCall, + global::Google.Gemini.ToolCall? toolCall, global::Google.Gemini.Blob? inlineData, - global::Google.Gemini.ToolResponse? toolResponse, global::Google.Gemini.ExecutableCode? executableCode, - global::Google.Gemini.ToolCall? toolCall, - byte[]? thoughtSignature, - bool? thought, - global::Google.Gemini.FunctionCall? functionCall) + global::Google.Gemini.CodeExecutionResult? codeExecutionResult, + bool? thought) { - this.CodeExecutionResult = codeExecutionResult; - this.FileData = fileData; this.PartMetadata = partMetadata; + this.ToolResponse = toolResponse; + this.ThoughtSignature = thoughtSignature; + this.FileData = fileData; this.Text = text; this.FunctionResponse = functionResponse; + this.FunctionCall = functionCall; + this.ToolCall = toolCall; this.InlineData = inlineData; - this.ToolResponse = toolResponse; this.ExecutableCode = executableCode; - this.ToolCall = toolCall; - this.ThoughtSignature = thoughtSignature; + this.CodeExecutionResult = codeExecutionResult; this.Thought = thought; - this.FunctionCall = functionCall; } /// 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 a11649af..7f87adba 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 @@ -8,6 +8,13 @@ namespace Google.Gemini /// public sealed partial class Permission { + /// + /// Optional. Immutable. The type of the grantee. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("granteeType")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeJsonConverter))] + public global::Google.Gemini.PermissionGranteeType? GranteeType { 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 @@ -16,11 +23,10 @@ public sealed partial class Permission public string? Name { get; set; } /// - /// Optional. Immutable. The type of the grantee. + /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// - [global::System.Text.Json.Serialization.JsonPropertyName("granteeType")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeJsonConverter))] - public global::Google.Gemini.PermissionGranteeType? GranteeType { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("emailAddress")] + public string? EmailAddress { get; set; } /// /// Required. The role granted by this permission. @@ -29,12 +35,6 @@ public sealed partial class Permission [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.PermissionRoleJsonConverter))] public global::Google.Gemini.PermissionRole? Role { get; set; } - /// - /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("emailAddress")] - public string? EmailAddress { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -44,32 +44,32 @@ public sealed partial class Permission /// /// Initializes a new instance of the class. /// + /// + /// Optional. Immutable. The type of the grantee. + /// /// /// Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.
/// Included only in responses /// - /// - /// Optional. Immutable. The type of the grantee. + /// + /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// /// /// Required. The role granted by this 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. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Permission( - string? name, global::Google.Gemini.PermissionGranteeType? granteeType, - global::Google.Gemini.PermissionRole? role, - string? emailAddress) + string? name, + string? emailAddress, + global::Google.Gemini.PermissionRole? role) { - this.Name = name; this.GranteeType = granteeType; - this.Role = role; + this.Name = name; this.EmailAddress = emailAddress; + this.Role = role; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ResponseFormatConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ResponseFormatConfig.g.cs index fafacf58..cb73b58e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ResponseFormatConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ResponseFormatConfig.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class ResponseFormatConfig { + /// + /// Configuration for text output format. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("text")] + public global::Google.Gemini.TextResponseFormat? Text { get; set; } + /// /// Configuration for audio output format. /// @@ -20,12 +26,6 @@ public sealed partial class ResponseFormatConfig [global::System.Text.Json.Serialization.JsonPropertyName("image")] public global::Google.Gemini.ImageResponseFormat? Image { get; set; } - /// - /// Configuration for text output format. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("text")] - public global::Google.Gemini.TextResponseFormat? Text { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class ResponseFormatConfig /// /// Initializes a new instance of the class. /// + /// + /// Configuration for text output format. + /// /// /// Configuration for audio output format. /// /// /// Configuration for image output format. /// - /// - /// Configuration for text output format. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ResponseFormatConfig( + global::Google.Gemini.TextResponseFormat? text, global::Google.Gemini.AudioResponseFormat? audio, - global::Google.Gemini.ImageResponseFormat? image, - global::Google.Gemini.TextResponseFormat? text) + global::Google.Gemini.ImageResponseFormat? image) { + this.Text = text; this.Audio = audio; this.Image = image; - this.Text = text; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.RetrievalConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.RetrievalConfig.g.cs index 587cc51b..10e07f1c 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.RetrievalConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.RetrievalConfig.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class RetrievalConfig { - /// - /// 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). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("languageCode")] - public string? LanguageCode { get; set; } - /// /// 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. /// [global::System.Text.Json.Serialization.JsonPropertyName("latLng")] public global::Google.Gemini.LatLng? LatLng { get; set; } + /// + /// 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). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("languageCode")] + public string? LanguageCode { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class RetrievalConfig /// /// Initializes a new instance of the class. /// - /// - /// 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). - /// /// /// 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. /// + /// + /// 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). + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public RetrievalConfig( - string? languageCode, - global::Google.Gemini.LatLng? latLng) + global::Google.Gemini.LatLng? latLng, + string? languageCode) { - this.LanguageCode = languageCode; this.LatLng = latLng; + this.LanguageCode = languageCode; } /// 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 04cc06c3..46da57c4 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,16 +9,10 @@ namespace Google.Gemini public sealed partial class RetrievedContext { /// - /// 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. + /// Optional. Title of the document. /// - [global::System.Text.Json.Serialization.JsonPropertyName("uri")] - public string? Uri { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("title")] + public string? Title { get; set; } /// /// Optional. Page number of the retrieved context, if applicable. @@ -27,16 +21,16 @@ public sealed partial class RetrievedContext public int? PageNumber { get; set; } /// - /// Optional. Text of the chunk. + /// Optional. URI reference of the semantic retrieval document. /// - [global::System.Text.Json.Serialization.JsonPropertyName("text")] - public string? Text { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("uri")] + public string? Uri { get; set; } /// - /// Optional. Title of the document. + /// Optional. Text of the chunk. /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - public string? Title { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("text")] + public string? Text { get; set; } /// /// Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123` @@ -44,6 +38,12 @@ public sealed partial class RetrievedContext [global::System.Text.Json.Serialization.JsonPropertyName("fileSearchStore")] public string? FileSearchStore { 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. User-provided metadata about the retrieved context. /// @@ -59,24 +59,24 @@ public sealed partial class RetrievedContext /// /// Initializes a new instance of the class. /// - /// - /// 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. + /// + /// Optional. Title of the document. /// /// /// Optional. Page number of the retrieved context, if applicable. /// + /// + /// Optional. URI reference of the semantic retrieval document. + /// /// /// Optional. Text of the chunk. /// - /// - /// Optional. Title of the document. - /// /// /// Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123` /// + /// + /// 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. /// @@ -84,20 +84,20 @@ public sealed partial class RetrievedContext [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public RetrievedContext( - string? mediaId, - string? uri, + string? title, int? pageNumber, + string? uri, string? text, - string? title, string? fileSearchStore, + string? mediaId, global::System.Collections.Generic.IList? customMetadata) { - this.MediaId = mediaId; - this.Uri = uri; + this.Title = title; this.PageNumber = pageNumber; + this.Uri = uri; this.Text = text; - this.Title = title; this.FileSearchStore = fileSearchStore; + this.MediaId = mediaId; this.CustomMetadata = customMetadata; } 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 c6531ab3..7eb80d6f 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 @@ -8,13 +8,6 @@ namespace Google.Gemini /// public sealed partial class SafetyRating { - /// - /// Required. The probability of harm for this content. - /// - [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; } - /// /// Required. The category for this rating. /// @@ -22,6 +15,13 @@ public sealed partial class SafetyRating [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryJsonConverter))] public global::Google.Gemini.SafetyRatingCategory? Category { get; set; } + /// + /// Required. The probability of harm for this content. + /// + [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; } + /// /// Was this content blocked because of this rating? /// @@ -37,12 +37,12 @@ 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. /// + /// + /// Required. The probability of harm for this content. + /// /// /// Was this content blocked because of this rating? /// @@ -50,12 +50,12 @@ public sealed partial class SafetyRating [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public SafetyRating( - global::Google.Gemini.SafetyRatingProbability? probability, global::Google.Gemini.SafetyRatingCategory? category, + global::Google.Gemini.SafetyRatingProbability? probability, bool? blocked) { - this.Probability = probability; this.Category = category; + this.Probability = probability; this.Blocked = blocked; } 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 6f418d22..00c2a014 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,34 +9,22 @@ namespace Google.Gemini public sealed partial class Schema { /// - /// Optional. Maximum number of the elements for Type.ARRAY. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxItems")] - public string? MaxItems { get; set; } - - /// - /// Optional. The title of the schema. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - public string? Title { get; set; } - - /// - /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING + /// 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("minLength")] - public string? MinLength { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("enum")] + public global::System.Collections.Generic.IList? Enum { 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. Required properties of Type.OBJECT. + /// Optional. Properties of Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("required")] - public global::System.Collections.Generic.IList? Required { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("properties")] + public global::System.Collections.Generic.Dictionary? Properties { get; set; } /// /// Optional. Pattern of the Type.STRING to restrict a string to a regular expression. @@ -51,22 +39,41 @@ public sealed partial class Schema public global::System.Collections.Generic.IList? AnyOf { 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. 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("default")] - public object? Default { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("description")] + public string? Description { get; set; } /// - /// Optional. Indicates if the value may be null. + /// Optional. Required properties of Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("nullable")] - public bool? Nullable { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("required")] + public global::System.Collections.Generic.IList? Required { get; set; } /// - /// Optional. Minimum number of the properties for Type.OBJECT. + /// Required. Data type. /// - [global::System.Text.Json.Serialization.JsonPropertyName("minProperties")] - public string? MinProperties { 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; } + + /// + /// 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("items")] + public global::Google.Gemini.Schema? Items { get; set; } + + /// + /// Optional. Minimum number of the elements for Type.ARRAY. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("minItems")] + public string? MinItems { 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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("default")] + public object? Default { get; set; } /// /// Optional. Maximum length of the Type.STRING @@ -75,11 +82,10 @@ public sealed partial class Schema public string? MaxLength { get; set; } /// - /// Required. Data type. + /// Optional. Maximum number of the elements for Type.ARRAY. /// - [global::System.Text.Json.Serialization.JsonPropertyName("type")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.SchemaTypeJsonConverter))] - public global::Google.Gemini.SchemaType? Type { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxItems")] + public string? MaxItems { get; set; } /// /// Optional. Maximum number of the properties for Type.OBJECT. @@ -88,16 +94,10 @@ public sealed partial class Schema public string? MaxProperties { get; set; } /// - /// Optional. Properties of Type.OBJECT. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("properties")] - public global::System.Collections.Generic.Dictionary? Properties { 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. 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("items")] - public global::Google.Gemini.Schema? Items { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("propertyOrdering")] + public global::System.Collections.Generic.IList? PropertyOrdering { get; set; } /// /// Optional. Maximum value of the Type.INTEGER and Type.NUMBER @@ -106,40 +106,40 @@ public sealed partial class Schema public double? Maximum { 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. Minimum number of the properties for Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("propertyOrdering")] - public global::System.Collections.Generic.IList? PropertyOrdering { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minProperties")] + public string? MinProperties { get; set; } /// - /// Optional. Example of the object. Will only populated when the object is the root. + /// Optional. Indicates if the value may be null. /// - [global::System.Text.Json.Serialization.JsonPropertyName("example")] - public object? Example { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("nullable")] + public bool? Nullable { get; set; } /// - /// Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER + /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING /// - [global::System.Text.Json.Serialization.JsonPropertyName("minimum")] - public double? Minimum { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minLength")] + public string? MinLength { get; set; } /// - /// Optional. Minimum number of the elements for Type.ARRAY. + /// Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality. /// - [global::System.Text.Json.Serialization.JsonPropertyName("minItems")] - public string? MinItems { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("format")] + public string? Format { 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. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER /// - [global::System.Text.Json.Serialization.JsonPropertyName("enum")] - public global::System.Collections.Generic.IList? Enum { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minimum")] + public double? Minimum { get; set; } /// - /// Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown. + /// Optional. The title of the schema. /// - [global::System.Text.Json.Serialization.JsonPropertyName("description")] - public string? Description { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("title")] + public string? Title { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -150,20 +150,14 @@ public sealed partial class Schema /// /// Initializes a new instance of the class. /// - /// - /// Optional. Maximum number of the elements for Type.ARRAY. - /// - /// - /// Optional. The title of the schema. - /// - /// - /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING + /// + /// 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 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. /// - /// - /// Optional. Required properties of Type.OBJECT. + /// + /// Optional. Properties of Type.OBJECT. /// /// /// Optional. Pattern of the Type.STRING to restrict a string to a regular expression. @@ -171,100 +165,106 @@ public sealed partial class Schema /// /// Optional. The value should be validated against any (one or more) of the subschemas in the list. /// - /// - /// 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. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown. /// - /// - /// Optional. Indicates if the value may be null. + /// + /// Optional. Required properties of Type.OBJECT. /// - /// - /// Optional. Minimum number of the properties for Type.OBJECT. + /// + /// Required. Data type. + /// + /// + /// 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. + /// + /// + /// 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 /// - /// - /// Required. Data type. + /// + /// Optional. Maximum number of the elements for Type.ARRAY. /// /// /// Optional. Maximum number of the properties for Type.OBJECT. /// - /// - /// 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. The order of the properties. Not a standard field in open api spec. Used to determine the order of the properties in the response. /// /// /// Optional. Maximum value of the Type.INTEGER and Type.NUMBER /// - /// - /// Optional. 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. Minimum number of the properties for Type.OBJECT. /// - /// - /// Optional. Example of the object. Will only populated when the object is the root. + /// + /// Optional. Indicates if the value may be null. /// - /// - /// Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER + /// + /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING /// - /// - /// Optional. Minimum number of the elements for Type.ARRAY. + /// + /// Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality. /// - /// - /// Optional. Possible values of the element of Type.STRING with enum format. For example we can define an Enum Direction as : {type:STRING, format:enum, enum:["EAST", NORTH", "SOUTH", "WEST"]} + /// + /// Optional. 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. The title of the schema. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Schema( - string? maxItems, - string? title, - string? minLength, - string? format, - global::System.Collections.Generic.IList? required, + global::System.Collections.Generic.IList? @enum, + object? example, + global::System.Collections.Generic.Dictionary? properties, string? pattern, global::System.Collections.Generic.IList? anyOf, + string? description, + global::System.Collections.Generic.IList? required, + global::Google.Gemini.SchemaType? type, + global::Google.Gemini.Schema? items, + string? minItems, object? @default, - bool? nullable, - string? minProperties, string? maxLength, - global::Google.Gemini.SchemaType? type, + string? maxItems, string? maxProperties, - global::System.Collections.Generic.Dictionary? properties, - global::Google.Gemini.Schema? items, - double? maximum, global::System.Collections.Generic.IList? propertyOrdering, - object? example, + double? maximum, + string? minProperties, + bool? nullable, + string? minLength, + string? format, double? minimum, - string? minItems, - global::System.Collections.Generic.IList? @enum, - string? description) + string? title) { - this.MaxItems = maxItems; - this.Title = title; - this.MinLength = minLength; - this.Format = format; - this.Required = required; + this.Enum = @enum; + this.Example = example; + this.Properties = properties; this.Pattern = pattern; this.AnyOf = anyOf; + this.Description = description; + this.Required = required; + this.Type = type; + this.Items = items; + this.MinItems = minItems; this.Default = @default; - this.Nullable = nullable; - this.MinProperties = minProperties; this.MaxLength = maxLength; - this.Type = type; + this.MaxItems = maxItems; this.MaxProperties = maxProperties; - this.Properties = properties; - this.Items = items; - this.Maximum = maximum; this.PropertyOrdering = propertyOrdering; - this.Example = example; + this.Maximum = maximum; + this.MinProperties = minProperties; + this.Nullable = nullable; + this.MinLength = minLength; + this.Format = format; this.Minimum = minimum; - this.MinItems = minItems; - this.Enum = @enum; - this.Description = description; + this.Title = title; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeechConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeechConfig.g.cs index 2cdf8fc7..cc31a307 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeechConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeechConfig.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class SpeechConfig { - /// - /// The configuration for the multi-speaker setup. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("multiSpeakerVoiceConfig")] - public global::Google.Gemini.MultiSpeakerVoiceConfig? MultiSpeakerVoiceConfig { get; set; } - /// /// 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`. /// [global::System.Text.Json.Serialization.JsonPropertyName("languageCode")] public string? LanguageCode { get; set; } + /// + /// The configuration for the multi-speaker setup. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("multiSpeakerVoiceConfig")] + public global::Google.Gemini.MultiSpeakerVoiceConfig? MultiSpeakerVoiceConfig { get; set; } + /// /// The configuration for the voice to use. /// @@ -35,12 +35,12 @@ public sealed partial class SpeechConfig /// /// Initializes a new instance of the class. /// - /// - /// The configuration for the multi-speaker setup. - /// /// /// 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`. /// + /// + /// The configuration for the multi-speaker setup. + /// /// /// The configuration for the voice to use. /// @@ -48,12 +48,12 @@ public sealed partial class SpeechConfig [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public SpeechConfig( - global::Google.Gemini.MultiSpeakerVoiceConfig? multiSpeakerVoiceConfig, string? languageCode, + global::Google.Gemini.MultiSpeakerVoiceConfig? multiSpeakerVoiceConfig, global::Google.Gemini.VoiceConfig? voiceConfig) { - this.MultiSpeakerVoiceConfig = multiSpeakerVoiceConfig; this.LanguageCode = languageCode; + this.MultiSpeakerVoiceConfig = multiSpeakerVoiceConfig; this.VoiceConfig = voiceConfig; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Status.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Status.g.cs index 11577f8c..d40cd9d8 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Status.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Status.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class Status { - /// - /// A list of messages that carry the error details. There is a common set of message types for APIs to use. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("details")] - public global::System.Collections.Generic.IList? Details { get; set; } - /// /// The status code, which should be an enum value of google.rpc.Code. /// @@ -26,6 +20,12 @@ public sealed partial class Status [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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("details")] + public global::System.Collections.Generic.IList? Details { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class Status /// /// Initializes a new instance of the class. /// - /// - /// A list of messages that carry the error details. There is a common set of message types for APIs to use. - /// /// /// The status code, which should be an enum value of google.rpc.Code. /// /// /// A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client. /// + /// + /// A list of messages that carry the error details. There is a common set of message types for APIs to use. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Status( - global::System.Collections.Generic.IList? details, int? code, - string? message) + string? message, + global::System.Collections.Generic.IList? details) { - this.Details = details; 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 589fdec8..b39ac295 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 @@ -8,30 +8,30 @@ namespace Google.Gemini /// public sealed partial class StreamableHttpTransport { - /// - /// Optional: Fields for authentication headers, timeouts, etc., if needed. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("headers")] - public global::System.Collections.Generic.Dictionary? Headers { get; set; } - /// /// The full URL for the MCPServer endpoint. Example: "https://api.example.com/mcp" /// [global::System.Text.Json.Serialization.JsonPropertyName("url")] public string? Url { get; set; } - /// - /// HTTP timeout for regular operations. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("timeout")] - public string? Timeout { get; set; } - /// /// Timeout for SSE read operations. /// [global::System.Text.Json.Serialization.JsonPropertyName("sseReadTimeout")] public string? SseReadTimeout { get; set; } + /// + /// Optional: Fields for authentication headers, timeouts, etc., if needed. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("headers")] + public global::System.Collections.Generic.Dictionary? Headers { get; set; } + + /// + /// HTTP timeout for regular operations. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("timeout")] + public string? Timeout { get; set; } + /// /// Whether to close the client session when the transport closes. /// @@ -47,18 +47,18 @@ public sealed partial class StreamableHttpTransport /// /// Initializes a new instance of the class. /// - /// - /// Optional: Fields for authentication headers, timeouts, etc., if needed. - /// /// /// The full URL for the MCPServer endpoint. Example: "https://api.example.com/mcp" /// - /// - /// HTTP timeout for regular operations. - /// /// /// Timeout for SSE read operations. /// + /// + /// Optional: Fields for authentication headers, timeouts, etc., if needed. + /// + /// + /// HTTP timeout for regular operations. + /// /// /// Whether to close the client session when the transport closes. /// @@ -66,16 +66,16 @@ public sealed partial class StreamableHttpTransport [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public StreamableHttpTransport( - global::System.Collections.Generic.Dictionary? headers, string? url, - string? timeout, string? sseReadTimeout, + global::System.Collections.Generic.Dictionary? headers, + string? timeout, bool? terminateOnClose) { - this.Headers = headers; this.Url = url; - this.Timeout = timeout; this.SseReadTimeout = sseReadTimeout; + this.Headers = headers; + this.Timeout = timeout; this.TerminateOnClose = terminateOnClose; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ThinkingConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ThinkingConfig.g.cs index 6470d5f7..f6546f19 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ThinkingConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ThinkingConfig.g.cs @@ -8,13 +8,6 @@ namespace Google.Gemini /// public sealed partial class ThinkingConfig { - /// - /// 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. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("thinkingLevel")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelJsonConverter))] - public global::Google.Gemini.ThinkingConfigThinkingLevel? ThinkingLevel { get; set; } - /// /// Indicates whether to include thoughts in the response. If true, thoughts are returned only when available. /// @@ -27,6 +20,13 @@ public sealed partial class ThinkingConfig [global::System.Text.Json.Serialization.JsonPropertyName("thinkingBudget")] public int? ThinkingBudget { get; set; } + /// + /// Optional. Controls the maximum depth of the model's internal reasoning process before it produces a response. 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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("thinkingLevel")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelJsonConverter))] + public global::Google.Gemini.ThinkingConfigThinkingLevel? ThinkingLevel { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -36,26 +36,26 @@ public sealed partial class ThinkingConfig /// /// Initializes a new instance of the class. /// - /// - /// 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. - /// /// /// Indicates whether to include thoughts in the response. If true, thoughts are returned only when available. /// /// /// The number of thoughts tokens that the model should generate. /// + /// + /// Optional. Controls the maximum depth of the model's internal reasoning process before it produces a response. 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. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ThinkingConfig( - global::Google.Gemini.ThinkingConfigThinkingLevel? thinkingLevel, bool? includeThoughts, - int? thinkingBudget) + int? thinkingBudget, + global::Google.Gemini.ThinkingConfigThinkingLevel? thinkingLevel) { - this.ThinkingLevel = thinkingLevel; this.IncludeThoughts = includeThoughts; this.ThinkingBudget = thinkingBudget; + this.ThinkingLevel = thinkingLevel; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Tool.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Tool.g.cs index 9de8540c..4be16a07 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,10 +9,16 @@ namespace Google.Gemini public sealed partial class Tool { /// - /// Tool to support URL context retrieval. + /// Tool to retrieve public web data for grounding, powered by Google. /// - [global::System.Text.Json.Serialization.JsonPropertyName("urlContext")] - public global::Google.Gemini.UrlContext? UrlContext { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("googleSearchRetrieval")] + public global::Google.Gemini.GoogleSearchRetrieval? GoogleSearchRetrieval { get; set; } + + /// + /// Optional. MCP Servers to connect to. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("mcpServers")] + public global::System.Collections.Generic.IList? McpServers { get; set; } /// /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. @@ -21,16 +27,16 @@ public sealed partial class Tool public global::Google.Gemini.GoogleSearch? GoogleSearch { get; set; } /// - /// The GoogleMaps Tool that provides geospatial context for the user's query. + /// Tool to support URL context retrieval. /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleMaps")] - public global::Google.Gemini.GoogleMaps? GoogleMaps { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("urlContext")] + public global::Google.Gemini.UrlContext? UrlContext { get; set; } /// - /// The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API. + /// The GoogleMaps Tool that provides geospatial context for the user's query. /// - [global::System.Text.Json.Serialization.JsonPropertyName("fileSearch")] - public global::Google.Gemini.FileSearch? FileSearch { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("googleMaps")] + public global::Google.Gemini.GoogleMaps? GoogleMaps { 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. @@ -39,10 +45,10 @@ public sealed partial class Tool public global::System.Collections.Generic.IList? FunctionDeclarations { get; set; } /// - /// Tool to retrieve public web data for grounding, powered by Google. + /// Computer Use tool type. /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleSearchRetrieval")] - public global::Google.Gemini.GoogleSearchRetrieval? GoogleSearchRetrieval { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("computerUse")] + public global::Google.Gemini.ComputerUse? ComputerUse { 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 +57,10 @@ public sealed partial class Tool public global::Google.Gemini.CodeExecution? CodeExecution { get; set; } /// - /// Optional. MCP Servers to connect to. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("mcpServers")] - public global::System.Collections.Generic.IList? McpServers { get; set; } - - /// - /// Computer Use tool type. + /// The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API. /// - [global::System.Text.Json.Serialization.JsonPropertyName("computerUse")] - public global::Google.Gemini.ComputerUse? ComputerUse { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("fileSearch")] + public global::Google.Gemini.FileSearch? FileSearch { 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 support URL context retrieval. + /// + /// Tool to retrieve public web data for grounding, powered by Google. + /// + /// + /// Optional. MCP Servers to connect to. /// /// /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. /// + /// + /// Tool to support URL context retrieval. + /// /// /// 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. - /// /// /// Optional. A list of `FunctionDeclarations` available to the model that can be used for function calling. The model or system does not execute the function. Instead the defined function may be returned as a FunctionCall with arguments to the client side for execution. The model may decide to call a subset of these functions by populating FunctionCall in the response. The next conversation turn may contain a FunctionResponse with the Content.role "function" generation context for the next model turn. /// - /// - /// Tool to retrieve public web data for grounding, powered by Google. + /// + /// Computer Use tool type. /// /// /// 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. /// - /// - /// Optional. MCP Servers to connect to. - /// - /// - /// Computer Use tool type. + /// + /// The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Tool( - global::Google.Gemini.UrlContext? urlContext, + global::Google.Gemini.GoogleSearchRetrieval? googleSearchRetrieval, + global::System.Collections.Generic.IList? mcpServers, global::Google.Gemini.GoogleSearch? googleSearch, + global::Google.Gemini.UrlContext? urlContext, global::Google.Gemini.GoogleMaps? googleMaps, - global::Google.Gemini.FileSearch? fileSearch, global::System.Collections.Generic.IList? functionDeclarations, - global::Google.Gemini.GoogleSearchRetrieval? googleSearchRetrieval, + global::Google.Gemini.ComputerUse? computerUse, global::Google.Gemini.CodeExecution? codeExecution, - global::System.Collections.Generic.IList? mcpServers, - global::Google.Gemini.ComputerUse? computerUse) + global::Google.Gemini.FileSearch? fileSearch) { - this.UrlContext = urlContext; + this.GoogleSearchRetrieval = googleSearchRetrieval; + this.McpServers = mcpServers; this.GoogleSearch = googleSearch; + this.UrlContext = urlContext; this.GoogleMaps = googleMaps; - this.FileSearch = fileSearch; this.FunctionDeclarations = functionDeclarations; - this.GoogleSearchRetrieval = googleSearchRetrieval; - this.CodeExecution = codeExecution; - this.McpServers = mcpServers; this.ComputerUse = computerUse; + this.CodeExecution = codeExecution; + this.FileSearch = fileSearch; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolConfig.g.cs index 04b17ff7..247efaa6 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolConfig.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ToolConfig { - /// - /// Retrieval config. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("retrievalConfig")] - public global::Google.Gemini.RetrievalConfig? RetrievalConfig { get; set; } - /// /// Configuration for specifying function calling behavior. /// [global::System.Text.Json.Serialization.JsonPropertyName("functionCallingConfig")] public global::Google.Gemini.FunctionCallingConfig? FunctionCallingConfig { get; set; } + /// + /// Retrieval config. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("retrievalConfig")] + public global::Google.Gemini.RetrievalConfig? RetrievalConfig { get; set; } + /// /// Optional. If true, the API response will include the server-side tool calls and responses within the `Content` message. This allows clients to observe the server's tool interactions. /// @@ -35,12 +35,12 @@ public sealed partial class ToolConfig /// /// Initializes a new instance of the class. /// - /// - /// Retrieval config. - /// /// /// Configuration for specifying function calling behavior. /// + /// + /// Retrieval config. + /// /// /// Optional. If true, the API response will include the server-side tool calls and responses within the `Content` message. This allows clients to observe the server's tool interactions. /// @@ -48,12 +48,12 @@ public sealed partial class ToolConfig [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ToolConfig( - global::Google.Gemini.RetrievalConfig? retrievalConfig, global::Google.Gemini.FunctionCallingConfig? functionCallingConfig, + global::Google.Gemini.RetrievalConfig? retrievalConfig, bool? includeServerSideToolInvocations) { - this.RetrievalConfig = retrievalConfig; this.FunctionCallingConfig = functionCallingConfig; + this.RetrievalConfig = retrievalConfig; this.IncludeServerSideToolInvocations = includeServerSideToolInvocations; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolResponse.g.cs index e99681cb..3cf6fa00 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolResponse.g.cs @@ -14,12 +14,6 @@ public sealed partial class ToolResponse [global::System.Text.Json.Serialization.JsonPropertyName("id")] public string? Id { get; set; } - /// - /// Optional. The tool response. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("response")] - public object? Response { get; set; } - /// /// Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`. /// @@ -27,6 +21,12 @@ public sealed partial class ToolResponse [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeJsonConverter))] public global::Google.Gemini.ToolResponseToolType? ToolType { get; set; } + /// + /// Optional. The tool response. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("response")] + public object? Response { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -39,23 +39,23 @@ public sealed partial class ToolResponse /// /// Optional. The identifier of the tool call this response is for. /// - /// - /// Optional. The tool response. - /// /// /// Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`. /// + /// + /// Optional. The tool response. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ToolResponse( string? id, - object? response, - global::Google.Gemini.ToolResponseToolType? toolType) + global::Google.Gemini.ToolResponseToolType? toolType, + object? response) { this.Id = id; - this.Response = response; this.ToolType = toolType; + this.Response = response; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TranslationConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TranslationConfig.g.cs index 5586af7c..9487be42 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TranslationConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TranslationConfig.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class TranslationConfig { - /// - /// Required. The target language for translation. Supported values are BCP-47 language codes (e.g. "en", "es", "fr"). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("targetLanguageCode")] - public string? TargetLanguageCode { get; set; } - /// /// Optional. If true, the model will generate audio when the target language is spoken, essentially it will parrot the input. If false, we will not produce audio for the target language. /// [global::System.Text.Json.Serialization.JsonPropertyName("echoTargetLanguage")] public bool? EchoTargetLanguage { get; set; } + /// + /// Required. The target language for translation. Supported values are BCP-47 language codes (e.g. "en", "es", "fr"). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("targetLanguageCode")] + public string? TargetLanguageCode { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class TranslationConfig /// /// Initializes a new instance of the class. /// - /// - /// Required. The target language for translation. Supported values are BCP-47 language codes (e.g. "en", "es", "fr"). - /// /// /// Optional. If true, the model will generate audio when the target language is spoken, essentially it will parrot the input. If false, we will not produce audio for the target language. /// + /// + /// Required. The target language for translation. Supported values are BCP-47 language codes (e.g. "en", "es", "fr"). + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public TranslationConfig( - string? targetLanguageCode, - bool? echoTargetLanguage) + bool? echoTargetLanguage, + string? targetLanguageCode) { - this.TargetLanguageCode = targetLanguageCode; this.EchoTargetLanguage = echoTargetLanguage; + this.TargetLanguageCode = targetLanguageCode; } /// 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 822fb74a..915d9601 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,24 +9,11 @@ namespace Google.Gemini public sealed partial class TunedModel { /// - /// 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; } - - /// - /// Optional. A short description of this model. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("description")] - public string? Description { get; set; } - - /// - /// Output only. The state of the tuned model.
+ /// Output only. The timestamp when this model was created.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("state")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.TunedModelStateJsonConverter))] - public global::Google.Gemini.TunedModelState? State { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { 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. @@ -35,36 +22,44 @@ public sealed partial class TunedModel public float? TopP { get; set; } /// - /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. + /// Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] - public float? Temperature { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// - /// Output only. The timestamp when this model was created.
+ /// 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. + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("topK")] + public int? TopK { get; set; } + + /// + /// Output only. The timestamp when this model was updated.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { 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`
+ /// Output only. The state of the tuned model.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("state")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.TunedModelStateJsonConverter))] + public global::Google.Gemini.TunedModelState? State { get; set; } /// - /// Tuning tasks that create tuned models. + /// Optional. List of project numbers that have read access to the tuned model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("tuningTask")] - public global::Google.Gemini.TuningTask? TuningTask { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("readerProjectNumbers")] + public global::System.Collections.Generic.IList? ReaderProjectNumbers { 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. + /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` /// - [global::System.Text.Json.Serialization.JsonPropertyName("topK")] - public int? TopK { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("baseModel")] + public string? BaseModel { get; set; } /// /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. @@ -73,17 +68,16 @@ public sealed partial class TunedModel public string? DisplayName { get; set; } /// - /// Output only. The timestamp when this model was updated.
- /// Included only in responses + /// Tuning tasks that create tuned models. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("tuningTask")] + public global::Google.Gemini.TuningTask? TuningTask { get; set; } /// - /// Optional. List of project numbers that have read access to the tuned model. + /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("readerProjectNumbers")] - public global::System.Collections.Generic.IList? ReaderProjectNumbers { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] + public float? Temperature { get; set; } /// /// Tuned model as a source for training a new model. @@ -91,6 +85,12 @@ public sealed partial class TunedModel [global::System.Text.Json.Serialization.JsonPropertyName("tunedModelSource")] public global::Google.Gemini.TunedModelSource? TunedModelSource { get; set; } + /// + /// Optional. A short description of this model. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("description")] + public string? Description { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -100,80 +100,80 @@ public sealed partial class TunedModel /// /// Initializes a new instance of the class. /// - /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` - /// - /// - /// Optional. A short description of this model. - /// - /// - /// Output only. The state of the tuned model.
+ /// + /// Output only. The timestamp when this model was created.
/// Included only in responses /// /// /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. - /// - /// - /// Output only. The timestamp when this model was created.
- /// Included only in responses - /// /// /// Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`
/// Included only in responses /// - /// - /// Tuning tasks that create tuned models. - /// /// /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. - /// /// /// Output only. The timestamp when this model was updated.
/// Included only in responses /// + /// + /// Output only. The state of the tuned model.
+ /// Included only in responses + /// /// /// Optional. List of project numbers that have read access to the tuned 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. + /// + /// + /// Tuning tasks that create tuned models. + /// + /// + /// 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. + /// /// /// Tuned model as a source for training a new model. /// + /// + /// Optional. A short description of this model. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public TunedModel( - string? baseModel, - string? description, - global::Google.Gemini.TunedModelState? state, - float? topP, - float? temperature, string? createTime, + float? topP, string? name, - global::Google.Gemini.TuningTask? tuningTask, int? topK, - string? displayName, string? updateTime, + global::Google.Gemini.TunedModelState? state, global::System.Collections.Generic.IList? readerProjectNumbers, - global::Google.Gemini.TunedModelSource? tunedModelSource) + string? baseModel, + string? displayName, + global::Google.Gemini.TuningTask? tuningTask, + float? temperature, + global::Google.Gemini.TunedModelSource? tunedModelSource, + string? description) { - this.BaseModel = baseModel; - this.Description = description; - this.State = state; - this.TopP = topP; - this.Temperature = temperature; this.CreateTime = createTime; + this.TopP = topP; this.Name = name; - this.TuningTask = tuningTask; this.TopK = topK; - this.DisplayName = displayName; this.UpdateTime = updateTime; + this.State = state; this.ReaderProjectNumbers = readerProjectNumbers; + this.BaseModel = baseModel; + this.DisplayName = displayName; + this.TuningTask = tuningTask; + this.Temperature = temperature; this.TunedModelSource = tunedModelSource; + this.Description = description; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TuningSnapshot.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TuningSnapshot.g.cs index 0dd495e3..0cb1717c 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TuningSnapshot.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TuningSnapshot.g.cs @@ -9,18 +9,18 @@ namespace Google.Gemini public sealed partial class TuningSnapshot { /// - /// Output only. The timestamp when this metric was computed.
+ /// Output only. The epoch this step was part of.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("computeTime")] - public string? ComputeTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("epoch")] + public int? Epoch { get; set; } /// - /// Output only. The epoch this step was part of.
+ /// Output only. The mean loss of the training examples for this step.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("epoch")] - public int? Epoch { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("meanLoss")] + public float? MeanLoss { get; set; } /// /// Output only. The tuning step.
@@ -30,11 +30,11 @@ public sealed partial class TuningSnapshot public int? Step { get; set; } /// - /// Output only. The mean loss of the training examples for this step.
+ /// Output only. The timestamp when this metric was computed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("meanLoss")] - public float? MeanLoss { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("computeTime")] + public string? ComputeTime { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -45,35 +45,35 @@ public sealed partial class TuningSnapshot /// /// Initializes a new instance of the class. /// - /// - /// Output only. The timestamp when this metric was computed.
- /// Included only in responses - /// /// /// Output only. The epoch this step was part of.
/// Included only in responses /// + /// + /// Output only. The mean loss of the training examples for this step.
+ /// Included only in responses + /// /// /// Output only. The tuning step.
/// Included only in responses /// - /// - /// Output only. The mean loss of the training examples for this step.
+ /// + /// Output only. The timestamp when this metric was computed.
/// Included only in responses /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public TuningSnapshot( - string? computeTime, int? epoch, + float? meanLoss, int? step, - float? meanLoss) + string? computeTime) { - this.ComputeTime = computeTime; this.Epoch = epoch; - this.Step = step; this.MeanLoss = meanLoss; + this.Step = step; + this.ComputeTime = computeTime; } /// 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 b675917c..54053061 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TuningTask.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TuningTask.g.cs @@ -9,17 +9,11 @@ namespace Google.Gemini public sealed partial class TuningTask { /// - /// Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance - /// - [global::System.Text.Json.Serialization.JsonPropertyName("hyperparameters")] - public global::Google.Gemini.Hyperparameters? Hyperparameters { get; set; } - - /// - /// Output only. The timestamp when tuning this model started.
+ /// Output only. Metrics collected during tuning.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("startTime")] - public string? StartTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("snapshots")] + public global::System.Collections.Generic.IList? Snapshots { get; set; } /// /// Output only. The timestamp when tuning this model completed.
@@ -28,6 +22,13 @@ public sealed partial class TuningTask [global::System.Text.Json.Serialization.JsonPropertyName("completeTime")] public string? CompleteTime { get; set; } + /// + /// Output only. The timestamp when tuning this model started.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("startTime")] + public string? StartTime { get; set; } + /// /// Dataset for training or validation. /// @@ -35,11 +36,10 @@ public sealed partial class TuningTask public global::Google.Gemini.Dataset? TrainingData { get; set; } /// - /// Output only. Metrics collected during tuning.
- /// 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("snapshots")] - public global::System.Collections.Generic.IList? Snapshots { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("hyperparameters")] + public global::Google.Gemini.Hyperparameters? Hyperparameters { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -50,39 +50,39 @@ public sealed partial class TuningTask /// /// Initializes a new instance of the class. /// - /// - /// 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.
+ /// + /// Output only. Metrics collected during tuning.
/// Included only in responses /// /// /// Output only. The timestamp when tuning this model completed.
/// Included only in responses /// + /// + /// Output only. The timestamp when tuning this model started.
+ /// Included only in responses + /// /// /// Dataset for training or validation. /// - /// - /// Output only. Metrics collected during tuning.
- /// Included only in responses + /// + /// Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public TuningTask( - global::Google.Gemini.Hyperparameters? hyperparameters, - string? startTime, + global::System.Collections.Generic.IList? snapshots, string? completeTime, + string? startTime, global::Google.Gemini.Dataset? trainingData, - global::System.Collections.Generic.IList? snapshots) + global::Google.Gemini.Hyperparameters? hyperparameters) { - this.Hyperparameters = hyperparameters; - this.StartTime = startTime; + this.Snapshots = snapshots; this.CompleteTime = completeTime; + this.StartTime = startTime; this.TrainingData = trainingData; - this.Snapshots = snapshots; + this.Hyperparameters = hyperparameters; } /// 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 8be9fd58..92ed5e03 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,6 +8,12 @@ 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. /// @@ -15,12 +21,6 @@ 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. /// - /// - /// Status of the url retrieval. - /// /// /// Retrieved url by the tool. /// + /// + /// Status of the url retrieval. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public UrlMetadata( - global::Google.Gemini.UrlMetadataUrlRetrievalStatus? urlRetrievalStatus, - string? retrievedUrl) + string? retrievedUrl, + global::Google.Gemini.UrlMetadataUrlRetrievalStatus? urlRetrievalStatus) { - this.UrlRetrievalStatus = urlRetrievalStatus; this.RetrievedUrl = retrievedUrl; + this.UrlRetrievalStatus = urlRetrievalStatus; } /// 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 e061e599..8e2ff7b4 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,37 +9,25 @@ namespace Google.Gemini public sealed partial class UsageMetadata { /// - /// Total number of tokens across all the generated response candidates. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokenCount")] - public int? CandidatesTokenCount { get; set; } - - /// - /// Total token count for the generation request (prompt + thoughts + response candidates). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("totalTokenCount")] - public int? TotalTokenCount { get; set; } - - /// - /// Output only. List of modalities that were returned in the response.
- /// 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. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokensDetails")] - public global::System.Collections.Generic.IList? CandidatesTokensDetails { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("promptTokenCount")] + public int? PromptTokenCount { get; set; } /// - /// Output only. List of modalities of the cached content in the request input.
+ /// Output only. Number of tokens present in tool-use prompt(s).
/// 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("toolUsePromptTokenCount")] + public int? ToolUsePromptTokenCount { 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; } /// /// Output only. Number of tokens of thoughts for thinking models.
@@ -49,18 +37,18 @@ public sealed partial class UsageMetadata public int? ThoughtsTokenCount { 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. + /// Output only. List of modalities that were returned in the response.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("promptTokenCount")] - public int? PromptTokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokensDetails")] + public global::System.Collections.Generic.IList? CandidatesTokensDetails { get; set; } /// - /// Output only. Service tier of the request.
+ /// Output only. List of modalities that were processed for tool-use request inputs.
/// Included only in responses ///
- [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("toolUsePromptTokensDetails")] + public global::System.Collections.Generic.IList? ToolUsePromptTokensDetails { get; set; } /// /// Number of tokens in the cached part of the prompt (the cached content) @@ -69,18 +57,30 @@ public sealed partial class UsageMetadata public int? CachedContentTokenCount { get; set; } /// - /// Output only. List of modalities that were processed for tool-use request inputs.
+ /// Output only. List of modalities that were processed 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("promptTokensDetails")] + public global::System.Collections.Generic.IList? PromptTokensDetails { get; set; } /// - /// Output only. Number of tokens present in tool-use prompt(s).
+ /// Output only. List of modalities of the cached content in the request input.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("toolUsePromptTokenCount")] - public int? ToolUsePromptTokenCount { 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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokenCount")] + public int? CandidatesTokenCount { get; set; } + + /// + /// Total token count for the generation request (prompt + thoughts + response candidates). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("totalTokenCount")] + public int? TotalTokenCount { get; set; } /// /// Output only. Number of tokens in the response. Used by Gemini 3.1+ Live API models instead of candidatesTokenCount.
@@ -105,46 +105,46 @@ public sealed partial class UsageMetadata /// /// Initializes a new instance of the class. /// - /// - /// Total number of tokens across all the generated response candidates. - /// - /// - /// 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 + /// + /// Number of tokens in the prompt. When `cached_content` is set, this is still the total effective prompt size meaning this includes the number of tokens in the cached content. /// - /// - /// Output only. List of modalities of the cached content in the request input.
+ /// + /// Output only. Number of tokens present in tool-use prompt(s).
/// Included only in responses /// - /// - /// Output only. List of modalities that were processed in the request input.
+ /// + /// Output only. Service tier of the request.
/// Included only in responses /// /// /// Output only. Number of tokens of thoughts for thinking models.
/// 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. + /// + /// Output only. List of modalities that were returned in the response.
+ /// Included only in responses /// - /// - /// Output only. Service tier of the request.
+ /// + /// Output only. List of modalities that were processed for tool-use request inputs.
/// Included only in responses /// /// /// Number of tokens in the cached part of the prompt (the cached content) /// - /// - /// Output only. List of modalities that were processed for tool-use request inputs.
+ /// + /// Output only. List of modalities that were processed in the request input.
/// Included only in responses /// - /// - /// Output only. Number of tokens present in tool-use prompt(s).
+ /// + /// Output only. List of modalities of the cached content in the request input.
/// Included only in responses /// + /// + /// Total number of tokens across all the generated response candidates. + /// + /// + /// Total token count for the generation request (prompt + thoughts + response candidates). + /// /// /// Output only. Number of tokens in the response. Used by Gemini 3.1+ Live API models instead of candidatesTokenCount.
/// Included only in responses @@ -157,31 +157,31 @@ public sealed partial class UsageMetadata [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public UsageMetadata( - int? candidatesTokenCount, - int? totalTokenCount, - global::System.Collections.Generic.IList? candidatesTokensDetails, - global::System.Collections.Generic.IList? cacheTokensDetails, - global::System.Collections.Generic.IList? promptTokensDetails, - int? thoughtsTokenCount, int? promptTokenCount, + int? toolUsePromptTokenCount, global::Google.Gemini.UsageMetadataServiceTier? serviceTier, - int? cachedContentTokenCount, + int? thoughtsTokenCount, + global::System.Collections.Generic.IList? candidatesTokensDetails, global::System.Collections.Generic.IList? toolUsePromptTokensDetails, - int? toolUsePromptTokenCount, + int? cachedContentTokenCount, + global::System.Collections.Generic.IList? promptTokensDetails, + global::System.Collections.Generic.IList? cacheTokensDetails, + int? candidatesTokenCount, + int? totalTokenCount, int? responseTokenCount, global::System.Collections.Generic.IList? responseTokensDetails) { - this.CandidatesTokenCount = candidatesTokenCount; - this.TotalTokenCount = totalTokenCount; - this.CandidatesTokensDetails = candidatesTokensDetails; - this.CacheTokensDetails = cacheTokensDetails; - this.PromptTokensDetails = promptTokensDetails; - this.ThoughtsTokenCount = thoughtsTokenCount; this.PromptTokenCount = promptTokenCount; + this.ToolUsePromptTokenCount = toolUsePromptTokenCount; this.ServiceTier = serviceTier; - this.CachedContentTokenCount = cachedContentTokenCount; + this.ThoughtsTokenCount = thoughtsTokenCount; + this.CandidatesTokensDetails = candidatesTokensDetails; this.ToolUsePromptTokensDetails = toolUsePromptTokensDetails; - this.ToolUsePromptTokenCount = toolUsePromptTokenCount; + this.CachedContentTokenCount = cachedContentTokenCount; + this.PromptTokensDetails = promptTokensDetails; + this.CacheTokensDetails = cacheTokensDetails; + this.CandidatesTokenCount = candidatesTokenCount; + this.TotalTokenCount = totalTokenCount; this.ResponseTokenCount = responseTokenCount; this.ResponseTokensDetails = responseTokensDetails; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.VideoMetadata.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.VideoMetadata.g.cs index 9220677a..011001b8 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 @@ -9,6 +9,13 @@ namespace Google.Gemini [global::System.Obsolete("This model marked as deprecated.")] public sealed partial class VideoMetadata { + /// + /// Optional. The start offset of the video. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("startOffset")] + [global::System.Obsolete("This property marked as deprecated.")] + public string? StartOffset { get; set; } + /// /// Optional. The end offset of the video. /// @@ -23,13 +30,6 @@ public sealed partial class VideoMetadata [global::System.Obsolete("This property marked as deprecated.")] public double? Fps { get; set; } - /// - /// Optional. The start offset of the video. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("startOffset")] - [global::System.Obsolete("This property marked as deprecated.")] - 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 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? startOffset) + double? fps) { + this.StartOffset = startOffset; this.EndOffset = endOffset; this.Fps = fps; - this.StartOffset = startOffset; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.WhiteSpaceConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.WhiteSpaceConfig.g.cs index c7b0c0fb..24c4a609 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.WhiteSpaceConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.WhiteSpaceConfig.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class WhiteSpaceConfig { - /// - /// Maximum number of overlapping tokens between two adjacent chunks. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxOverlapTokens")] - public int? MaxOverlapTokens { get; set; } - /// /// 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. /// [global::System.Text.Json.Serialization.JsonPropertyName("maxTokensPerChunk")] public int? MaxTokensPerChunk { get; set; } + /// + /// Maximum number of overlapping tokens between two adjacent chunks. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("maxOverlapTokens")] + public int? MaxOverlapTokens { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class WhiteSpaceConfig /// /// Initializes a new instance of the class. /// - /// - /// Maximum number of overlapping tokens between two adjacent chunks. - /// /// /// 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. /// + /// + /// Maximum number of overlapping tokens between two adjacent chunks. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public WhiteSpaceConfig( - int? maxOverlapTokens, - int? maxTokensPerChunk) + int? maxTokensPerChunk, + int? maxOverlapTokens) { - this.MaxOverlapTokens = maxOverlapTokens; this.MaxTokensPerChunk = maxTokensPerChunk; + this.MaxOverlapTokens = maxOverlapTokens; } /// diff --git a/src/libs/Google.Gemini/openapi.json b/src/libs/Google.Gemini/openapi.json index 5547e1cb..fe8f8313 100644 --- a/src/libs/Google.Gemini/openapi.json +++ b/src/libs/Google.Gemini/openapi.json @@ -11,28 +11,19 @@ } ], "paths": { - "/cachedContents/{cachedContentsId}": { - "patch": { - "description": "Updates CachedContent resource (only expiration is updatable).", - "operationId": "cachedContents.patch", + "/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": "cachedContentsId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`", - "schema": { - "type": "string", - "pattern": "^cachedContents/[^/]+$" - } - }, - { - "name": "updateMask", - "in": "query", - "description": "The list of fields to update.", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "format": "google-fieldmask" + "pattern": "^tunedModels/[^/]+$" } } ], @@ -40,7 +31,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/GenerateContentRequest" } } } @@ -51,25 +42,32 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/GenerateContentResponse" + } + }, + "text/event-stream": { + "schema": { + "$ref": "#/components/schemas/GenerateContentResponse" } } } } } - }, - "delete": { - "description": "Deletes CachedContent resource.", - "operationId": "cachedContents.delete", + } + }, + "/tunedModels/{tunedModelsId}": { + "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/[^/]+$" } } ], @@ -79,62 +77,71 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/TunedModel" } } } } } }, - "get": { - "description": "Reads CachedContent resource.", - "operationId": "cachedContents.get", + "patch": { + "description": "Updates a tuned model.", + "operationId": "tunedModels.patch", "parameters": [ { - "name": "cachedContentsId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The resource name referring to the content cache entry. 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": "Optional. The list of fields to update.", + "schema": { + "type": "string", + "format": "google-fieldmask" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/TunedModel" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/TunedModel" } } } } } - } - }, - "/cachedContents": { - "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/[^/]+$" } } ], @@ -144,21 +151,35 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListCachedContentsResponse" + "$ref": "#/components/schemas/Empty" } } } } } - }, + } + }, + "/tunedModels/{tunedModelsId}:generateContent": { "post": { - "description": "Creates CachedContent resource.", - "operationId": "cachedContents.create", + "description": "Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details.", + "operationId": "tunedModels.generateContent", + "parameters": [ + { + "name": "tunedModelsId", + "in": "path", + "required": true, + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "schema": { + "type": "string", + "pattern": "^tunedModels/[^/]+$" + } + } + ], "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/GenerateContentRequest" } } } @@ -169,7 +190,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/GenerateContentResponse" } } } @@ -177,36 +198,38 @@ } } }, - "/generatedFiles": { - "get": { - "description": "Lists the generated files owned by the requesting project.", - "operationId": "generatedFiles.list", + "/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": "pageSize", - "in": "query", - "description": "Optional. Maximum number of `GeneratedFile`s to return per page. If unspecified, defaults to 10. Maximum `page_size` is 50.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "Optional. A page token from a previous `ListGeneratedFiles` call.", + "name": "tunedModelsId", + "in": "path", + "required": true, + "description": "Required. The resource name of the tuned model to transfer ownership. Format: `tunedModels/my-model-id`", "schema": { - "type": "string" + "type": "string", + "pattern": "^tunedModels/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/TransferOwnershipRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListGeneratedFilesResponse" + "$ref": "#/components/schemas/TransferOwnershipResponse" } } } @@ -214,53 +237,27 @@ } } }, - "/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", + "/tunedModels/{tunedModelsId}:batchGenerateContent": { + "post": { + "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", + "operationId": "tunedModels.batchGenerateContent", "parameters": [ { - "name": "operationsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "generatedFilesId", + "name": "tunedModelsId", "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": "^generatedFiles/[^/]+/operations/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Operation" - } - } - } - } - } - } - }, - "/files": { - "post": { - "description": "Creates a `File`.", - "operationId": "media.upload", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CreateFileRequest" + "$ref": "#/components/schemas/BatchGenerateContentRequest" } } } @@ -271,21 +268,31 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CreateFileResponse" + "$ref": "#/components/schemas/Operation" } } } } } - }, + } + }, + "/tunedModels": { "get": { - "description": "Lists the metadata for `File`s owned by the requesting project.", - "operationId": "files.list", + "description": "Lists created tuned models.", + "operationId": "tunedModels.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. Maximum number of `File`s to return per page. If unspecified, defaults to 10. Maximum `page_size` is 100.", + "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" @@ -294,7 +301,7 @@ { "name": "pageToken", "in": "query", - "description": "Optional. A page token from a previous `ListFiles` call.", + "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" } @@ -306,27 +313,23 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListFilesResponse" + "$ref": "#/components/schemas/ListTunedModelsResponse" } } } } } - } - }, - "/fileSearchStores/{fileSearchStoresId}:uploadToFileSearchStore": { + }, "post": { - "description": "Uploads data to a FileSearchStore, preprocesses and chunks before storing it in a FileSearchStore Document.", - "operationId": "media.uploadToFileSearchStore", + "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": "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`", + "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": "^fileSearchStores/[^/]+$" + "type": "string" } } ], @@ -334,69 +337,11 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/UploadToFileSearchStoreRequest" + "$ref": "#/components/schemas/TunedModel" } } } }, - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/CustomLongRunningOperation" - } - } - } - } - } - } - }, - "/batches/{batchesId}": { - "delete": { - "description": "Deletes a long-running operation. This method indicates that the client is no longer interested in the operation result. It does not cancel the operation. If the server doesn't support this method, it returns `google.rpc.Code.UNIMPLEMENTED`.", - "operationId": "batches.delete", - "parameters": [ - { - "name": "batchesId", - "in": "path", - "required": true, - "description": "The name of the operation resource to be deleted.", - "schema": { - "type": "string", - "pattern": "^batches/[^/]+$" - } - } - ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/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": "batchesId", - "in": "path", - "required": true, - "description": "The name of the operation resource.", - "schema": { - "type": "string", - "pattern": "^batches/[^/]+$" - } - } - ], "responses": { "200": { "description": "Successful response", @@ -411,28 +356,19 @@ } } }, - "/batches/{batchesId}:updateGenerateContentBatch": { - "patch": { - "description": "Updates a batch of GenerateContent requests for batch processing.", - "operationId": "batches.updateGenerateContentBatch", + "/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": "batchesId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", - "schema": { - "type": "string", - "pattern": "^batches/[^/]+$" - } - }, - { - "name": "updateMask", - "in": "query", - "description": "Optional. The list of fields to update.", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "format": "google-fieldmask" + "pattern": "^tunedModels/[^/]+$" } } ], @@ -440,7 +376,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentBatch" + "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" } } } @@ -451,7 +387,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentBatch" + "$ref": "#/components/schemas/Operation" } } } @@ -459,10 +395,10 @@ } } }, - "/batches": { + "/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": "batches.list", + "operationId": "tunedModels.operations.list", "parameters": [ { "name": "filter", @@ -472,6 +408,16 @@ "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", @@ -512,19 +458,27 @@ } } }, - "/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", + "/tunedModels/{tunedModelsId}/operations/{operationsId}": { + "get": { + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "tunedModels.operations.get", "parameters": [ { - "name": "batchesId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "The name of the operation resource to be cancelled.", + "schema": { + "type": "string" + } + }, + { + "name": "operationsId", + "in": "path", + "required": true, + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^batches/[^/]+$" + "pattern": "^tunedModels/[^/]+/operations/[^/]+$" } } ], @@ -534,7 +488,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/Operation" } } } @@ -542,25 +496,69 @@ } } }, - "/batches/{batchesId}:updateEmbedContentBatch": { + "/tunedModels/{tunedModelsId}/permissions/{permissionsId}": { + "get": { + "description": "Gets information about a specific Permission.", + "operationId": "tunedModels.permissions.get", + "parameters": [ + { + "name": "tunedModelsId", + "in": "path", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "permissionsId", + "in": "path", + "required": true, + "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", + "schema": { + "type": "string", + "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" + } + } + ], + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Permission" + } + } + } + } + } + }, "patch": { - "description": "Updates a batch of EmbedContent requests for batch processing.", - "operationId": "batches.updateEmbedContentBatch", + "description": "Updates the permission.", + "operationId": "tunedModels.permissions.patch", "parameters": [ { - "name": "batchesId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", + "schema": { + "type": "string" + } + }, + { + "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": "^batches/[^/]+$" + "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" } }, { "name": "updateMask", "in": "query", - "description": "Optional. The list of fields to update.", + "description": "Required. The list of fields to update. Accepted ones: - role (`Permission.role` field)", "schema": { "type": "string", "format": "google-fieldmask" @@ -571,7 +569,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/EmbedContentBatch" + "$ref": "#/components/schemas/Permission" } } } @@ -582,35 +580,33 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/EmbedContentBatch" + "$ref": "#/components/schemas/Permission" } } } } } - } - }, - "/corpora/{corporaId}": { + }, "delete": { - "description": "Deletes a `Corpus`.", - "operationId": "corpora.delete", + "description": "Deletes the permission.", + "operationId": "tunedModels.permissions.delete", "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": "tunedModelsId", + "in": "path", + "required": true, "schema": { - "type": "boolean" + "type": "string" } }, { - "name": "corporaId", + "name": "permissionsId", "in": "path", "required": true, - "description": "Required. The resource name of the `Corpus`. Example: `corpora/my-corpus-123`", + "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", "schema": { "type": "string", - "pattern": "^corpora/[^/]+$" + "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" } } ], @@ -626,19 +622,38 @@ } } } - }, + } + }, + "/tunedModels/{tunedModelsId}/permissions": { "get": { - "description": "Gets information about a specific `Corpus`.", - "operationId": "corpora.get", + "description": "Lists permissions for the specific resource.", + "operationId": "tunedModels.permissions.list", "parameters": [ { - "name": "corporaId", + "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", "in": "path", "required": true, - "description": "Required. The name of the `Corpus`. Example: `corpora/my-corpus-123`", + "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", "schema": { "type": "string", - "pattern": "^corpora/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], @@ -648,23 +663,33 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Corpus" + "$ref": "#/components/schemas/ListPermissionsResponse" } } } } } - } - }, - "/corpora": { + }, "post": { - "description": "Creates an empty `Corpus`.", - "operationId": "corpora.create", - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Corpus" + "description": "Create a permission to a specific resource.", + "operationId": "tunedModels.permissions.create", + "parameters": [ + { + "name": "tunedModelsId", + "in": "path", + "required": true, + "description": "Required. The parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", + "schema": { + "type": "string", + "pattern": "^tunedModels/[^/]+$" + } + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Permission" } } } @@ -675,32 +700,35 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Corpus" + "$ref": "#/components/schemas/Permission" } } } } } - }, - "get": { - "description": "Lists all `Corpora` owned by the user.", - "operationId": "corpora.list", + } + }, + "/fileSearchStores/{fileSearchStoresId}": { + "delete": { + "description": "Deletes a `FileSearchStore`.", + "operationId": "fileSearchStores.delete", "parameters": [ { - "name": "pageSize", + "name": "force", "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. 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": "integer", - "format": "int32" + "type": "boolean" } }, { - "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.", + "name": "fileSearchStoresId", + "in": "path", + "required": true, + "description": "Required. The resource name of the `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", "schema": { - "type": "string" + "type": "string", + "pattern": "^fileSearchStores/[^/]+$" } } ], @@ -710,35 +738,25 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListCorporaResponse" + "$ref": "#/components/schemas/Empty" } } } } } - } - }, - "/corpora/{corporaId}/operations/{operationsId}": { + }, "get": { - "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "corpora.operations.get", + "description": "Gets information about a specific `FileSearchStore`.", + "operationId": "fileSearchStores.get", "parameters": [ { - "name": "operationsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "corporaId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "The name of the operation resource.", + "description": "Required. The name of the `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "pattern": "^corpora/[^/]+/operations/[^/]+$" + "pattern": "^fileSearchStores/[^/]+$" } } ], @@ -748,7 +766,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/FileSearchStore" } } } @@ -756,27 +774,26 @@ } } }, - "/corpora/{corporaId}/permissions/{permissionsId}": { - "delete": { - "description": "Deletes the permission.", - "operationId": "corpora.permissions.delete", + "/fileSearchStores": { + "get": { + "description": "Lists all `FileSearchStores` owned by the user.", + "operationId": "fileSearchStores.list", "parameters": [ { - "name": "permissionsId", - "in": "path", - "required": true, + "name": "pageSize", + "in": "query", + "description": "Optional. The maximum number of `FileSearchStores` to return (per page). The service may return fewer `FileSearchStores`. If unspecified, at most 10 `FileSearchStores` will be returned. The maximum size limit is 20 `FileSearchStores` per page.", "schema": { - "type": "string" + "type": "integer", + "format": "int32" } }, { - "name": "corporaId", - "in": "path", - "required": true, - "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", + "name": "pageToken", + "in": "query", + "description": "Optional. A page token, 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", - "pattern": "^corpora/[^/]+/permissions/[^/]+$" + "type": "string" } } ], @@ -786,42 +803,52 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/ListFileSearchStoresResponse" } } } } } }, - "patch": { - "description": "Updates the permission.", - "operationId": "corpora.permissions.patch", - "parameters": [ - { - "name": "permissionsId", - "in": "path", - "required": true, - "schema": { - "type": "string" + "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", + "parameters": [ { - "name": "corporaId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.", - "schema": { - "type": "string", - "pattern": "^corpora/[^/]+/permissions/[^/]+$" - } - }, - { - "name": "updateMask", - "in": "query", - "description": "Required. The list of fields to update. Accepted ones: - role (`Permission.role` field)", + "description": "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/[^/]+$" } } ], @@ -829,7 +856,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/ImportFileRequest" } } } @@ -840,19 +867,21 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/Operation" } } } } } - }, + } + }, + "/fileSearchStores/{fileSearchStoresId}/upload/operations/{operationsId}": { "get": { - "description": "Gets information about a specific Permission.", - "operationId": "corpora.permissions.get", + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "fileSearchStores.upload.operations.get", "parameters": [ { - "name": "permissionsId", + "name": "operationsId", "in": "path", "required": true, "schema": { @@ -860,13 +889,13 @@ } }, { - "name": "corporaId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^corpora/[^/]+/permissions/[^/]+$" + "pattern": "^fileSearchStores/[^/]+/upload/operations/[^/]+$" } } ], @@ -876,7 +905,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/Operation" } } } @@ -884,73 +913,71 @@ } } }, - "/corpora/{corporaId}/permissions": { - "post": { - "description": "Create a permission to a specific resource.", - "operationId": "corpora.permissions.create", + "/fileSearchStores/{fileSearchStoresId}/documents/{documentsId}": { + "get": { + "description": "Gets information about a specific `Document`.", + "operationId": "fileSearchStores.documents.get", "parameters": [ { - "name": "corporaId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Required. The parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", + "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": "^corpora/[^/]+$" + "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Permission" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/Document" } } } } } }, - "get": { - "description": "Lists permissions for the specific resource.", - "operationId": "corpora.permissions.list", + "delete": { + "description": "Deletes a `Document`.", + "operationId": "fileSearchStores.documents.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.", + "name": "fileSearchStoresId", + "in": "path", + "required": true, "schema": { - "type": "integer", - "format": "int32" + "type": "string" } }, { - "name": "pageToken", + "name": "force", "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. 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": "string" + "type": "boolean" } }, { - "name": "corporaId", + "name": "documentsId", "in": "path", "required": true, - "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", + "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": "^corpora/[^/]+$" + "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" } } ], @@ -960,7 +987,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListPermissionsResponse" + "$ref": "#/components/schemas/Empty" } } } @@ -968,15 +995,15 @@ } } }, - "/models": { + "/fileSearchStores/{fileSearchStoresId}/documents": { "get": { - "description": "Lists the [`Model`s](https://ai.google.dev/gemini-api/docs/models/gemini) available through the Gemini API.", - "operationId": "models.list", + "description": "Lists all `Document`s in a `Corpus`.", + "operationId": "fileSearchStores.documents.list", "parameters": [ { "name": "pageSize", "in": "query", - "description": "The maximum number of `Models` to return (per page). If unspecified, 50 models will be returned per page. This method returns at most 1000 models per page, even if you pass a larger page_size.", + "description": "Optional. The maximum number of `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" @@ -985,19 +1012,29 @@ { "name": "pageToken", "in": "query", - "description": "A page token, received from a previous `ListModels` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListModels` must match the call that provided the page token.", + "description": "Optional. A page token, received from a previous `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" } - } - ], - "responses": { + }, + { + "name": "fileSearchStoresId", + "in": "path", + "required": true, + "description": "Required. The name of the `FileSearchStore` containing `Document`s. Example: `fileSearchStores/my-file-search-store-123`", + "schema": { + "type": "string", + "pattern": "^fileSearchStores/[^/]+$" + } + } + ], + "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListModelsResponse" + "$ref": "#/components/schemas/ListDocumentsResponse" } } } @@ -1005,38 +1042,37 @@ } } }, - "/models/{modelsId}:generateContent": { - "post": { - "description": "Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details.", - "operationId": "models.generateContent", + "/fileSearchStores/{fileSearchStoresId}/operations/{operationsId}": { + "get": { + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "fileSearchStores.operations.get", "parameters": [ { - "name": "modelsId", + "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" + } + }, + { + "name": "fileSearchStoresId", + "in": "path", + "required": true, + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^fileSearchStores/[^/]+/operations/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/Operation" } } } @@ -1044,27 +1080,15 @@ } } }, - "/models/{modelsId}:countTokens": { + "/corpora": { "post": { - "description": "Runs a model's tokenizer on input `Content` and returns the token count. Refer to the [tokens guide](https://ai.google.dev/gemini-api/docs/tokens) to learn more about tokens.", - "operationId": "models.countTokens", - "parameters": [ - { - "name": "modelsId", - "in": "path", - "required": true, - "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", - "schema": { - "type": "string", - "pattern": "^models/[^/]+$" - } - } - ], + "description": "Creates an empty `Corpus`.", + "operationId": "corpora.create", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CountTokensRequest" + "$ref": "#/components/schemas/Corpus" } } } @@ -1075,46 +1099,42 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CountTokensResponse" + "$ref": "#/components/schemas/Corpus" } } } } } - } - }, - "/models/{modelsId}:batchGenerateContent": { - "post": { - "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", - "operationId": "models.batchGenerateContent", + }, + "get": { + "description": "Lists all `Corpora` owned by the user.", + "operationId": "corpora.list", "parameters": [ { - "name": "modelsId", - "in": "path", - "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "name": "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.", "schema": { - "type": "string", - "pattern": "^models/[^/]+$" + "type": "integer", + "format": "int32" } - } - ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/BatchGenerateContentRequest" - } + }, + { + "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.", + "schema": { + "type": "string" } } - }, + ], "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/ListCorporaResponse" } } } @@ -1122,82 +1142,65 @@ } } }, - "/models/{modelsId}:streamGenerateContent": { - "post": { - "description": "Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`.", - "operationId": "models.streamGenerateContent", + "/corpora/{corporaId}": { + "get": { + "description": "Gets information about a specific `Corpus`.", + "operationId": "corpora.get", "parameters": [ { - "name": "modelsId", + "name": "corporaId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "Required. The name of the `Corpus`. Example: `corpora/my-corpus-123`", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^corpora/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/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/Corpus" } } } } } - } - }, - "/models/{modelsId}:embedContent": { - "post": { - "description": "Generates a text embedding vector from the input `Content` using the specified [Gemini Embedding model](https://ai.google.dev/gemini-api/docs/models/gemini#text-embedding).", - "operationId": "models.embedContent", + }, + "delete": { + "description": "Deletes a `Corpus`.", + "operationId": "corpora.delete", "parameters": [ { - "name": "modelsId", + "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 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 resource name of the `Corpus`. Example: `corpora/my-corpus-123`", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^corpora/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/EmbedContentRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/EmbedContentResponse" + "$ref": "#/components/schemas/Empty" } } } @@ -1205,38 +1208,37 @@ } } }, - "/models/{modelsId}:batchEmbedContents": { - "post": { - "description": "Generates multiple embedding vectors from the input `Content` which consists of a batch of strings represented as `EmbedContentRequest` objects.", - "operationId": "models.batchEmbedContents", + "/corpora/{corporaId}/operations/{operationsId}": { + "get": { + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "corpora.operations.get", "parameters": [ { - "name": "modelsId", + "name": "operationsId", "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": "corporaId", + "in": "path", + "required": true, + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^corpora/[^/]+/operations/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/BatchEmbedContentsRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/BatchEmbedContentsResponse" + "$ref": "#/components/schemas/Operation" } } } @@ -1244,19 +1246,19 @@ } } }, - "/models/{modelsId}:asyncBatchEmbedContent": { + "/corpora/{corporaId}/permissions": { "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": "Create a permission to a specific resource.", + "operationId": "corpora.permissions.create", "parameters": [ { - "name": "modelsId", + "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": "^models/[^/]+$" + "pattern": "^corpora/[^/]+$" } } ], @@ -1264,7 +1266,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" + "$ref": "#/components/schemas/Permission" } } } @@ -1275,27 +1277,42 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Permission" } } } } } - } - }, - "/models/{modelsId}": { + }, "get": { - "description": "Gets information about a specific `Model` such as its version number, token limits, [parameters](https://ai.google.dev/gemini-api/docs/models/generative-models#model-parameters) and other metadata. Refer to the [Gemini models guide](https://ai.google.dev/gemini-api/docs/models/gemini) for detailed model information.", - "operationId": "models.get", + "description": "Lists permissions for the specific resource.", + "operationId": "corpora.permissions.list", "parameters": [ { - "name": "modelsId", + "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 resource name of the model. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", + "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^corpora/[^/]+$" } } ], @@ -1305,7 +1322,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Model" + "$ref": "#/components/schemas/ListPermissionsResponse" } } } @@ -1313,13 +1330,13 @@ } } }, - "/models/{modelsId}/operations/{operationsId}": { - "get": { - "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "models.operations.get", + "/corpora/{corporaId}/permissions/{permissionsId}": { + "delete": { + "description": "Deletes the permission.", + "operationId": "corpora.permissions.delete", "parameters": [ { - "name": "operationsId", + "name": "permissionsId", "in": "path", "required": true, "schema": { @@ -1327,13 +1344,13 @@ } }, { - "name": "modelsId", + "name": "corporaId", "in": "path", "required": true, - "description": "The name of the operation resource.", + "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", "schema": { "type": "string", - "pattern": "^models/[^/]+/operations/[^/]+$" + "pattern": "^corpora/[^/]+/permissions/[^/]+$" } } ], @@ -1343,60 +1360,33 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Empty" } } } } } - } - }, - "/models/{modelsId}/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": "models.operations.list", + "description": "Gets information about a specific Permission.", + "operationId": "corpora.permissions.get", "parameters": [ { - "name": "filter", - "in": "query", - "description": "The standard list filter.", + "name": "permissionsId", + "in": "path", + "required": true, "schema": { "type": "string" } }, { - "name": "modelsId", + "name": "corporaId", "in": "path", "required": true, - "description": "The name of the operation's parent resource.", + "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", "schema": { "type": "string", - "pattern": "^models/[^/]+$" - } - }, - { - "name": "pageSize", - "in": "query", - "description": "The standard list page size.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "The standard list page token.", - "schema": { - "type": "string" - } - }, - { - "name": "returnPartialSuccess", - "in": "query", - "description": "When set to `true`, operations that are reachable are returned as normal, and those that are unreachable are returned in the ListOperationsResponse.unreachable field. This can only be `true` when reading across collections. For example, when `parent` is set to `\"projects/example/locations/-\"`. This field is not supported by default and will result in an `UNIMPLEMENTED` error if set unless explicitly documented otherwise in service or product specific documentation.", - "schema": { - "type": "boolean" + "pattern": "^corpora/[^/]+/permissions/[^/]+$" } } ], @@ -1406,27 +1396,42 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListOperationsResponse" + "$ref": "#/components/schemas/Permission" } } } } } - } - }, - "/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", + }, + "patch": { + "description": "Updates the permission.", + "operationId": "corpora.permissions.patch", "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": "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" } } ], @@ -1434,7 +1439,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" + "$ref": "#/components/schemas/Permission" } } } @@ -1445,7 +1450,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Permission" } } } @@ -1453,19 +1458,26 @@ } } }, - "/tunedModels/{tunedModelsId}": { + "/cachedContents": { "get": { - "description": "Gets information about a specific TunedModel.", - "operationId": "tunedModels.get", + "description": "Lists CachedContents.", + "operationId": "cachedContents.list", "parameters": [ { - "name": "tunedModelsId", - "in": "path", - "required": true, - "description": "Required. The resource name of the model. Format: `tunedModels/my-model-id`", + "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": "string", - "pattern": "^tunedModels/[^/]+$" + "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.", + "schema": { + "type": "string" } } ], @@ -1475,25 +1487,52 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/ListCachedContentsResponse" } } } } } }, - "delete": { - "description": "Deletes a tuned model.", - "operationId": "tunedModels.delete", + "post": { + "description": "Creates CachedContent resource.", + "operationId": "cachedContents.create", + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/CachedContent" + } + } + } + }, + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/CachedContent" + } + } + } + } + } + } + }, + "/cachedContents/{cachedContentsId}": { + "get": { + "description": "Reads CachedContent resource.", + "operationId": "cachedContents.get", "parameters": [ { - "name": "tunedModelsId", + "name": "cachedContentsId", "in": "path", "required": true, - "description": "Required. The resource name of the model. Format: `tunedModels/my-model-id`", + "description": "Required. The resource name referring to the content cache entry. Format: `cachedContents/{id}`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^cachedContents/[^/]+$" } } ], @@ -1503,7 +1542,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/CachedContent" } } } @@ -1511,23 +1550,23 @@ } }, "patch": { - "description": "Updates a tuned model.", - "operationId": "tunedModels.patch", + "description": "Updates CachedContent resource (only expiration is updatable).", + "operationId": "cachedContents.patch", "parameters": [ { - "name": "tunedModelsId", + "name": "cachedContentsId", "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`", + "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^cachedContents/[^/]+$" } }, { "name": "updateMask", "in": "query", - "description": "Optional. The list of fields to update.", + "description": "The list of fields to update.", "schema": { "type": "string", "format": "google-fieldmask" @@ -1538,7 +1577,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/CachedContent" } } } @@ -1549,46 +1588,35 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/CachedContent" } } } } } - } - }, - "/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", + }, + "delete": { + "description": "Deletes CachedContent resource.", + "operationId": "cachedContents.delete", "parameters": [ { - "name": "tunedModelsId", + "name": "cachedContentsId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "Required. The resource name referring to the content cache entry Format: `cachedContents/{id}`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^cachedContents/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/Empty" } } } @@ -1596,69 +1624,64 @@ } } }, - "/tunedModels": { - "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", + "/generatedFiles": { + "get": { + "description": "Lists the generated files owned by the requesting project.", + "operationId": "generatedFiles.list", "parameters": [ { - "name": "tunedModelId", + "name": "pageSize", "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])?`.", + "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" + } + }, + { + "name": "pageToken", + "in": "query", + "description": "Optional. A page token from a previous `ListGeneratedFiles` call.", "schema": { "type": "string" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/TunedModel" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/ListGeneratedFilesResponse" } } } } } - }, + } + }, + "/generatedFiles/{generatedFilesId}/operations/{operationsId}": { "get": { - "description": "Lists created tuned models.", - "operationId": "tunedModels.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": "generatedFiles.operations.get", "parameters": [ { - "name": "filter", - "in": "query", - "description": "Optional. A filter is a full text search over the tuned model's description and display name. By default, results will not include tuned models shared with everyone. Additional operators: - owner:me - writers:me - readers:me - readers:everyone Examples: \"owner:me\" returns all tuned models to which caller has owner role \"readers:me\" returns all tuned models to which caller has reader role \"readers:everyone\" returns all tuned models that are shared with everyone", + "name": "operationsId", + "in": "path", + "required": true, "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.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "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.", + "name": "generatedFilesId", + "in": "path", + "required": true, + "description": "The name of the operation resource.", "schema": { - "type": "string" + "type": "string", + "pattern": "^generatedFiles/[^/]+/operations/[^/]+$" } } ], @@ -1668,7 +1691,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListTunedModelsResponse" + "$ref": "#/components/schemas/Operation" } } } @@ -1676,19 +1699,19 @@ } } }, - "/tunedModels/{tunedModelsId}:batchGenerateContent": { + "/dynamic/{dynamicId}:generateContent": { "post": { - "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", - "operationId": "tunedModels.batchGenerateContent", + "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": "tunedModelsId", + "name": "dynamicId", "in": "path", "required": true, "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^dynamic/[^/]+$" } } ], @@ -1696,7 +1719,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/BatchGenerateContentRequest" + "$ref": "#/components/schemas/GenerateContentRequest" } } } @@ -1707,7 +1730,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/GenerateContentResponse" } } } @@ -1715,19 +1738,19 @@ } } }, - "/tunedModels/{tunedModelsId}:streamGenerateContent": { + "/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": "tunedModels.streamGenerateContent", + "operationId": "dynamic.streamGenerateContent", "parameters": [ { - "name": "tunedModelsId", + "name": "dynamicId", "in": "path", "required": true, "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^dynamic/[^/]+$" } } ], @@ -1759,27 +1782,73 @@ } } }, - "/tunedModels/{tunedModelsId}:transferOwnership": { - "post": { - "description": "Transfers ownership of the tuned model. This is the only way to change ownership of the tuned model. The current owner will be downgraded to writer role.", - "operationId": "tunedModels.transferOwnership", + "/files/{filesId}": { + "delete": { + "description": "Deletes the `File`.", + "operationId": "files.delete", "parameters": [ { - "name": "tunedModelsId", + "name": "filesId", "in": "path", "required": true, - "description": "Required. The resource name of the tuned model to transfer ownership. Format: `tunedModels/my-model-id`", + "description": "Required. The name of the `File` to delete. Example: `files/abc-123`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^files/[^/]+$" + } + } + ], + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Empty" + } + } + } + } + } + }, + "get": { + "description": "Gets the metadata for the given `File`.", + "operationId": "files.get", + "parameters": [ + { + "name": "filesId", + "in": "path", + "required": true, + "description": "Required. The name of the `File` to get. Example: `files/abc-123`", + "schema": { + "type": "string", + "pattern": "^files/[^/]+$" } } ], + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/File" + } + } + } + } + } + } + }, + "/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/TransferOwnershipRequest" + "$ref": "#/components/schemas/RegisterFilesRequest" } } } @@ -1790,7 +1859,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TransferOwnershipResponse" + "$ref": "#/components/schemas/RegisterFilesResponse" } } } @@ -1798,33 +1867,15 @@ } } }, - "/tunedModels/{tunedModelsId}/operations": { + "/files": { "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 the metadata for `File`s owned by the requesting project.", + "operationId": "files.list", "parameters": [ - { - "name": "filter", - "in": "query", - "description": "The standard list filter.", - "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. Maximum number of `File`s to return per page. If unspecified, defaults to 10. Maximum `page_size` is 100.", "schema": { "type": "integer", "format": "int32" @@ -1833,18 +1884,10 @@ { "name": "pageToken", "in": "query", - "description": "The standard list page token.", + "description": "Optional. A page token from a previous `ListFiles` call.", "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": { @@ -1853,45 +1896,32 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListOperationsResponse" + "$ref": "#/components/schemas/ListFilesResponse" } } } } } - } - }, - "/tunedModels/{tunedModelsId}/operations/{operationsId}": { - "get": { - "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "tunedModels.operations.get", - "parameters": [ - { - "name": "tunedModelsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "operationsId", - "in": "path", - "required": true, - "description": "The name of the operation resource.", - "schema": { - "type": "string", - "pattern": "^tunedModels/[^/]+/operations/[^/]+$" + }, + "post": { + "description": "Creates a `File`.", + "operationId": "media.upload", + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/CreateFileRequest" + } } } - ], + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/CreateFileResponse" } } } @@ -1899,19 +1929,19 @@ } } }, - "/tunedModels/{tunedModelsId}/permissions": { + "/models/{modelsId}:streamGenerateContent": { "post": { - "description": "Create a permission to a specific resource.", - "operationId": "tunedModels.permissions.create", + "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": "tunedModelsId", + "name": "modelsId", "in": "path", "required": true, - "description": "Required. The parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^models/[^/]+$" } } ], @@ -1919,7 +1949,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/GenerateContentRequest" } } } @@ -1930,42 +1960,32 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/GenerateContentResponse" + } + }, + "text/event-stream": { + "schema": { + "$ref": "#/components/schemas/GenerateContentResponse" } } } } } - }, + } + }, + "/models/{modelsId}": { "get": { - "description": "Lists permissions for the specific resource.", - "operationId": "tunedModels.permissions.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 `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": "modelsId", "in": "path", "required": true, - "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", + "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": "^tunedModels/[^/]+$" + "pattern": "^models/[^/]+$" } } ], @@ -1975,7 +1995,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListPermissionsResponse" + "$ref": "#/components/schemas/Model" } } } @@ -1983,72 +2003,58 @@ } } }, - "/tunedModels/{tunedModelsId}/permissions/{permissionsId}": { - "get": { - "description": "Gets information about a specific Permission.", - "operationId": "tunedModels.permissions.get", + "/models/{modelsId}:generateContent": { + "post": { + "description": "Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details.", + "operationId": "models.generateContent", "parameters": [ { - "name": "tunedModelsId", + "name": "modelsId", "in": "path", "required": true, + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { - "type": "string" - } - }, - { - "name": "permissionsId", - "in": "path", - "required": true, - "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", - "schema": { - "type": "string", - "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" + "type": "string", + "pattern": "^models/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/GenerateContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/GenerateContentResponse" } } } } } - }, - "patch": { - "description": "Updates the permission.", - "operationId": "tunedModels.permissions.patch", + } + }, + "/models/{modelsId}:batchGenerateContent": { + "post": { + "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", + "operationId": "models.batchGenerateContent", "parameters": [ { - "name": "tunedModelsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "permissionsId", + "name": "modelsId", "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/[^/]+$" - } - }, - { - "name": "updateMask", - "in": "query", - "description": "Required. The list of fields to update. Accepted ones: - role (`Permission.role` field)", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "format": "google-fieldmask" + "pattern": "^models/[^/]+$" } } ], @@ -2056,7 +2062,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/BatchGenerateContentRequest" } } } @@ -2067,33 +2073,34 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/Operation" } } } } } - }, - "delete": { - "description": "Deletes the permission.", - "operationId": "tunedModels.permissions.delete", + } + }, + "/models": { + "get": { + "description": "Lists the [`Model`s](https://ai.google.dev/gemini-api/docs/models/gemini) available through the Gemini API.", + "operationId": "models.list", "parameters": [ { - "name": "tunedModelsId", - "in": "path", - "required": true, + "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" + "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": "A page token, received from a previous `ListModels` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListModels` must match the call that provided the page token.", "schema": { - "type": "string", - "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" + "type": "string" } } ], @@ -2103,7 +2110,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/ListModelsResponse" } } } @@ -2111,19 +2118,19 @@ } } }, - "/dynamic/{dynamicId}:generateContent": { + "/models/{modelsId}:countTokens": { "post": { - "description": "Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details.", - "operationId": "dynamic.generateContent", + "description": "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": "dynamicId", + "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": "^dynamic/[^/]+$" + "pattern": "^models/[^/]+$" } } ], @@ -2131,7 +2138,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "$ref": "#/components/schemas/CountTokensRequest" } } } @@ -2142,7 +2149,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/CountTokensResponse" } } } @@ -2150,19 +2157,19 @@ } } }, - "/dynamic/{dynamicId}:streamGenerateContent": { + "/models/{modelsId}:batchEmbedContents": { "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", + "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": "dynamicId", + "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": "^dynamic/[^/]+$" + "pattern": "^models/[^/]+$" } } ], @@ -2170,7 +2177,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "$ref": "#/components/schemas/BatchEmbedContentsRequest" } } } @@ -2181,12 +2188,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" - } - }, - "text/event-stream": { - "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/BatchEmbedContentsResponse" } } } @@ -2194,73 +2196,27 @@ } } }, - "/files/{filesId}": { - "delete": { - "description": "Deletes the `File`.", - "operationId": "files.delete", - "parameters": [ - { - "name": "filesId", - "in": "path", - "required": true, - "description": "Required. The name of the `File` to delete. Example: `files/abc-123`", - "schema": { - "type": "string", - "pattern": "^files/[^/]+$" - } - } - ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Empty" - } - } - } - } - } - }, - "get": { - "description": "Gets the metadata for the given `File`.", - "operationId": "files.get", + "/models/{modelsId}:embedContent": { + "post": { + "description": "Generates a text embedding vector from the input `Content` using the specified [Gemini Embedding model](https://ai.google.dev/gemini-api/docs/models/gemini#text-embedding).", + "operationId": "models.embedContent", "parameters": [ { - "name": "filesId", + "name": "modelsId", "in": "path", "required": true, - "description": "Required. The name of the `File` to get. Example: `files/abc-123`", + "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": "^files/[^/]+$" + "pattern": "^models/[^/]+$" } } ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/File" - } - } - } - } - } - } - }, - "/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/EmbedContentRequest" } } } @@ -2271,7 +2227,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/RegisterFilesResponse" + "$ref": "#/components/schemas/EmbedContentResponse" } } } @@ -2279,19 +2235,19 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}:importFile": { + "/models/{modelsId}:asyncBatchEmbedContent": { "post": { - "description": "Imports a `File` from File Service to a `FileSearchStore`.", - "operationId": "fileSearchStores.importFile", + "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": "fileSearchStoresId", + "name": "modelsId", "in": "path", "required": true, - "description": "Required. Immutable. The name of the `FileSearchStore` to import the file into. Example: `fileSearchStores/my-file-search-store-123`", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+$" + "pattern": "^models/[^/]+$" } } ], @@ -2299,7 +2255,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ImportFileRequest" + "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" } } } @@ -2318,27 +2274,52 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}": { - "delete": { - "description": "Deletes a `FileSearchStore`.", - "operationId": "fileSearchStores.delete", + "/models/{modelsId}/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": "models.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": "modelsId", "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": "^models/[^/]+$" + } + }, + { + "name": "pageSize", + "in": "query", + "description": "The standard list page size.", + "schema": { + "type": "integer", + "format": "int32" + } + }, + { + "name": "pageToken", + "in": "query", + "description": "The standard list page token.", + "schema": { + "type": "string" + } + }, + { + "name": "returnPartialSuccess", + "in": "query", + "description": "When set to `true`, operations that are reachable are returned as normal, and those that are unreachable are returned in the ListOperationsResponse.unreachable field. This can only be `true` when reading across collections. For example, when `parent` is set to `\"projects/example/locations/-\"`. This field is not supported by default and will result in an `UNIMPLEMENTED` error if set unless explicitly documented otherwise in service or product specific documentation.", + "schema": { + "type": "boolean" } } ], @@ -2348,25 +2329,35 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/ListOperationsResponse" } } } } } - }, + } + }, + "/models/{modelsId}/operations/{operationsId}": { "get": { - "description": "Gets information about a specific `FileSearchStore`.", - "operationId": "fileSearchStores.get", - "parameters": [ + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "models.operations.get", + "parameters": [ { - "name": "fileSearchStoresId", + "name": "operationsId", "in": "path", "required": true, - "description": "Required. The name of the `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", + "schema": { + "type": "string" + } + }, + { + "name": "modelsId", + "in": "path", + "required": true, + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+$" + "pattern": "^models/[^/]+/operations/[^/]+$" } } ], @@ -2376,7 +2367,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/FileSearchStore" + "$ref": "#/components/schemas/Operation" } } } @@ -2384,51 +2375,19 @@ } } }, - "/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 all `FileSearchStores` owned by the user.", - "operationId": "fileSearchStores.list", + "/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": "pageSize", - "in": "query", - "description": "Optional. The maximum number of `FileSearchStores` to return (per page). The service may return fewer `FileSearchStores`. If unspecified, at most 10 `FileSearchStores` will be returned. The maximum size limit is 20 `FileSearchStores` per page.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "Optional. A page token, received from a previous `ListFileSearchStores` call. Provide the `next_page_token` returned in the response as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListFileSearchStores` must match the call that provided the page token.", + "name": "batchesId", + "in": "path", + "required": true, + "description": "The name of the operation resource to be deleted.", "schema": { - "type": "string" + "type": "string", + "pattern": "^batches/[^/]+$" } } ], @@ -2438,35 +2397,25 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListFileSearchStoresResponse" + "$ref": "#/components/schemas/Empty" } } } } } - } - }, - "/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", + "operationId": "batches.get", "parameters": [ { - "name": "operationsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "fileSearchStoresId", + "name": "batchesId", "in": "path", "required": true, "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/operations/[^/]+$" + "pattern": "^batches/[^/]+$" } } ], @@ -2484,15 +2433,23 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}/documents": { + "/batches": { "get": { - "description": "Lists all `Document`s in a `Corpus`.", - "operationId": "fileSearchStores.documents.list", + "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": "filter", + "in": "query", + "description": "The standard list filter.", + "schema": { + "type": "string" + } + }, { "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.", + "description": "The standard list page size.", "schema": { "type": "integer", "format": "int32" @@ -2501,19 +2458,47 @@ { "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.", + "description": "The standard list page token.", "schema": { "type": "string" } }, { - "name": "fileSearchStoresId", + "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": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/ListOperationsResponse" + } + } + } + } + } + } + }, + "/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": "batchesId", "in": "path", "required": true, - "description": "Required. The name of the `FileSearchStore` containing `Document`s. Example: `fileSearchStores/my-file-search-store-123`", + "description": "The name of the operation resource to be cancelled.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+$" + "pattern": "^batches/[^/]+$" } } ], @@ -2523,7 +2508,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListDocumentsResponse" + "$ref": "#/components/schemas/Empty" } } } @@ -2531,81 +2516,95 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}/documents/{documentsId}": { - "get": { - "description": "Gets information about a specific `Document`.", - "operationId": "fileSearchStores.documents.get", + "/batches/{batchesId}:updateEmbedContentBatch": { + "patch": { + "description": "Updates a batch of EmbedContent requests for batch processing.", + "operationId": "batches.updateEmbedContentBatch", "parameters": [ { - "name": "fileSearchStoresId", + "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": "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`", + "name": "updateMask", + "in": "query", + "description": "Optional. The list of fields to update.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" + "format": "google-fieldmask" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/EmbedContentBatch" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Document" + "$ref": "#/components/schemas/EmbedContentBatch" } } } } } - }, - "delete": { - "description": "Deletes a `Document`.", - "operationId": "fileSearchStores.documents.delete", + } + }, + "/batches/{batchesId}:updateGenerateContentBatch": { + "patch": { + "description": "Updates a batch of GenerateContent requests for batch processing.", + "operationId": "batches.updateGenerateContentBatch", "parameters": [ { - "name": "fileSearchStoresId", + "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": "force", + "name": "updateMask", "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`", + "description": "Optional. The list of fields to update.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" + "format": "google-fieldmask" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/GenerateContentBatch" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/GenerateContentBatch" } } } @@ -2613,37 +2612,38 @@ } } }, - "/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", + "/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": "operationsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, { "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "The name of the operation resource.", + "description": "Required. Immutable. The name of the `FileSearchStore` to upload the file into. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/upload/operations/[^/]+$" + "pattern": "^fileSearchStores/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/UploadToFileSearchStoreRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/CustomLongRunningOperation" } } } @@ -2654,1531 +2654,1461 @@ }, "components": { "schemas": { - "TransferOwnershipRequest": { - "type": "object", + "ImageResponseFormat": { "properties": { - "emailAddress": { - "description": "Required. The email address of the user to whom the tuned model is being transferred to.", - "type": "string" - } - }, - "description": "Request to transfer the ownership of the tuned model." - }, - "ListFileSearchStoresResponse": { - "description": "Response from `ListFileSearchStores` containing a paginated list of `FileSearchStores`. The results are sorted by ascending `file_search_store.create_time`.", - "properties": { - "fileSearchStores": { - "description": "The returned rag_stores.", - "items": { - "$ref": "#/components/schemas/FileSearchStore" - }, - "type": "array" + "mimeType": { + "description": "Optional. The MIME type of the image output.", + "type": "string", + "x-enum-descriptions": [ + "Default value. This value is unused.", + "JPEG image format." + ], + "enum": [ + "MIME_TYPE_UNSPECIFIED", + "IMAGE_JPEG" + ] }, - "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" - }, - "ModelStatus": { - "type": "object", - "properties": { - "modelStage": { + "aspectRatio": { + "type": "string", + "description": "Optional. The aspect ratio for the image output.", "enum": [ - "MODEL_STAGE_UNSPECIFIED", - "UNSTABLE_EXPERIMENTAL", - "EXPERIMENTAL", - "PREVIEW", - "STABLE", - "LEGACY", - "DEPRECATED", - "RETIRED" + "ASPECT_RATIO_UNSPECIFIED", + "ASPECT_RATIO_ONE_BY_ONE", + "ASPECT_RATIO_TWO_BY_THREE", + "ASPECT_RATIO_THREE_BY_TWO", + "ASPECT_RATIO_THREE_BY_FOUR", + "ASPECT_RATIO_FOUR_BY_THREE", + "ASPECT_RATIO_FOUR_BY_FIVE", + "ASPECT_RATIO_FIVE_BY_FOUR", + "ASPECT_RATIO_NINE_BY_SIXTEEN", + "ASPECT_RATIO_SIXTEEN_BY_NINE", + "ASPECT_RATIO_TWENTY_ONE_BY_NINE", + "ASPECT_RATIO_ONE_BY_EIGHT", + "ASPECT_RATIO_EIGHT_BY_ONE", + "ASPECT_RATIO_ONE_BY_FOUR", + "ASPECT_RATIO_FOUR_BY_ONE" ], - "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." - ], - "type": "string", - "enumDeprecated": [ - false, - true, - false, - false, - false, - false, - true, - false + "Default value. This value is unused.", + "1:1 aspect ratio.", + "2:3 aspect ratio.", + "3:2 aspect ratio.", + "3:4 aspect ratio.", + "4:3 aspect ratio.", + "4:5 aspect ratio.", + "5:4 aspect ratio.", + "9:16 aspect ratio.", + "16:9 aspect ratio.", + "21:9 aspect ratio.", + "1:8 aspect ratio.", + "8:1 aspect ratio.", + "1:4 aspect ratio.", + "4:1 aspect ratio." ] }, - "message": { - "description": "A message explaining the model status.", - "type": "string" + "delivery": { + "enum": [ + "DELIVERY_UNSPECIFIED", + "INLINE", + "URI" + ], + "x-enum-descriptions": [ + "Default value. This value is unused.", + "Image data is returned inline in the response.", + "Image data is returned as a URI." + ], + "type": "string", + "description": "Optional. The delivery mode for the image output." }, - "retirementTime": { - "description": "The time at which the model will be retired.", + "imageSize": { "type": "string", - "format": "google-datetime" + "description": "Optional. The size of the image output.", + "enum": [ + "IMAGE_SIZE_UNSPECIFIED", + "IMAGE_SIZE_FIVE_TWELVE", + "IMAGE_SIZE_ONE_K", + "IMAGE_SIZE_TWO_K", + "IMAGE_SIZE_FOUR_K" + ], + "x-enum-descriptions": [ + "Default value. This value is unused.", + "512px image size.", + "1K image size.", + "2K image size.", + "4K image size." + ] } }, - "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", + "description": "Configuration for image output format." }, - "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.", + "EmbedContentBatchOutput": { "type": "object", + "description": "The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field.", "properties": { - "web": { - "$ref": "#/components/schemas/Web", - "description": "Grounding chunk from the web." - }, - "image": { - "$ref": "#/components/schemas/Image", - "description": "Optional. Grounding chunk from image search." - }, - "retrievedContext": { - "$ref": "#/components/schemas/RetrievedContext", - "description": "Optional. Grounding chunk from context retrieved by the file search tool." + "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.", + "type": "string", + "readOnly": true }, - "maps": { - "description": "Optional. Grounding chunk from Google Maps.", - "$ref": "#/components/schemas/Maps" + "inlinedResponses": { + "description": "Output only. The responses to the requests in the batch. Returned when the batch was built using inlined requests. The responses will be in the same order as the input requests.", + "readOnly": true, + "$ref": "#/components/schemas/InlinedEmbedContentResponses" } } }, - "RetrievalMetadata": { - "properties": { - "googleSearchDynamicRetrievalScore": { - "description": "Optional. Score indicating how likely information from google search could help answer the prompt. The score is in the range [0, 1], where 0 is the least likely and 1 is the most likely. This score is only populated when google search grounding and dynamic retrieval is enabled. It will be compared to the threshold to determine whether to trigger google search.", - "type": "number", - "format": "float" - } - }, + "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", - "description": "Metadata related to retrieval in the grounding flow." + "properties": {} }, - "EmbedContentConfig": { - "properties": { - "autoTruncate": { - "description": "Optional. Whether to silently truncate the input content if it's longer than the maximum sequence length.", - "type": "boolean" - }, - "documentOcr": { - "description": "Optional. Whether to enable OCR for document content.", - "type": "boolean" - }, - "title": { - "description": "Optional. The title for the text.", - "type": "string" - }, - "taskType": { - "type": "string", - "enum": [ - "TASK_TYPE_UNSPECIFIED", - "RETRIEVAL_QUERY", - "RETRIEVAL_DOCUMENT", - "SEMANTIC_SIMILARITY", - "CLASSIFICATION", - "CLUSTERING", - "QUESTION_ANSWERING", - "FACT_VERIFICATION", - "CODE_RETRIEVAL_QUERY" - ], - "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": "Optional. The task type of the embedding." - }, - "outputDimensionality": { - "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." - }, - "audioTrackExtraction": { - "description": "Optional. Whether to extract audio from video content.", - "type": "boolean" - } - }, + "InlinedEmbedContentRequest": { "type": "object", - "description": "Configurations for the EmbedContent request." - }, - "GoogleSearchRetrieval": { - "description": "Tool to retrieve public web data for grounding, powered by Google.", + "description": "The request to be processed in the batch.", "properties": { - "dynamicRetrievalConfig": { - "$ref": "#/components/schemas/DynamicRetrievalConfig", - "description": "Specifies the dynamic retrieval configuration for the given source." + "request": { + "$ref": "#/components/schemas/EmbedContentRequest", + "description": "Required. The request to be processed in the batch." + }, + "metadata": { + "additionalProperties": { + "description": "Properties of the object." + }, + "description": "Optional. The metadata to be associated with the request.", + "type": "object" } - }, - "type": "object" + } }, - "PromptFeedback": { + "ListOperationsResponse": { + "description": "The response message for Operations.ListOperations.", + "type": "object", "properties": { - "blockReason": { - "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. If set, the prompt was blocked and no candidates are returned. Rephrase the prompt.", - "type": "string", - "enum": [ - "BLOCK_REASON_UNSPECIFIED", - "SAFETY", - "OTHER", - "BLOCKLIST", - "PROHIBITED_CONTENT", - "IMAGE_SAFETY" - ] + "operations": { + "description": "A list of operations that matches the specified filter in the request.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Operation" + } }, - "safetyRatings": { - "description": "Ratings for safety of the prompt. There is at most one rating per category.", + "unreachable": { + "type": "array", "items": { - "$ref": "#/components/schemas/SafetyRating" + "type": "string" }, - "type": "array" - } - }, - "type": "object", - "description": "A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`." - }, - "SearchEntryPoint": { - "properties": { - "sdkBlob": { - "type": "string", - "format": "byte", - "description": "Optional. Base64 encoded JSON representing array of tuple." + "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." }, - "renderedContent": { - "description": "Optional. Web content snippet that can be embedded in a web page or an app webview.", + "nextPageToken": { + "description": "The standard List next-page token.", "type": "string" } - }, - "type": "object", - "description": "Google search entry point." + } }, - "Web": { - "description": "Chunk from the web.", + "AsyncBatchEmbedContentRequest": { "properties": { - "uri": { - "readOnly": true, - "type": "string", - "description": "Output only. URI reference of the chunk." - }, - "title": { - "readOnly": true, - "type": "string", - "description": "Output only. Title of the chunk." + "batch": { + "$ref": "#/components/schemas/EmbedContentBatch", + "description": "Required. The batch to create." } }, + "description": "Request for an `AsyncBatchEmbedContent` operation.", "type": "object" }, - "GoogleAiGenerativelanguageV1betaGroundingSupport": { - "description": "Grounding support.", + "InlinedRequests": { "type": "object", + "description": "The requests to be processed in the batch if provided as part of the batch creation request.", "properties": { - "renderedParts": { - "readOnly": true, + "requests": { + "description": "Required. The requests to be processed in the batch.", "type": "array", - "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": { - "type": "integer", - "format": "int32" + "$ref": "#/components/schemas/InlinedRequest" } + } + } + }, + "CachedContent": { + "type": "object", + "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": { + "toolConfig": { + "$ref": "#/components/schemas/ToolConfig", + "description": "Optional. Input only. Immutable. Tool config. This config is shared for all tools." }, - "segment": { - "description": "Segment of the content this support belongs to.", - "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaSegment" + "usageMetadata": { + "$ref": "#/components/schemas/CachedContentUsageMetadata", + "readOnly": true, + "description": "Output only. Metadata on the usage of the cached content." }, - "groundingChunkIndices": { + "model": { + "type": "string", + "description": "Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}`" + }, + "tools": { + "description": "Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response", "type": "array", - "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": { - "type": "integer", - "format": "int32" + "$ref": "#/components/schemas/Tool" } }, - "confidenceScores": { + "updateTime": { + "type": "string", + "description": "Output only. When the cache entry was last updated in UTC time.", + "format": "google-datetime", + "readOnly": true + }, + "name": { + "readOnly": true, + "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`", + "type": "string" + }, + "systemInstruction": { + "$ref": "#/components/schemas/Content", + "description": "Optional. Input only. Immutable. Developer set system instruction. Currently text only." + }, + "ttl": { + "type": "string", + "description": "Input only. New TTL for this resource, input only.", + "format": "google-duration" + }, + "contents": { "type": "array", "items": { - "type": "number", - "format": "float" + "$ref": "#/components/schemas/Content" }, - "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." - } - } - }, - "InlinedRequest": { - "description": "The request to be processed in the batch.", - "type": "object", - "properties": { - "request": { - "$ref": "#/components/schemas/GenerateContentRequest", - "description": "Required. The request to be processed in the batch." + "description": "Optional. Input only. Immutable. The content to cache." }, - "metadata": { - "additionalProperties": { - "description": "Properties of the object." - }, - "type": "object", - "description": "Optional. The metadata to be associated with the request." + "createTime": { + "description": "Output only. Creation time of the cache entry.", + "format": "google-datetime", + "type": "string", + "readOnly": true + }, + "displayName": { + "type": "string", + "description": "Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters." + }, + "expireTime": { + "type": "string", + "description": "Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input.", + "format": "google-datetime" } } }, - "Hyperparameters": { + "UrlMetadata": { "properties": { - "batchSize": { - "type": "integer", - "format": "int32", - "description": "Immutable. The batch size hyperparameter for tuning. If not set, a default of 4 or 16 will be used based on the number of training examples." - }, - "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." - }, - "epochCount": { - "type": "integer", - "format": "int32", - "description": "Immutable. The number of training epochs. An epoch is one pass through the training data. If not set, a default of 5 will be used." + "retrievedUrl": { + "description": "Retrieved url by the tool.", + "type": "string" }, - "learningRateMultiplier": { - "type": "number", - "format": "float", - "description": "Optional. Immutable. The learning rate multiplier is used to calculate a final learning_rate based on the default (recommended) value. Actual learning rate := learning_rate_multiplier * default learning rate Default learning rate is dependent on base model and dataset size. If not set, a default of 1.0 will be used." + "urlRetrievalStatus": { + "type": "string", + "description": "Status of the url retrieval.", + "enum": [ + "URL_RETRIEVAL_STATUS_UNSPECIFIED", + "URL_RETRIEVAL_STATUS_SUCCESS", + "URL_RETRIEVAL_STATUS_ERROR", + "URL_RETRIEVAL_STATUS_PAYWALL", + "URL_RETRIEVAL_STATUS_UNSAFE" + ], + "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." + ] } }, "type": "object", - "description": "Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance" + "description": "Context of the a single url retrieval." }, - "BatchGenerateContentRequest": { + "InlinedEmbedContentResponses": { "type": "object", + "description": "The responses to the requests in the batch.", "properties": { - "batch": { - "description": "Required. The batch to create.", - "$ref": "#/components/schemas/GenerateContentBatch" + "inlinedResponses": { + "readOnly": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/InlinedEmbedContentResponse" + }, + "description": "Output only. The responses to the requests in the batch." } - }, - "description": "Request for a `BatchGenerateContent` operation." + } }, - "AsyncBatchEmbedContentRequest": { + "ReviewSnippet": { "properties": { - "batch": { - "description": "Required. The batch to create.", - "$ref": "#/components/schemas/EmbedContentBatch" + "googleMapsUri": { + "type": "string", + "description": "A link that corresponds to the user review on Google Maps." + }, + "title": { + "type": "string", + "description": "Title of the review." + }, + "reviewId": { + "description": "The ID of the review snippet.", + "type": "string" } }, "type": "object", - "description": "Request for an `AsyncBatchEmbedContent` operation." + "description": "Encapsulates a snippet of a user review that answers a question about the features of a specific place in Google Maps." }, - "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.", + "File": { + "description": "A file uploaded to the API. Next ID: 15", + "type": "object", "properties": { - "model": { - "description": "Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}`", - "type": "string" - }, - "tools": { - "type": "array", - "items": { - "$ref": "#/components/schemas/Tool" - }, - "description": "Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response" - }, - "toolConfig": { - "description": "Optional. Input only. Immutable. Tool config. This config is shared for all tools.", - "$ref": "#/components/schemas/ToolConfig" - }, "updateTime": { - "description": "Output only. When the cache entry was last updated in UTC time.", + "type": "string", + "description": "Output only. The timestamp of when the `File` was last updated.", + "format": "google-datetime", + "readOnly": true + }, + "videoMetadata": { + "$ref": "#/components/schemas/VideoFileMetadata", "readOnly": true, + "description": "Output only. Metadata for a video." + }, + "state": { "type": "string", - "format": "google-datetime" + "readOnly": true, + "x-enum-descriptions": [ + "The default value. This value is used if the state is omitted.", + "File is being processed and cannot be used for inference yet.", + "File is processed and available for inference.", + "File failed processing." + ], + "description": "Output only. Processing state of the File.", + "enum": [ + "STATE_UNSPECIFIED", + "PROCESSING", + "ACTIVE", + "FAILED" + ] }, - "displayName": { - "description": "Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters.", + "downloadUri": { + "readOnly": true, + "description": "Output only. The download uri of the `File`.", "type": "string" }, - "contents": { - "items": { - "$ref": "#/components/schemas/Content" - }, - "description": "Optional. Input only. Immutable. The content to cache.", - "type": "array" + "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" }, - "ttl": { - "description": "Input only. New TTL for this resource, input only.", + "sizeBytes": { + "description": "Output only. Size of the file in bytes.", + "format": "int64", "type": "string", - "format": "google-duration" - }, - "systemInstruction": { - "$ref": "#/components/schemas/Content", - "description": "Optional. Input only. Immutable. Developer set system instruction. Currently text only." + "readOnly": true }, - "name": { + "createTime": { "readOnly": true, "type": "string", - "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`" + "description": "Output only. The timestamp of when the `File` was created.", + "format": "google-datetime" }, - "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.", + "source": { + "enum": [ + "SOURCE_UNSPECIFIED", + "UPLOADED", + "GENERATED", + "REGISTERED" + ], + "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." + ], "type": "string", - "format": "google-datetime" + "description": "Source of the File." }, - "createTime": { + "expirationTime": { + "description": "Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.", + "format": "google-datetime", + "type": "string", + "readOnly": true + }, + "error": { "readOnly": true, + "$ref": "#/components/schemas/Status", + "description": "Output only. Error status if File processing failed." + }, + "sha256Hash": { "type": "string", - "format": "google-datetime", - "description": "Output only. Creation time of the cache entry." + "description": "Output only. SHA-256 hash of the uploaded bytes.", + "format": "byte", + "readOnly": true }, - "usageMetadata": { - "description": "Output only. Metadata on the usage of the cached content.", - "$ref": "#/components/schemas/CachedContentUsageMetadata", + "mimeType": { + "description": "Output only. MIME type of the file.", + "type": "string", + "readOnly": true + }, + "uri": { + "type": "string", + "description": "Output only. The uri of the `File`.", "readOnly": true + }, + "displayName": { + "description": "Optional. The human-readable display name for the `File`. The display name must be no more than 512 characters in length, including spaces. Example: \"Welcome Image\"", + "type": "string" } - }, - "type": "object" + } }, - "InlinedResponses": { + "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", "properties": { - "inlinedResponses": { - "description": "Output only. The responses to the requests in the batch.", - "items": { - "$ref": "#/components/schemas/InlinedResponse" - }, - "readOnly": true, - "type": "array" + "name": { + "description": "Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128.", + "type": "string" + }, + "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" + }, + "args": { + "type": "object", + "description": "Optional. The function parameters and values in JSON object format.", + "additionalProperties": { + "description": "Properties of the object." + } } - }, - "description": "The responses to the requests in the batch." + } }, - "Interval": { - "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.", + "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.", "type": "object", "properties": { - "startTime": { + "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" + }, + "description": { "type": "string", - "format": "google-datetime", - "description": "Optional. Inclusive start of the interval. If specified, a Timestamp matching this interval will have to be the same or after the start." + "description": "Required. A brief description of the function." }, - "endTime": { - "description": "Optional. Exclusive end of the interval. If specified, a Timestamp matching this interval will have to be before the end.", + "behavior": { "type": "string", - "format": "google-datetime" + "description": "Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method.", + "enum": [ + "UNSPECIFIED", + "BLOCKING", + "NON_BLOCKING" + ], + "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." + ] + }, + "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" + }, + "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`." + }, + "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`." + }, + "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" } } }, - "GoogleMaps": { - "description": "The GoogleMaps Tool that provides geospatial context for the user's query.", + "TranslationConfig": { "properties": { - "enableWidget": { - "description": "Optional. Whether to return a widget context token in the GroundingMetadata of the response. Developers can use the widget context token to render a Google Maps widget with geospatial context related to the places that the model references in the response.", - "type": "boolean" + "echoTargetLanguage": { + "type": "boolean", + "description": "Optional. If true, the model will generate audio when the target language is spoken, essentially it will parrot the input. If false, we will not produce audio for the target language." + }, + "targetLanguageCode": { + "description": "Required. The target language for translation. Supported values are BCP-47 language codes (e.g. \"en\", \"es\", \"fr\").", + "type": "string" } }, - "type": "object" - }, - "GenerateContentBatchOutput": { "type": "object", + "description": "Config for translation features." + }, + "Candidate": { "properties": { - "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 `GenerateContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests.", + "groundingMetadata": { + "description": "Output only. Grounding metadata for the candidate. This field is populated for `GenerateContent` calls.", "readOnly": true, - "type": "string" + "$ref": "#/components/schemas/GroundingMetadata" }, - "inlinedResponses": { + "avgLogprobs": { "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" - } - }, - "description": "The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field." - }, - "EmbeddingUsageMetadata": { - "properties": { - "promptTokenDetails": { - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - }, - "description": "Output only. List of modalities that were processed in the request input.", + "type": "number", + "description": "Output only. Average log probability score of the candidate.", + "format": "double" + }, + "finishMessage": { "readOnly": true, - "type": "array" + "type": "string", + "description": "Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set." }, - "promptTokenCount": { - "description": "Output only. Number of tokens in the prompt.", + "index": { "readOnly": true, "type": "integer", + "description": "Output only. Index of the candidate in the list of response candidates.", "format": "int32" - } - }, - "type": "object", - "description": "Metadata on the usage of the embedding request." - }, - "ListFilesResponse": { - "description": "Response for `ListFiles`.", - "properties": { - "files": { + }, + "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, + "$ref": "#/components/schemas/CitationMetadata" + }, + "groundingAttributions": { + "description": "Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.", "type": "array", - "description": "The list of `File`s.", "items": { - "$ref": "#/components/schemas/File" - } + "$ref": "#/components/schemas/GroundingAttribution" + }, + "readOnly": true }, - "nextPageToken": { - "description": "A token that can be sent as a `page_token` into a subsequent `ListFiles` call.", - "type": "string" - } - }, - "type": "object" - }, - "Maps": { - "description": "A grounding chunk from Google Maps. A Maps chunk corresponds to a single place.", - "type": "object", - "properties": { - "title": { - "description": "Title of the place.", - "type": "string" + "logprobsResult": { + "description": "Output only. Log-likelihood scores for the response tokens and top tokens", + "readOnly": true, + "$ref": "#/components/schemas/LogprobsResult" }, - "text": { - "description": "Text description of the place answer.", - "type": "string" + "safetyRatings": { + "description": "List of ratings for the safety of a response candidate. There is at most one rating per category.", + "type": "array", + "items": { + "$ref": "#/components/schemas/SafetyRating" + } }, - "uri": { - "description": "URI reference of the place.", - "type": "string" + "tokenCount": { + "readOnly": true, + "type": "integer", + "description": "Output only. Token count for this candidate.", + "format": "int32" }, - "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" + "urlContextMetadata": { + "$ref": "#/components/schemas/UrlContextMetadata", + "readOnly": true, + "description": "Output only. Metadata related to url context retrieval tool." }, - "placeAnswerSources": { - "description": "Sources that provide answers about the features of a given place in Google Maps.", - "$ref": "#/components/schemas/PlaceAnswerSources" - } - } - }, - "UrlMetadata": { - "description": "Context of the a single url retrieval.", - "type": "object", - "properties": { - "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." + "content": { + "description": "Output only. Generated content returned from the model.", + "readOnly": true, + "$ref": "#/components/schemas/Content" + }, + "finishReason": { + "description": "Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.", + "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", + "ESCALATION" ], "type": "string", - "enum": [ - "URL_RETRIEVAL_STATUS_UNSPECIFIED", - "URL_RETRIEVAL_STATUS_SUCCESS", - "URL_RETRIEVAL_STATUS_ERROR", - "URL_RETRIEVAL_STATUS_PAYWALL", - "URL_RETRIEVAL_STATUS_UNSAFE" + "readOnly": true, + "x-enum-descriptions": [ + "Default value. This value is unused.", + "Natural stop point of the model or provided stop sequence.", + "The maximum number of tokens as specified in the request was reached.", + "The response candidate content was flagged for safety reasons.", + "The response candidate content was flagged for recitation reasons.", + "The response candidate content was flagged for using an unsupported language.", + "Unknown reason.", + "Token generation stopped because the content contains forbidden terms.", + "Token generation stopped for potentially containing prohibited content.", + "Token generation stopped because the content potentially contains Sensitive Personally Identifiable Information (SPII).", + "The function call generated by the model is invalid.", + "Token generation stopped because generated images contain safety violations.", + "Image generation stopped because generated images has other prohibited content.", + "Image generation stopped because of other miscellaneous issue.", + "The model was expected to generate an image, but none was generated.", + "Image generation stopped due to recitation.", + "Model generated a tool call but no tools were enabled in the request.", + "Model called too many tools consecutively, thus the system exited execution.", + "Request has at least one thought signature missing.", + "Finished due to malformed response.", + "Request was filtered by an escalation rule." ] - }, - "retrievedUrl": { - "description": "Retrieved url by the tool.", - "type": "string" } - } + }, + "description": "A response candidate generated from the model.", + "type": "object" }, - "FunctionResponse": { + "CustomLongRunningOperation": { "properties": { - "willContinue": { - "description": "Optional. Signals that function call continues, and more responses will be returned, turning the function call into a generator. Is only applicable to NON_BLOCKING function calls, is ignored otherwise. If set to false, future responses will not be considered. It is allowed to return empty `response` with `will_continue=False` to signal that the function call is finished. This may still trigger the model generation. To avoid triggering the generation and finish the function call, additionally set `scheduling` to `SILENT`.", - "type": "boolean" - }, - "parts": { - "items": { - "$ref": "#/components/schemas/FunctionResponsePart" - }, - "description": "Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types.", - "type": "array" + "response": { + "description": "The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.", + "type": "object", + "additionalProperties": { + "description": "Properties of the object. Contains field @type with type URL." + } }, "name": { - "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.", + "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" }, - "scheduling": { - "type": "string", - "enum": [ - "SCHEDULING_UNSPECIFIED", - "SILENT", - "WHEN_IDLE", - "INTERRUPT" - ], - "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." - ], - "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." + "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." }, - "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. Multimedia can be included by using a subobject containing a single \"$ref\" key whose value is the `inline_data.display_name` of a `FunctionResponsePart` holding the multimedia. See https://ai.google.dev/gemini-api/docs/function-calling#multimodal.", + "metadata": { "additionalProperties": { - "description": "Properties of the object." + "description": "Properties of the object. Contains field @type with type URL." }, + "description": "Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any.", "type": "object" }, - "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" + "error": { + "$ref": "#/components/schemas/Status", + "description": "The error result of the operation in case of failure or cancellation." } }, - "type": "object", - "description": "The result output from a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model. This should contain the result of a`FunctionCall` made based on model prediction." + "type": "object" }, - "BatchEmbedContentsRequest": { - "description": "Batch request to get embeddings from the model for a list of prompts.", + "Web": { "properties": { - "requests": { - "type": "array", - "items": { - "$ref": "#/components/schemas/EmbedContentRequest" - }, - "description": "Required. Embed requests for the batch. The model in each of these requests must match the model specified `BatchEmbedContentsRequest.model`." + "uri": { + "type": "string", + "description": "Output only. URI reference of the chunk.", + "readOnly": true + }, + "title": { + "readOnly": true, + "type": "string", + "description": "Output only. Title of the chunk." } }, + "description": "Chunk from the web.", "type": "object" }, - "WebSearch": { - "type": "object", - "properties": {}, - "description": "Standard web search for grounding and related configurations." - }, - "Image": { + "PrebuiltVoiceConfig": { "type": "object", + "description": "The configuration for the prebuilt speaker to use.", "properties": { - "domain": { - "description": "The root domain of the web page that the image is from, e.g. \"example.com\".", - "type": "string" - }, - "title": { - "description": "The title of the web page that the image is from.", - "type": "string" - }, - "sourceUri": { - "description": "The web page URI for attribution.", - "type": "string" - }, - "imageUri": { - "description": "The image asset URL.", + "voiceName": { + "description": "The name of the preset voice to use.", "type": "string" } - }, - "description": "Chunk from image search." + } }, - "SafetySetting": { + "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": { - "category": { - "x-enum-descriptions": [ - "Category is unspecified.", - "**PaLM** - Negative or harmful comments targeting identity and/or protected attribute.", - "**PaLM** - Content that is rude, disrespectful, or profane.", - "**PaLM** - Describes scenarios depicting violence against an individual or group, or general descriptions of gore.", - "**PaLM** - Contains references to sexual acts or other lewd content.", - "**PaLM** - Promotes unchecked medical advice.", - "**PaLM** - Dangerous content that promotes, facilitates, or encourages harmful acts.", - "**Gemini** - Harassment content.", - "**Gemini** - Hate speech and content.", - "**Gemini** - Sexually explicit content.", - "**Gemini** - Dangerous content.", - "**Gemini** - Content that may be used to harm civic integrity. DEPRECATED: use enable_enhanced_civic_answers instead." - ], - "description": "Required. The category for this setting.", - "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" - ], - "enumDeprecated": [ - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - true - ], - "type": "string" - }, - "threshold": { - "type": "string", - "enum": [ - "HARM_BLOCK_THRESHOLD_UNSPECIFIED", - "BLOCK_LOW_AND_ABOVE", - "BLOCK_MEDIUM_AND_ABOVE", - "BLOCK_ONLY_HIGH", - "BLOCK_NONE", - "OFF" - ], - "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." - ], - "description": "Required. Controls the probability threshold at which harm is blocked." + "streamableHttpTransport": { + "description": "A transport that can stream HTTP requests and responses.", + "$ref": "#/components/schemas/StreamableHttpTransport" + }, + "name": { + "type": "string", + "description": "The name of the MCPServer." } - }, - "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." + } }, - "LogprobsResult": { + "TopCandidates": { "properties": { - "logProbabilitySum": { - "type": "number", - "format": "float", - "description": "Sum of log probabilities for all tokens." - }, - "chosenCandidates": { + "candidates": { "type": "array", - "description": "Length = total number of decoding steps. The chosen candidates may or may not be in top_candidates.", "items": { "$ref": "#/components/schemas/LogprobsResultCandidate" - } - }, - "topCandidates": { - "type": "array", - "items": { - "$ref": "#/components/schemas/TopCandidates" }, - "description": "Length = total number of decoding steps." + "description": "Sorted by log probability in descending order." } }, "type": "object", - "description": "Logprobs Result" + "description": "Candidates with top log probabilities at each decoding step." }, - "Operation": { + "Blob": { "type": "object", + "description": "Raw media bytes. Text should not be sent as raw bytes, use the 'text' field.", "properties": { - "error": { - "description": "The error result of the operation in case of failure or cancellation.", - "$ref": "#/components/schemas/Status" - }, - "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" - }, - "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`.", - "additionalProperties": { - "description": "Properties of the object. Contains field @type with type URL." - }, - "type": "object" - }, - "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" + "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). //" }, - "metadata": { - "additionalProperties": { - "description": "Properties of the object. Contains field @type with type URL." - }, - "type": "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." - } - }, - "description": "This resource represents a long-running operation that is the result of a network API call." - }, - "ChunkingConfig": { - "description": "Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto", - "properties": { - "whiteSpaceConfig": { - "description": "White space chunking configuration.", - "$ref": "#/components/schemas/WhiteSpaceConfig" + "data": { + "type": "string", + "description": "Raw bytes for media formats.", + "format": "byte" } - }, - "type": "object" - }, - "Empty": { - "description": "A generic empty message that you can re-use to avoid defining duplicated empty messages in your APIs. A typical example is to use it as the request or the response type of an API method. For instance: service Foo { rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); }", - "properties": {}, - "type": "object" + } }, - "UploadToFileSearchStoreRequest": { + "Document": { "properties": { - "chunkingConfig": { - "$ref": "#/components/schemas/ChunkingConfig", - "description": "Optional. Config for telling the service how to chunk the data. If not provided, the service will use default parameters." + "createTime": { + "description": "Output only. The Timestamp of when the `Document` was created.", + "format": "google-datetime", + "type": "string", + "readOnly": true + }, + "state": { + "readOnly": true, + "x-enum-descriptions": [ + "The default value. This value is used if the state is omitted.", + "Some `Chunks` of the `Document` are being processed (embedding and vector storage).", + "All `Chunks` of the `Document` is processed and available for querying.", + "Some `Chunks` of the `Document` failed processing." + ], + "type": "string", + "enum": [ + "STATE_UNSPECIFIED", + "STATE_PENDING", + "STATE_ACTIVE", + "STATE_FAILED" + ], + "description": "Output only. Current state of the `Document`." }, "displayName": { - "description": "Optional. Display name of the created document.", + "description": "Optional. The human-readable display name for the `Document`. The display name must be no more than 512 characters in length, including spaces. Example: \"Semantic Retriever Documentation\"", "type": "string" }, + "updateTime": { + "readOnly": true, + "type": "string", + "description": "Output only. The Timestamp of when the `Document` was last updated.", + "format": "google-datetime" + }, + "mimeType": { + "description": "Output only. The mime type of the Document.", + "type": "string", + "readOnly": true + }, + "name": { + "type": "string", + "description": "Immutable. Identifier. The `Document` resource name. The ID (name excluding the \"fileSearchStores/*/documents/\" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/{file_search_store_id}/documents/my-awesome-doc-123a456b789c`" + }, + "sizeBytes": { + "description": "Output only. The size of raw bytes ingested into the Document.", + "format": "int64", + "type": "string", + "readOnly": true + }, "customMetadata": { "type": "array", - "description": "Custom metadata to be associated with the data.", "items": { "$ref": "#/components/schemas/CustomMetadata" - } - }, - "mimeType": { - "description": "Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content.", - "type": "string" + }, + "description": "Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`." } }, "type": "object", - "description": "Request for `UploadToFileSearchStore`." + "description": "A `Document` is a collection of `Chunk`s." }, - "ModalityTokenCount": { - "type": "object", + "InputEmbedContentConfig": { "properties": { - "modality": { + "fileName": { "type": "string", - "enum": [ - "MODALITY_UNSPECIFIED", - "TEXT", - "IMAGE", - "VIDEO", - "AUDIO", - "DOCUMENT" - ], - "description": "The modality associated with this token count.", - "x-enum-descriptions": [ - "Unspecified modality.", - "Plain text.", - "Image.", - "Video.", - "Audio.", - "Document, e.g. PDF." - ] + "description": "The name of the `File` containing the input requests." }, - "tokenCount": { - "description": "Number of tokens.", - "type": "integer", - "format": "int32" + "requests": { + "description": "The requests to be processed in the batch.", + "$ref": "#/components/schemas/InlinedEmbedContentRequests" } }, - "description": "Represents token counting info for a single modality." + "type": "object", + "description": "Configures the input to the batch request." }, - "StringList": { - "description": "User provided string values assigned to a single metadata key.", + "InlinedRequest": { "properties": { - "values": { - "type": "array", - "description": "The string values of the metadata to store.", - "items": { - "type": "string" + "request": { + "description": "Required. The request to be processed in the batch.", + "$ref": "#/components/schemas/GenerateContentRequest" + }, + "metadata": { + "type": "object", + "description": "Optional. The metadata to be associated with the request.", + "additionalProperties": { + "description": "Properties of the object." } } }, - "type": "object" + "type": "object", + "description": "The request to be processed in the batch." }, - "CustomLongRunningOperation": { + "Model": { "properties": { - "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." + "temperature": { + "description": "Controls the randomness of the output. Values can range over `[0.0,max_temperature]`, inclusive. A higher value will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be used by the backend while making the call to the model.", + "format": "float", + "type": "number" + }, + "baseModelId": { + "description": "Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash`", + "type": "string" + }, + "maxTemperature": { + "description": "The maximum temperature this model can use.", + "format": "float", + "type": "number" + }, + "description": { + "description": "A short description of the model.", + "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`.", + "type": "array", + "items": { + "type": "string" } }, - "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.", + "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." + }, + "thinking": { + "description": "Whether the model supports thinking.", "type": "boolean" }, - "error": { - "description": "The error result of the operation in case of failure or cancellation.", - "$ref": "#/components/schemas/Status" + "version": { + "type": "string", + "description": "Required. The version number of the model. This represents the major version (`1.0` or `1.5`)" + }, + "topK": { + "type": "integer", + "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.", + "format": "int32" + }, + "inputTokenLimit": { + "description": "Maximum number of input tokens allowed for this model.", + "format": "int32", + "type": "integer" + }, + "topP": { + "type": "number", + "description": "For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model.", + "format": "float" + }, + "outputTokenLimit": { + "description": "Maximum number of output tokens available for this model.", + "format": "int32", + "type": "integer" }, "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}`.", + "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" - }, - "metadata": { - "type": "object", - "additionalProperties": { - "description": "Properties of the object. Contains field @type with type URL." - }, - "description": "Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any." } }, + "description": "Information about a Generative Language Model.", "type": "object" }, - "ListOperationsResponse": { + "SearchEntryPoint": { + "description": "Google search entry point.", "type": "object", "properties": { - "operations": { - "items": { - "$ref": "#/components/schemas/Operation" - }, - "description": "A list of operations that matches the specified filter in the request.", - "type": "array" - }, - "nextPageToken": { - "description": "The standard List next-page token.", + "sdkBlob": { + "description": "Optional. Base64 encoded JSON representing array of tuple.", + "format": "byte", "type": "string" }, - "unreachable": { + "renderedContent": { + "type": "string", + "description": "Optional. Web content snippet that can be embedded in a web page or an app webview." + } + } + }, + "LogprobsResult": { + "type": "object", + "description": "Logprobs Result", + "properties": { + "logProbabilitySum": { + "description": "Sum of log probabilities for all tokens.", + "format": "float", + "type": "number" + }, + "chosenCandidates": { + "type": "array", + "items": { + "$ref": "#/components/schemas/LogprobsResultCandidate" + }, + "description": "Length = total number of decoding steps. The chosen candidates may or may not be in top_candidates." + }, + "topCandidates": { "type": "array", "items": { - "type": "string" + "$ref": "#/components/schemas/TopCandidates" }, - "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." + "description": "Length = total number of decoding steps." } - }, - "description": "The response message for Operations.ListOperations." + } }, - "ListTunedModelsResponse": { + "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": { - "tunedModels": { - "type": "array", - "description": "The returned Models.", - "items": { - "$ref": "#/components/schemas/TunedModel" - } + "endTime": { + "type": "string", + "description": "Optional. Exclusive end of the interval. If specified, a Timestamp matching this interval will have to be before the end.", + "format": "google-datetime" }, - "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.", + "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" } - }, - "description": "Response from `ListTunedModels` containing a paginated list of Models." + } }, - "TextResponseFormat": { - "description": "Configuration for text output format.", + "ThinkingConfig": { + "type": "object", + "description": "Config for thinking features.", "properties": { - "mimeType": { - "description": "Optional. The MIME type of the text output.", - "x-enum-descriptions": [ - "Default value. This value is unused.", - "JSON output format.", - "Plain text output format." - ], + "includeThoughts": { + "type": "boolean", + "description": "Indicates whether to include thoughts in the response. If true, thoughts are returned only when available." + }, + "thinkingBudget": { + "type": "integer", + "description": "The number of thoughts tokens that the model should generate.", + "format": "int32" + }, + "thinkingLevel": { "type": "string", + "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.", "enum": [ - "MIME_TYPE_UNSPECIFIED", - "APPLICATION_JSON", - "TEXT_PLAIN" + "THINKING_LEVEL_UNSPECIFIED", + "MINIMAL", + "LOW", + "MEDIUM", + "HIGH" + ], + "x-enum-descriptions": [ + "Default value.", + "Little to no thinking.", + "Low thinking level.", + "Medium thinking level.", + "High thinking level." ] + } + } + }, + "GroundingPassageId": { + "properties": { + "partIndex": { + "readOnly": true, + "description": "Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`.", + "format": "int32", + "type": "integer" }, - "schema": { - "description": "Optional. The JSON schema that the output should conform to. Only applicable when mime_type is APPLICATION_JSON." + "passageId": { + "description": "Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`.", + "type": "string", + "readOnly": true } }, + "description": "Identifier for a part within a `GroundingPassage`.", "type": "object" }, - "DynamicRetrievalConfig": { - "description": "Describes the options to customize dynamic retrieval.", + "RetrievalMetadata": { + "description": "Metadata related to retrieval in the grounding flow.", "type": "object", "properties": { - "mode": { - "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." - ], - "type": "string", - "enum": [ - "MODE_UNSPECIFIED", - "MODE_DYNAMIC" - ] - }, - "dynamicThreshold": { - "description": "The threshold to be used in dynamic retrieval. If not set, a system default value is used.", - "type": "number", - "format": "float" + "googleSearchDynamicRetrievalScore": { + "description": "Optional. Score indicating how likely information from google search could help answer the prompt. The score is in the range [0, 1], where 0 is the least likely and 1 is the most likely. This score is only populated when google search grounding and dynamic retrieval is enabled. It will be compared to the threshold to determine whether to trigger google search.", + "format": "float", + "type": "number" } } }, + "BatchEmbedContentsRequest": { + "properties": { + "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/EmbedContentRequest" + } + } + }, + "description": "Batch request to get embeddings from the model for a list of prompts.", + "type": "object" + }, "VideoMetadata": { + "type": "object", + "deprecated": true, + "description": "Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content.", "properties": { + "startOffset": { + "type": "string", + "description": "Optional. The start offset of the video.", + "format": "google-duration" + }, "endOffset": { "type": "string", - "format": "google-duration", - "description": "Optional. The end offset of the video." + "description": "Optional. The end offset of the video.", + "format": "google-duration" }, "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": { - "type": "string", - "format": "google-duration", - "description": "Optional. The start offset of the video." + "format": "double", + "type": "number" } - }, - "type": "object", - "description": "Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content.", - "deprecated": true - }, - "UrlContext": { - "type": "object", - "properties": {}, - "description": "Tool to support URL context retrieval." + } }, - "GenerateContentRequest": { - "type": "object", + "SafetyRating": { "properties": { - "safetySettings": { - "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.", - "type": "array" - }, - "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" - }, - "systemInstruction": { - "$ref": "#/components/schemas/Content", - "description": "Optional. Developer set [system instruction(s)](https://ai.google.dev/gemini-api/docs/system-instructions). Currently, text only." - }, - "generationConfig": { - "$ref": "#/components/schemas/GenerationConfig", - "description": "Optional. Configuration options for model generation and outputs." - }, - "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.", - "items": { - "$ref": "#/components/schemas/Content" - }, - "type": "array" - }, - "serviceTier": { - "description": "Optional. The service tier of the request.", + "category": { "x-enum-descriptions": [ - "Default service tier, which is standard.", - "Standard service tier.", - "Flex service tier.", - "Priority service tier." + "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", "enum": [ - "unspecified", - "standard", - "flex", - "priority" - ] - }, - "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." - }, - "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." + "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" + ], + "enumDeprecated": [ + false, + false, + false, + false, + false, + false, + false, + false, + false, + false, + false, + true + ], + "description": "Required. The category for this rating." }, - "model": { - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", - "type": "string" + "probability": { + "enum": [ + "HARM_PROBABILITY_UNSPECIFIED", + "NEGLIGIBLE", + "LOW", + "MEDIUM", + "HIGH" + ], + "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." + ], + "type": "string", + "description": "Required. The probability of harm for this content." }, - "store": { - "description": "Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config.", - "type": "boolean" - } - }, - "description": "Request to generate a completion from the model." - }, - "ImageSearch": { - "type": "object", - "properties": {}, - "description": "Image search for grounding and related configurations." - }, - "VoiceConfig": { - "properties": { - "prebuiltVoiceConfig": { - "description": "The configuration for the prebuilt voice to use.", - "$ref": "#/components/schemas/PrebuiltVoiceConfig" - } - }, - "type": "object", - "description": "The configuration for the voice to use." - }, - "CodeExecution": { - "description": "Tool that executes code generated by the model, and automatically returns the result to the model. See also `ExecutableCode` and `CodeExecutionResult` which are only generated when using this tool.", - "properties": {}, + "blocked": { + "description": "Was this content blocked because of this rating?", + "type": "boolean" + } + }, + "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.", "type": "object" }, - "PrebuiltVoiceConfig": { + "EmbedContentResponse": { + "description": "The response to an `EmbedContentRequest`.", + "type": "object", "properties": { - "voiceName": { - "description": "The name of the preset voice to use.", - "type": "string" + "embedding": { + "$ref": "#/components/schemas/ContentEmbedding", + "readOnly": true, + "description": "Output only. The embedding generated from the input content." + }, + "usageMetadata": { + "description": "Output only. The usage metadata for the request.", + "readOnly": true, + "$ref": "#/components/schemas/EmbeddingUsageMetadata" } - }, - "type": "object", - "description": "The configuration for the prebuilt speaker to use." + } }, - "SpeakerVoiceConfig": { + "GoogleAiGenerativelanguageV1betaSegment": { "type": "object", + "description": "Segment of the content.", "properties": { - "speaker": { - "description": "Required. The name of the speaker to use. Should be the same as in the prompt.", - "type": "string" + "partIndex": { + "type": "integer", + "description": "The index of a Part object within its parent Content object.", + "format": "int32" }, - "voiceConfig": { - "description": "Required. The configuration for the voice to use.", - "$ref": "#/components/schemas/VoiceConfig" + "startIndex": { + "description": "Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero.", + "format": "int32", + "type": "integer" + }, + "endIndex": { + "type": "integer", + "description": "End index in the given Part, measured in bytes. Offset from the start of the Part, exclusive, starting at zero.", + "format": "int32" + }, + "text": { + "type": "string", + "description": "The text corresponding to the segment from the response." + } + } + }, + "TransferOwnershipRequest": { + "properties": { + "emailAddress": { + "type": "string", + "description": "Required. The email address of the user to whom the tuned model is being transferred to." } }, - "description": "The configuration for a single speaker in a multi speaker setup." + "type": "object", + "description": "Request to transfer the ownership of the tuned model." }, "ToolConfig": { - "description": "The Tool configuration containing parameters for specifying `Tool` use in the request.", - "type": "object", "properties": { - "retrievalConfig": { - "$ref": "#/components/schemas/RetrievalConfig", - "description": "Optional. Retrieval config." - }, "functionCallingConfig": { "description": "Optional. Function calling config.", "$ref": "#/components/schemas/FunctionCallingConfig" }, + "retrievalConfig": { + "$ref": "#/components/schemas/RetrievalConfig", + "description": "Optional. Retrieval config." + }, "includeServerSideToolInvocations": { "description": "Optional. If true, the API response will include the server-side tool calls and responses within the `Content` message. This allows clients to observe the server's tool interactions.", "type": "boolean" } - } - }, - "CitationMetadata": { - "description": "A collection of source attributions for a piece of content.", - "properties": { - "citationSources": { - "description": "Citations to sources for a specific response.", - "items": { - "$ref": "#/components/schemas/CitationSource" - }, - "type": "array" - } }, - "type": "object" + "type": "object", + "description": "The Tool configuration containing parameters for specifying `Tool` use in the request." }, - "Dataset": { + "ListFileSearchStoresResponse": { "properties": { - "examples": { - "description": "Optional. Inline examples with simple input/output text.", - "$ref": "#/components/schemas/TuningExamples" + "fileSearchStores": { + "description": "The returned rag_stores.", + "type": "array", + "items": { + "$ref": "#/components/schemas/FileSearchStore" + } + }, + "nextPageToken": { + "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", + "type": "string" } }, "type": "object", - "description": "Dataset for training or validation." + "description": "Response from `ListFileSearchStores` containing a paginated list of `FileSearchStores`. The results are sorted by ascending `file_search_store.create_time`." }, - "CodeExecutionResult": { + "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.", + "type": "object", "properties": { - "id": { - "description": "Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id.", - "type": "string" - }, - "outcome": { - "type": "string", + "modelStage": { "enum": [ - "OUTCOME_UNSPECIFIED", - "OUTCOME_OK", - "OUTCOME_FAILED", - "OUTCOME_DEADLINE_EXCEEDED" + "MODEL_STAGE_UNSPECIFIED", + "UNSTABLE_EXPERIMENTAL", + "EXPERIMENTAL", + "PREVIEW", + "STABLE", + "LEGACY", + "DEPRECATED", + "RETIRED" + ], + "enumDeprecated": [ + false, + true, + false, + false, + false, + false, + true, + false ], + "description": "The stage of the underlying model.", "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." + "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." ], - "description": "Required. Outcome of the code execution." - }, - "output": { - "description": "Optional. Contains stdout when code execution is successful, stderr or other description otherwise.", "type": "string" - } - }, - "type": "object", - "description": "Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used." - }, - "SemanticRetrieverChunk": { - "description": "Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`.", - "type": "object", - "properties": { - "source": { - "description": "Output only. Name of the source matching the request's `SemanticRetrieverConfig.source`. Example: `corpora/123` or `corpora/123/documents/abc`", - "readOnly": true, + }, + "retirementTime": { + "description": "The time at which the model will be retired.", + "format": "google-datetime", "type": "string" }, - "chunk": { - "description": "Output only. Name of the `Chunk` containing the attributed text. Example: `corpora/123/documents/abc/chunks/xyz`", - "readOnly": true, + "message": { + "description": "A message explaining the model status.", "type": "string" } } }, - "TopCandidates": { - "description": "Candidates with top log probabilities at each decoding step.", - "type": "object", + "PlaceAnswerSources": { "properties": { - "candidates": { + "reviewSnippets": { + "description": "Snippets of reviews that are used to generate answers about the features of a given place in Google Maps.", "type": "array", "items": { - "$ref": "#/components/schemas/LogprobsResultCandidate" - }, - "description": "Sorted by log probability in descending order." + "$ref": "#/components/schemas/ReviewSnippet" + } } - } + }, + "type": "object", + "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." }, - "Corpus": { - "description": "A `Corpus` is a collection of `Document`s. A project can create up to 10 corpora.", + "SearchTypes": { + "properties": { + "webSearch": { + "description": "Optional. Enables web search. Only text results are returned.", + "$ref": "#/components/schemas/WebSearch" + }, + "imageSearch": { + "description": "Optional. Enables image search. Image bytes are returned.", + "$ref": "#/components/schemas/ImageSearch" + } + }, + "type": "object", + "description": "Different types of search that can be enabled on the GoogleSearch tool." + }, + "EmbedContentBatchStats": { + "description": "Stats about the batch.", "type": "object", "properties": { - "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\"", + "pendingRequestCount": { + "readOnly": true, + "description": "Output only. The number of requests that are still pending processing.", + "format": "int64", "type": "string" }, - "createTime": { - "description": "Output only. The Timestamp of when the `Corpus` was created.", - "readOnly": true, + "successfulRequestCount": { "type": "string", - "format": "google-datetime" + "description": "Output only. The number of requests that were successfully processed.", + "format": "int64", + "readOnly": true }, - "name": { + "failedRequestCount": { "readOnly": true, "type": "string", - "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`" + "description": "Output only. The number of requests that failed to be processed.", + "format": "int64" }, - "updateTime": { - "readOnly": true, + "requestCount": { + "description": "Output only. The number of requests in the batch.", + "format": "int64", "type": "string", - "format": "google-datetime", - "description": "Output only. The Timestamp of when the `Corpus` was last updated." + "readOnly": true } } }, - "RetrievalConfig": { - "description": "Retrieval config.", + "CitationSource": { + "description": "A citation to a source for a portion of a specific response.", + "type": "object", "properties": { - "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).", + "uri": { + "description": "Optional. URI that is attributed as a source for a portion of the text.", "type": "string" }, - "latLng": { - "description": "Optional. The location of the user.", - "$ref": "#/components/schemas/LatLng" + "startIndex": { + "description": "Optional. Start of segment of the response that is attributed to this source. Index indicates the start of the segment, measured in bytes.", + "format": "int32", + "type": "integer" + }, + "endIndex": { + "description": "Optional. End of the attributed segment, exclusive.", + "format": "int32", + "type": "integer" + }, + "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." } - }, - "type": "object" + } }, - "GroundingMetadata": { - "description": "Metadata returned to client when grounding is enabled.", + "GoogleAiGenerativelanguageV1betaGroundingSupport": { "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": { - "type": "array", - "description": "Web search queries for the following-up web search.", - "items": { - "type": "string" - } - }, - "groundingSupports": { - "type": "array", - "description": "List of grounding support.", - "items": { - "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaGroundingSupport" - } + "segment": { + "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaSegment", + "description": "Segment of the content this support belongs to." }, - "groundingChunks": { + "groundingChunkIndices": { + "type": "array", "items": { - "$ref": "#/components/schemas/GroundingChunk" + "type": "integer", + "format": "int32" }, - "description": "List of supporting references retrieved from specified grounding source. When streaming, this only contains the grounding chunks that have not been included in the grounding metadata of previous responses.", - "type": "array" - }, - "retrievalMetadata": { - "description": "Metadata related to retrieval in the grounding flow.", - "$ref": "#/components/schemas/RetrievalMetadata" + "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)." }, - "imageSearchQueries": { + "renderedParts": { "type": "array", "items": { - "type": "string" + "format": "int32", + "type": "integer" }, - "description": "Image search queries used for grounding." + "description": "Output only. Indices into the `parts` field of the candidate's content. These indices specify which rendered parts are associated with this support source.", + "readOnly": true + }, + "confidenceScores": { + "description": "Optional. Confidence score of the support references. Ranges from 0 to 1. 1 is the most confident. This list must have the same size as the grounding_chunk_indices.", + "type": "array", + "items": { + "format": "float", + "type": "number" + } } }, + "description": "Grounding support.", "type": "object" }, - "ListModelsResponse": { - "type": "object", + "ListCorporaResponse": { "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" - }, - "models": { + "corpora": { "type": "array", "items": { - "$ref": "#/components/schemas/Model" + "$ref": "#/components/schemas/Corpus" }, - "description": "The returned Models." - } - }, - "description": "Response from `ListModel` containing a paginated list of Models." - }, - "TuningExample": { - "properties": { - "textInput": { - "description": "Optional. Text model input.", - "type": "string" + "description": "The returned corpora." }, - "output": { - "description": "Required. The expected model output.", + "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", - "description": "A single example for tuning." + "description": "Response from `ListCorpora` containing a paginated list of `Corpora`. The results are sorted by ascending `corpus.create_time`.", + "type": "object" }, - "Permission": { + "ToolCall": { "properties": { - "name": { - "readOnly": true, - "type": "string", - "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." - }, - "granteeType": { - "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." - ], - "description": "Optional. Immutable. The type of the grantee.", + "toolType": { + "description": "Required. The type of tool that was called.", "type": "string", - "enum": [ - "GRANTEE_TYPE_UNSPECIFIED", - "USER", - "GROUP", - "EVERYONE" - ] - }, - "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." + "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." ], - "type": "string", "enum": [ - "ROLE_UNSPECIFIED", - "OWNER", - "WRITER", - "READER" + "TOOL_TYPE_UNSPECIFIED", + "GOOGLE_SEARCH_WEB", + "GOOGLE_SEARCH_IMAGE", + "URL_CONTEXT", + "GOOGLE_MAPS", + "FILE_SEARCH" ] }, - "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.", + "id": { + "description": "Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`.", "type": "string" - } - }, - "type": "object", - "description": "Permission resource grants user, group or the rest of the world access to the PaLM API resource (e.g. a tuned model, corpus). A role is a collection of permitted operations that allows users to perform specific actions on PaLM API resources. To make them available to users, groups, or service accounts, you assign roles. When you assign a role, you grant permissions that the role contains. There are three concentric roles. Each role is a superset of the previous role's permitted operations: - reader can use the resource (e.g. tuned model, corpus) for inference - writer has reader's permissions and additionally can edit and share - owner has writer's permissions and additionally can delete" - }, - "GroundingPassageId": { - "description": "Identifier for a part within a `GroundingPassage`.", - "type": "object", - "properties": { - "partIndex": { - "readOnly": true, - "type": "integer", - "format": "int32", - "description": "Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`." }, - "passageId": { - "readOnly": true, - "type": "string", - "description": "Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`." + "args": { + "description": "Optional. The tool call arguments. Example: {\"arg1\" : \"value1\", \"arg2\" : \"value2\" , ...}", + "type": "object", + "additionalProperties": { + "description": "Properties of the object." + } } - } + }, + "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" }, - "ComputerUse": { - "description": "Computer Use tool type.", - "type": "object", + "GenerateContentRequest": { "properties": { - "excludedPredefinedFunctions": { + "contents": { "type": "array", "items": { - "type": "string" + "$ref": "#/components/schemas/Content" }, - "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." + "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." }, - "disabledSafetyPolicies": { + "safetySettings": { + "type": "array", "items": { - "type": "string", - "enum": [ - "SAFETY_POLICY_UNSPECIFIED", - "FINANCIAL_TRANSACTIONS", - "SENSITIVE_DATA_MODIFICATION", - "COMMUNICATION_TOOL", - "ACCOUNT_CREATION", - "DATA_MODIFICATION", - "USER_CONSENT_MANAGEMENT", - "LEGAL_TERMS_AND_AGREEMENTS" - ], - "x-enum-descriptions": [ - "Unspecified safety policy.", - "Safety policy for financial transactions.", - "Safety policy for sensitive data modification.", - "Safety policy for communication tools (e.g. Gmail, Chat, Meet).", - "Safety policy for account creation.", - "Safety policy for data modification.", - "Safety policy for user consent management.", - "Safety policy for legal terms and agreements." - ] + "$ref": "#/components/schemas/SafetySetting" }, - "description": "Optional. Disabled safety policies for computer use.", - "type": "array" + "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." }, - "environment": { - "type": "string", - "enum": [ - "ENVIRONMENT_UNSPECIFIED", - "ENVIRONMENT_BROWSER", - "ENVIRONMENT_MOBILE", - "ENVIRONMENT_DESKTOP" - ], - "x-enum-descriptions": [ - "Defaults to browser.", - "Operates in a web browser.", - "Operates in a mobile environment.", - "Operates in a desktop environment." - ], - "description": "Required. The environment being operated." + "systemInstruction": { + "$ref": "#/components/schemas/Content", + "description": "Optional. Developer set [system instruction(s)](https://ai.google.dev/gemini-api/docs/system-instructions). Currently, text only." }, - "enablePromptInjectionDetection": { - "description": "Optional. Whether enable the prompt injection detection check on computer-use request.", - "type": "boolean" - } - } - }, - "InlinedEmbedContentResponse": { - "description": "The response to a single request in the batch.", - "type": "object", - "properties": { - "metadata": { - "readOnly": true, - "type": "object", - "additionalProperties": { - "description": "Properties of the object." - }, - "description": "Output only. The metadata associated with the request." + "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" }, - "error": { - "readOnly": true, - "$ref": "#/components/schemas/Status", - "description": "Output only. The error encountered while processing the request." + "store": { + "type": "boolean", + "description": "Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config." }, - "response": { - "description": "Output only. The response to the request.", - "$ref": "#/components/schemas/EmbedContentResponse", - "readOnly": true - } - } - }, - "ListPermissionsResponse": { - "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.", + "model": { + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "type": "string" }, - "permissions": { - "description": "Returned permissions.", + "tools": { + "description": "Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more.", + "type": "array", "items": { - "$ref": "#/components/schemas/Permission" - }, - "type": "array" - } - }, - "type": "object", - "description": "Response from `ListPermissions` containing a paginated list of permissions." - }, - "ToolResponse": { - "properties": { - "id": { - "description": "Optional. The identifier of the tool call this response is for.", - "type": "string" + "$ref": "#/components/schemas/Tool" + } }, - "response": { - "additionalProperties": { - "description": "Properties of the object." - }, - "type": "object", - "description": "Optional. The tool response." + "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." }, - "toolType": { - "type": "string", - "enum": [ - "TOOL_TYPE_UNSPECIFIED", - "GOOGLE_SEARCH_WEB", - "GOOGLE_SEARCH_IMAGE", - "URL_CONTEXT", - "GOOGLE_MAPS", - "FILE_SEARCH" - ], + "serviceTier": { "x-enum-descriptions": [ - "Unspecified tool type.", - "Google search tool, maps to Tool.google_search.search_types.web_search.", - "Image search tool, maps to Tool.google_search.search_types.image_search.", - "URL context tool, maps to Tool.url_context.", - "Google maps tool, maps to Tool.google_maps.", - "File search tool, maps to Tool.file_search." + "Default service tier, which is standard.", + "Standard service tier.", + "Flex service tier.", + "Priority service tier." + ], + "enum": [ + "unspecified", + "standard", + "flex", + "priority" ], - "description": "Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`." + "description": "Optional. The service tier of the request.", + "type": "string" + }, + "generationConfig": { + "description": "Optional. Configuration options for model generation and outputs.", + "$ref": "#/components/schemas/GenerationConfig" } }, - "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`." + "description": "Request to generate a completion from the model.", + "type": "object" }, "GroundingChunkStringList": { "description": "A list of string values.", @@ -4186,1486 +4116,1579 @@ "properties": { "values": { "description": "The string values of the list.", + "type": "array", "items": { "type": "string" - }, - "type": "array" - } - } - }, - "AttributionSourceId": { - "description": "Identifier for the source contributing to this attribution.", - "type": "object", - "properties": { - "groundingPassage": { - "description": "Identifier for an inline passage.", - "$ref": "#/components/schemas/GroundingPassageId" - }, - "semanticRetrieverChunk": { - "$ref": "#/components/schemas/SemanticRetrieverChunk", - "description": "Identifier for a `Chunk` fetched via Semantic Retriever." + } } } }, "FileSearchStore": { - "type": "object", "properties": { - "pendingDocumentsCount": { - "readOnly": true, - "type": "string", - "format": "int64", - "description": "Output only. The number of documents in the `FileSearchStore` that are being processed." - }, - "failedDocumentsCount": { - "readOnly": true, + "name": { "type": "string", - "format": "int64", - "description": "Output only. The number of documents in the `FileSearchStore` that have failed processing." + "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 }, "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, + "format": "int64", "type": "string", - "format": "int64" + "readOnly": true }, - "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, + "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" }, + "activeDocumentsCount": { + "type": "string", + "description": "Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.", + "format": "int64", + "readOnly": true + }, "createTime": { - "readOnly": true, "type": "string", + "description": "Output only. The Timestamp of when the `FileSearchStore` was created.", "format": "google-datetime", - "description": "Output only. The Timestamp of when the `FileSearchStore` was created." + "readOnly": true }, - "embeddingModel": { - "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" + "failedDocumentsCount": { + "description": "Output only. The number of documents in the `FileSearchStore` that have failed processing.", + "format": "int64", + "type": "string", + "readOnly": true }, - "activeDocumentsCount": { - "description": "Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.", + "pendingDocumentsCount": { "readOnly": true, "type": "string", + "description": "Output only. The number of documents in the `FileSearchStore` that are being processed.", "format": "int64" }, + "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." + }, "updateTime": { "description": "Output only. The Timestamp of when the `FileSearchStore` was last updated.", - "readOnly": true, + "format": "google-datetime", "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" + "readOnly": true } }, - "description": "A `FileSearchStore` is a collection of `Document`s." - }, - "ListDocumentsResponse": { "type": "object", - "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" - }, - "documents": { - "items": { - "$ref": "#/components/schemas/Document" - }, - "description": "The returned `Document`s.", - "type": "array" - } - }, - "description": "Response from `ListDocuments` containing a paginated list of `Document`s. The `Document`s are sorted by ascending `document.create_time`." + "description": "A `FileSearchStore` is a collection of `Document`s." }, - "InlinedResponse": { + "VoiceConfig": { "properties": { - "error": { - "readOnly": true, - "$ref": "#/components/schemas/Status", - "description": "Output only. The error encountered while processing the request." - }, - "response": { - "readOnly": true, - "$ref": "#/components/schemas/GenerateContentResponse", - "description": "Output only. The response to the request." - }, - "metadata": { - "additionalProperties": { - "description": "Properties of the object." - }, - "readOnly": true, - "type": "object", - "description": "Output only. The metadata associated with the request." + "prebuiltVoiceConfig": { + "description": "The configuration for the prebuilt voice to use.", + "$ref": "#/components/schemas/PrebuiltVoiceConfig" } }, "type": "object", - "description": "The response to a single request in the batch." + "description": "The configuration for the voice to use." }, - "ThinkingConfig": { - "type": "object", + "SpeechConfig": { "properties": { - "thinkingLevel": { - "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." - ] + "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" }, - "includeThoughts": { - "description": "Indicates whether to include thoughts in the response. If true, thoughts are returned only when available.", - "type": "boolean" + "multiSpeakerVoiceConfig": { + "$ref": "#/components/schemas/MultiSpeakerVoiceConfig", + "description": "Optional. The configuration for the multi-speaker setup. It is mutually exclusive with the voice_config field." }, - "thinkingBudget": { - "type": "integer", - "format": "int32", - "description": "The number of thoughts tokens that the model should generate." - } - }, - "description": "Config for thinking features." - }, - "TuningExamples": { - "type": "object", - "properties": { - "examples": { - "type": "array", - "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" - } + "voiceConfig": { + "description": "The configuration in case of single-voice output.", + "$ref": "#/components/schemas/VoiceConfig" } }, - "description": "A set of tuning examples. Can be training or validation data." - }, - "EmbedContentBatch": { - "description": "A resource representing a batch of `EmbedContent` requests.", "type": "object", - "properties": { - "state": { - "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" - ], - "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." - ] - }, - "name": { - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", - "readOnly": true, - "type": "string" - }, - "createTime": { - "description": "Output only. The time at which the batch was created.", - "readOnly": true, - "type": "string", - "format": "google-datetime" - }, - "inputConfig": { - "description": "Required. Input configuration of the instances on which batch processing are performed.", - "$ref": "#/components/schemas/InputEmbedContentConfig" - }, - "model": { - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", - "type": "string" - }, - "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" - }, - "batchStats": { - "readOnly": true, - "description": "Output only. Stats about the batch.", - "$ref": "#/components/schemas/EmbedContentBatchStats" - }, - "displayName": { - "description": "Required. The user-defined name of this batch.", - "type": "string" - }, - "endTime": { - "description": "Output only. The time at which the batch processing completed.", - "readOnly": true, - "type": "string", - "format": "google-datetime" - }, - "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." - } - } + "description": "Config for speech generation and transcription." }, - "CountTokensResponse": { + "InlinedResponses": { "type": "object", + "description": "The responses to the requests in the batch.", "properties": { - "promptTokensDetails": { - "readOnly": true, + "inlinedResponses": { + "description": "Output only. The responses to the requests in the batch.", "type": "array", "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - }, - "description": "Output only. List of modalities that were processed in the request input." - }, - "totalTokens": { - "type": "integer", - "format": "int32", - "description": "The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative." - }, - "cachedContentTokenCount": { - "type": "integer", - "format": "int32", - "description": "Number of tokens in the cached part of the prompt (the cached content)." - }, - "cacheTokensDetails": { - "description": "Output only. List of modalities that were processed in the cached content.", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" + "$ref": "#/components/schemas/InlinedResponse" }, - "readOnly": true, - "type": "array" + "readOnly": true } - }, - "description": "A response from `CountTokens`. It returns the model's `token_count` for the `prompt`." + } }, - "CreateFileResponse": { + "TuningExamples": { "properties": { - "file": { - "$ref": "#/components/schemas/File", - "description": "Metadata for the created file." + "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", - "description": "Response for `CreateFile`." + "description": "A set of tuning examples. Can be training or validation data." }, - "File": { - "description": "A file uploaded to the API. Next ID: 15", + "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": { - "createTime": { - "readOnly": true, - "type": "string", - "format": "google-datetime", - "description": "Output only. The timestamp of when the `File` was created." + "latitude": { + "description": "The latitude in degrees. It must be in the range [-90.0, +90.0].", + "format": "double", + "type": "number" + }, + "longitude": { + "description": "The longitude in degrees. It must be in the range [-180.0, +180.0].", + "format": "double", + "type": "number" + } + } + }, + "FunctionResponse": { + "type": "object", + "description": "The result output from a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model. This should contain the result of a`FunctionCall` made based on model prediction.", + "properties": { + "parts": { + "type": "array", + "items": { + "$ref": "#/components/schemas/FunctionResponsePart" + }, + "description": "Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types." + }, + "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`." }, "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`", + "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" }, - "source": { - "description": "Source of the File.", + "response": { + "type": "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. Multimedia can be included by using a subobject containing a single \"$ref\" key whose value is the `inline_data.display_name` of a `FunctionResponsePart` holding the multimedia. See https://ai.google.dev/gemini-api/docs/function-calling#multimodal.", + "additionalProperties": { + "description": "Properties of the object." + } + }, + "scheduling": { + "description": "Optional. Specifies how the response should be scheduled in the conversation. Only applicable to NON_BLOCKING function calls, is ignored otherwise. Defaults to WHEN_IDLE.", + "type": "string", "x-enum-descriptions": [ - "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." + "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." ], - "type": "string", "enum": [ - "SOURCE_UNSPECIFIED", - "UPLOADED", - "GENERATED", - "REGISTERED" + "SCHEDULING_UNSPECIFIED", + "SILENT", + "WHEN_IDLE", + "INTERRUPT" ] }, - "downloadUri": { - "description": "Output only. The download uri of the `File`.", - "readOnly": true, - "type": "string" + "id": { + "type": "string", + "description": "Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`." + } + } + }, + "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).", + "type": "object", + "properties": { + "enum": { + "description": "Optional. Possible values of the element of Type.STRING with enum format. For example we can define an Enum Direction as : {type:STRING, format:enum, enum:[\"EAST\", NORTH\", \"SOUTH\", \"WEST\"]}", + "type": "array", + "items": { + "type": "string" + } }, - "videoMetadata": { - "description": "Output only. Metadata for a video.", - "$ref": "#/components/schemas/VideoFileMetadata", - "readOnly": true + "example": { + "description": "Optional. Example of the object. Will only populated when the object is the root." }, - "expirationTime": { - "readOnly": true, + "properties": { + "description": "Optional. Properties of Type.OBJECT.", + "type": "object", + "additionalProperties": { + "$ref": "#/components/schemas/Schema" + } + }, + "pattern": { "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." + "description": "Optional. Pattern of the Type.STRING to restrict a string to a regular expression." }, - "displayName": { - "description": "Optional. The human-readable display name for the `File`. The display name must be no more than 512 characters in length, including spaces. Example: \"Welcome Image\"", - "type": "string" + "anyOf": { + "type": "array", + "items": { + "$ref": "#/components/schemas/Schema" + }, + "description": "Optional. The value should be validated against any (one or more) of the subschemas in the list." }, - "updateTime": { - "description": "Output only. The timestamp of when the `File` was last updated.", - "readOnly": true, + "description": { "type": "string", - "format": "google-datetime" + "description": "Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown." }, - "error": { - "readOnly": true, - "description": "Output only. Error status if File processing failed.", - "$ref": "#/components/schemas/Status" + "required": { + "type": "array", + "items": { + "type": "string" + }, + "description": "Optional. Required properties of Type.OBJECT." }, - "state": { - "readOnly": true, + "type": { + "type": "string", + "description": "Required. Data type.", "enum": [ - "STATE_UNSPECIFIED", - "PROCESSING", - "ACTIVE", - "FAILED" + "TYPE_UNSPECIFIED", + "STRING", + "NUMBER", + "INTEGER", + "BOOLEAN", + "ARRAY", + "OBJECT", + "NULL" ], - "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." - ], - "type": "string" + "Not specified, should not be used.", + "String type.", + "Number type.", + "Integer type.", + "Boolean type.", + "Array type.", + "Object type.", + "Null type." + ] }, - "sizeBytes": { - "readOnly": true, - "type": "string", + "items": { + "$ref": "#/components/schemas/Schema", + "description": "Optional. Schema of the elements of Type.ARRAY." + }, + "minItems": { + "description": "Optional. Minimum number of the elements for Type.ARRAY.", "format": "int64", - "description": "Output only. Size of the file in bytes." + "type": "string" }, - "uri": { - "readOnly": true, - "type": "string", - "description": "Output only. The uri of the `File`." + "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." }, - "sha256Hash": { - "readOnly": true, + "maxLength": { "type": "string", - "format": "byte", - "description": "Output only. SHA-256 hash of the uploaded bytes." + "description": "Optional. Maximum length of the Type.STRING", + "format": "int64" }, - "mimeType": { - "description": "Output only. MIME type of the file.", - "readOnly": true, - "type": "string" - } - }, - "type": "object" - }, - "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.", - "type": "object", - "properties": { - "probability": { + "maxItems": { "type": "string", - "enum": [ - "HARM_PROBABILITY_UNSPECIFIED", - "NEGLIGIBLE", - "LOW", - "MEDIUM", - "HIGH" - ], - "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." - ] + "description": "Optional. Maximum number of the elements for Type.ARRAY.", + "format": "int64" }, - "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." - ], - "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" - ], + "maxProperties": { "type": "string", - "enumDeprecated": [ - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - true - ] + "description": "Optional. Maximum number of the properties for Type.OBJECT.", + "format": "int64" + }, + "propertyOrdering": { + "description": "Optional. The order of the properties. Not a standard field in open api spec. Used to determine the order of the properties in the response.", + "type": "array", + "items": { + "type": "string" + } }, - "blocked": { - "description": "Was this content blocked because of this rating?", + "maximum": { + "type": "number", + "description": "Optional. Maximum value of the Type.INTEGER and Type.NUMBER", + "format": "double" + }, + "minProperties": { + "type": "string", + "description": "Optional. Minimum number of the properties for Type.OBJECT.", + "format": "int64" + }, + "nullable": { + "description": "Optional. Indicates if the value may be null.", "type": "boolean" + }, + "minLength": { + "type": "string", + "description": "Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING", + "format": "int64" + }, + "format": { + "type": "string", + "description": "Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality." + }, + "minimum": { + "description": "Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER", + "format": "double", + "type": "number" + }, + "title": { + "type": "string", + "description": "Optional. The title of the schema." } } }, - "CreateFileRequest": { - "description": "Request for `CreateFile`.", + "FunctionResponseBlob": { + "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" + }, + "data": { + "type": "string", + "description": "Raw bytes for media formats.", + "format": "byte" + } + }, "type": "object", + "description": "Raw media bytes for function response. Text should not be sent as raw bytes, use the 'FunctionResponse.response' field." + }, + "InlinedEmbedContentResponse": { "properties": { - "file": { - "description": "Optional. Metadata for the file to create.", - "$ref": "#/components/schemas/File" + "metadata": { + "readOnly": true, + "additionalProperties": { + "description": "Properties of the object." + }, + "description": "Output only. The metadata associated with the request.", + "type": "object" + }, + "error": { + "description": "Output only. The error encountered while processing the request.", + "$ref": "#/components/schemas/Status", + "readOnly": true + }, + "response": { + "readOnly": true, + "$ref": "#/components/schemas/EmbedContentResponse", + "description": "Output only. The response to the request." } - } + }, + "type": "object", + "description": "The response to a single request in the batch." }, - "FunctionCallingConfig": { - "description": "Configuration for specifying function calling behavior.", + "CustomMetadata": { "properties": { - "mode": { - "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\"." - ], + "stringValue": { "type": "string", - "enum": [ - "MODE_UNSPECIFIED", - "AUTO", - "ANY", - "NONE", - "VALIDATED" - ] + "description": "The string value of the metadata to store." }, - "allowedFunctionNames": { - "type": "array", - "items": { - "type": "string" - }, - "description": "Optional. A set of function names that, when provided, limits the functions the model will call. This should only be set when the Mode is ANY or VALIDATED. Function names should match [FunctionDeclaration.name]. When set, model will predict a function call from only allowed function names." + "key": { + "description": "Required. The key of the metadata to store.", + "type": "string" + }, + "stringListValue": { + "description": "The StringList value of the metadata to store.", + "$ref": "#/components/schemas/StringList" + }, + "numericValue": { + "type": "number", + "description": "The numeric value of the metadata to store.", + "format": "float" } }, + "description": "User provided metadata stored as key-value pairs.", "type": "object" }, - "TunedModelSource": { - "description": "Tuned model as a source for training a new model.", - "type": "object", + "TuningSnapshot": { "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" + "epoch": { + "readOnly": true, + "description": "Output only. The epoch this step was part of.", + "format": "int32", + "type": "integer" }, - "baseModel": { - "description": "Output only. The name of the base `Model` this `TunedModel` was tuned from. Example: `models/gemini-1.5-flash-001`", + "meanLoss": { "readOnly": true, - "type": "string" + "type": "number", + "description": "Output only. The mean loss of the training examples for this step.", + "format": "float" + }, + "step": { + "readOnly": true, + "type": "integer", + "description": "Output only. The tuning step.", + "format": "int32" + }, + "computeTime": { + "readOnly": true, + "type": "string", + "description": "Output only. The timestamp when this metric was computed.", + "format": "google-datetime" } - } + }, + "type": "object", + "description": "Record for a single tuning step." }, - "FileSearch": { + "RetrievedContext": { "properties": { - "metadataFilter": { - "description": "Optional. Metadata filter to apply to the semantic retrieval documents and chunks.", + "title": { + "description": "Optional. Title of the document.", "type": "string" }, - "topK": { - "type": "integer", + "pageNumber": { + "description": "Optional. Page number of the retrieved context, if applicable.", "format": "int32", - "description": "Optional. The number of semantic retrieval chunks to retrieve." + "type": "integer" }, - "fileSearchStoreNames": { + "uri": { + "type": "string", + "description": "Optional. URI reference of the semantic retrieval document." + }, + "text": { + "description": "Optional. Text of the chunk.", + "type": "string" + }, + "fileSearchStore": { + "description": "Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123`", + "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": { - "type": "string" - }, - "description": "Required. The names of the file_search_stores to retrieve from. Example: `fileSearchStores/my-file-search-store-123`" + "$ref": "#/components/schemas/GroundingChunkCustomMetadata" + } } }, "type": "object", - "description": "The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API." + "description": "Chunk from context retrieved by the file search tool." }, - "RegisterFilesRequest": { - "description": "Request for `RegisterFiles`.", + "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": { - "uris": { + "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" + }, + "contents": { + "description": "Optional. The input given to the model as a prompt. This field is ignored when `generate_content_request` is set.", "type": "array", - "description": "Required. The Google Cloud Storage URIs to register. Example: `gs://bucket/object`.", "items": { - "type": "string" + "$ref": "#/components/schemas/Content" } } - }, - "type": "object" + } }, - "CachedContentUsageMetadata": { + "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": { - "totalTokenCount": { - "type": "integer", - "format": "int32", - "description": "Total number of tokens that the cached content consumes." + "googleSearchRetrieval": { + "description": "Optional. Retrieval tool that is powered by Google search.", + "$ref": "#/components/schemas/GoogleSearchRetrieval" + }, + "mcpServers": { + "description": "Optional. MCP Servers to connect to.", + "type": "array", + "items": { + "$ref": "#/components/schemas/McpServer" + } + }, + "googleSearch": { + "description": "Optional. GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google.", + "$ref": "#/components/schemas/GoogleSearch" + }, + "urlContext": { + "description": "Optional. Tool to support URL context retrieval.", + "$ref": "#/components/schemas/UrlContext" + }, + "googleMaps": { + "description": "Optional. Tool that allows grounding the model's response with geospatial context related to the user's query.", + "$ref": "#/components/schemas/GoogleMaps" + }, + "functionDeclarations": { + "description": "Optional. A list of `FunctionDeclarations` available to the model that can be used for function calling. The model or system does not execute the function. Instead the defined function may be returned as a FunctionCall with arguments to the client side for execution. The model may decide to call a subset of these functions by populating FunctionCall in the response. The next conversation turn may contain a FunctionResponse with the Content.role \"function\" generation context for the next model turn.", + "type": "array", + "items": { + "$ref": "#/components/schemas/FunctionDeclaration" + } + }, + "computerUse": { + "$ref": "#/components/schemas/ComputerUse", + "description": "Optional. Tool to support the model interacting directly with the computer. If enabled, it automatically populates computer-use specific Function Declarations." + }, + "codeExecution": { + "$ref": "#/components/schemas/CodeExecution", + "description": "Optional. Enables the model to execute code as part of generation." + }, + "fileSearch": { + "$ref": "#/components/schemas/FileSearch", + "description": "Optional. FileSearch tool type. Tool to retrieve knowledge from Semantic Retrieval corpora." + } + } + }, + "PromptFeedback": { + "description": "A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`.", + "type": "object", + "properties": { + "blockReason": { + "description": "Optional. If set, the prompt was blocked and no candidates are returned. Rephrase the prompt.", + "type": "string", + "x-enum-descriptions": [ + "Default value. This value is unused.", + "Prompt was blocked due to safety reasons. Inspect `safety_ratings` to understand which safety category blocked it.", + "Prompt was blocked due to unknown reasons.", + "Prompt was blocked due to the terms which are included from the terminology blocklist.", + "Prompt was blocked due to prohibited content.", + "Candidates blocked due to unsafe image generation content." + ], + "enum": [ + "BLOCK_REASON_UNSPECIFIED", + "SAFETY", + "OTHER", + "BLOCKLIST", + "PROHIBITED_CONTENT", + "IMAGE_SAFETY" + ] + }, + "safetyRatings": { + "description": "Ratings for safety of the prompt. There is at most one rating per category.", + "type": "array", + "items": { + "$ref": "#/components/schemas/SafetyRating" + } + } + } + }, + "AttributionSourceId": { + "properties": { + "semanticRetrieverChunk": { + "description": "Identifier for a `Chunk` fetched via Semantic Retriever.", + "$ref": "#/components/schemas/SemanticRetrieverChunk" + }, + "groundingPassage": { + "$ref": "#/components/schemas/GroundingPassageId", + "description": "Identifier for an inline passage." } }, - "description": "Metadata on the usage of the cached content." + "type": "object", + "description": "Identifier for the source contributing to this attribution." }, - "InputEmbedContentConfig": { + "ListDocumentsResponse": { "type": "object", + "description": "Response from `ListDocuments` containing a paginated list of `Document`s. The `Document`s are sorted by ascending `document.create_time`.", "properties": { - "fileName": { - "description": "The name of the `File` containing the input requests.", - "type": "string" + "documents": { + "description": "The returned `Document`s.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Document" + } }, - "requests": { - "$ref": "#/components/schemas/InlinedEmbedContentRequests", - "description": "The requests to be processed in the batch." + "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" } - }, - "description": "Configures the input to the batch request." + } }, - "InlinedEmbedContentRequests": { - "type": "object", + "RegisterFilesResponse": { "properties": { - "requests": { - "description": "Required. The requests to be processed in the batch.", + "files": { + "description": "The registered files to be used when calling GenerateContent.", + "type": "array", "items": { - "$ref": "#/components/schemas/InlinedEmbedContentRequest" - }, - "type": "array" + "$ref": "#/components/schemas/File" + } } }, - "description": "The requests to be processed in the batch if provided as part of the batch creation request." + "type": "object", + "description": "Response for `RegisterFiles`." }, - "CustomMetadata": { - "description": "User provided metadata stored as key-value pairs.", + "GoogleMaps": { "type": "object", + "description": "The GoogleMaps Tool that provides geospatial context for the user's query.", "properties": { - "key": { - "description": "Required. The key of the metadata to store.", - "type": "string" - }, - "stringValue": { - "description": "The string value of the metadata to store.", - "type": "string" - }, - "stringListValue": { - "$ref": "#/components/schemas/StringList", - "description": "The StringList value of the metadata to store." - }, - "numericValue": { - "type": "number", - "format": "float", - "description": "The numeric value of the metadata to store." + "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" } } }, - "InlinedRequests": { + "VideoFileMetadata": { "type": "object", + "description": "Metadata for a video `File`.", "properties": { - "requests": { - "description": "Required. The requests to be processed in the batch.", - "items": { - "$ref": "#/components/schemas/InlinedRequest" - }, - "type": "array" + "videoDuration": { + "description": "Duration of the video.", + "format": "google-duration", + "type": "string" } - }, - "description": "The requests to be processed in the batch if provided as part of the batch creation request." + } }, "GoogleSearch": { + "type": "object", "description": "GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google.", "properties": { "timeRangeFilter": { - "description": "Optional. Filter search results to a specific time range. If customers set a start time, they must set an end time (and vice versa).", - "$ref": "#/components/schemas/Interval" + "$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": { - "$ref": "#/components/schemas/SearchTypes", - "description": "Optional. The set of search types to enable. If not set, web search is enabled by default." + "description": "Optional. The set of search types to enable. If not set, web search is enabled by default.", + "$ref": "#/components/schemas/SearchTypes" } - }, - "type": "object" + } }, - "InlinedEmbedContentRequest": { + "CreateFileResponse": { "properties": { - "request": { - "description": "Required. The request to be processed in the batch.", - "$ref": "#/components/schemas/EmbedContentRequest" - }, - "metadata": { - "additionalProperties": { - "description": "Properties of the object." - }, - "type": "object", - "description": "Optional. The metadata to be associated with the request." + "file": { + "$ref": "#/components/schemas/File", + "description": "Metadata for the created file." } }, "type": "object", - "description": "The request to be processed in the batch." + "description": "Response for `CreateFile`." }, - "Tool": { + "EmbedContentBatch": { + "description": "A resource representing a batch of `EmbedContent` requests.", + "type": "object", "properties": { - "urlContext": { - "description": "Optional. Tool to support URL context retrieval.", - "$ref": "#/components/schemas/UrlContext" + "inputConfig": { + "$ref": "#/components/schemas/InputEmbedContentConfig", + "description": "Required. Input configuration of the instances on which batch processing are performed." }, - "googleSearch": { - "$ref": "#/components/schemas/GoogleSearch", - "description": "Optional. GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google." + "displayName": { + "description": "Required. The user-defined name of this batch.", + "type": "string" }, - "googleMaps": { - "$ref": "#/components/schemas/GoogleMaps", - "description": "Optional. Tool that allows grounding the model's response with geospatial context related to the user's query." + "createTime": { + "type": "string", + "description": "Output only. The time at which the batch was created.", + "format": "google-datetime", + "readOnly": true }, - "fileSearch": { - "description": "Optional. FileSearch tool type. Tool to retrieve knowledge from Semantic Retrieval corpora.", - "$ref": "#/components/schemas/FileSearch" + "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" }, - "functionDeclarations": { - "description": "Optional. A list of `FunctionDeclarations` available to the model that can be used for function calling. The model or system does not execute the function. Instead the defined function may be returned as a FunctionCall with arguments to the client side for execution. The model may decide to call a subset of these functions by populating FunctionCall in the response. The next conversation turn may contain a FunctionResponse with the Content.role \"function\" generation context for the next model turn.", - "items": { - "$ref": "#/components/schemas/FunctionDeclaration" - }, - "type": "array" + "name": { + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", + "type": "string", + "readOnly": true }, - "googleSearchRetrieval": { - "$ref": "#/components/schemas/GoogleSearchRetrieval", - "description": "Optional. Retrieval tool that is powered by Google search." + "batchStats": { + "description": "Output only. Stats about the batch.", + "readOnly": true, + "$ref": "#/components/schemas/EmbedContentBatchStats" }, - "codeExecution": { - "description": "Optional. Enables the model to execute code as part of generation.", - "$ref": "#/components/schemas/CodeExecution" + "updateTime": { + "description": "Output only. The time at which the batch was last updated.", + "format": "google-datetime", + "type": "string", + "readOnly": true }, - "mcpServers": { - "type": "array", - "items": { - "$ref": "#/components/schemas/McpServer" - }, - "description": "Optional. MCP Servers to connect to." + "endTime": { + "description": "Output only. The time at which the batch processing completed.", + "format": "google-datetime", + "type": "string", + "readOnly": true }, - "computerUse": { - "$ref": "#/components/schemas/ComputerUse", - "description": "Optional. Tool to support the model interacting directly with the computer. If enabled, it automatically populates computer-use specific Function Declarations." + "model": { + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "type": "string" + }, + "state": { + "description": "Output only. The state of the batch.", + "enum": [ + "BATCH_STATE_UNSPECIFIED", + "BATCH_STATE_PENDING", + "BATCH_STATE_RUNNING", + "BATCH_STATE_SUCCEEDED", + "BATCH_STATE_FAILED", + "BATCH_STATE_CANCELLED", + "BATCH_STATE_EXPIRED" + ], + "type": "string", + "readOnly": true, + "x-enum-descriptions": [ + "The batch state is unspecified.", + "The service is preparing to run the batch.", + "The batch is in progress.", + "The batch completed successfully.", + "The batch failed.", + "The batch has been cancelled.", + "The batch has expired." + ] + }, + "output": { + "description": "Output only. The output of the batch request.", + "readOnly": true, + "$ref": "#/components/schemas/EmbedContentBatchOutput" } - }, - "type": "object", - "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" + } }, - "Blob": { + "TextResponseFormat": { + "description": "Configuration for text output format.", "type": "object", "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). //", + "x-enum-descriptions": [ + "Default value. This value is unused.", + "JSON output format.", + "Plain text output format." + ], + "enum": [ + "MIME_TYPE_UNSPECIFIED", + "APPLICATION_JSON", + "TEXT_PLAIN" + ], + "description": "Optional. The MIME type of the text output.", "type": "string" }, - "data": { - "description": "Raw bytes for media formats.", - "type": "string", - "format": "byte" + "schema": { + "description": "Optional. The JSON schema that the output should conform to. Only applicable when mime_type is APPLICATION_JSON." } - }, - "description": "Raw media bytes. Text should not be sent as raw bytes, use the 'text' field." + } }, - "Candidate": { - "description": "A response candidate generated from the model.", - "type": "object", + "TunedModel": { "properties": { - "citationMetadata": { + "createTime": { "readOnly": true, - "$ref": "#/components/schemas/CitationMetadata", - "description": "Output only. Citation information for model-generated candidate. This field may be populated with recitation information for any text included in the `content`. These are passages that are \"recited\" from copyrighted material in the foundational LLM's training data." + "type": "string", + "description": "Output only. The timestamp when this model was created.", + "format": "google-datetime" }, - "groundingMetadata": { - "readOnly": true, - "description": "Output only. Grounding metadata for the candidate. This field is populated for `GenerateContent` calls.", - "$ref": "#/components/schemas/GroundingMetadata" + "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" }, - "urlContextMetadata": { - "description": "Output only. Metadata related to url context retrieval tool.", - "$ref": "#/components/schemas/UrlContextMetadata", + "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`", + "type": "string", "readOnly": true }, - "groundingAttributions": { - "readOnly": true, - "type": "array", - "items": { - "$ref": "#/components/schemas/GroundingAttribution" - }, - "description": "Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls." + "topK": { + "type": "integer", + "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.", + "format": "int32" }, - "avgLogprobs": { - "description": "Output only. Average log probability score of the candidate.", + "updateTime": { "readOnly": true, - "type": "number", - "format": "double" + "type": "string", + "description": "Output only. The timestamp when this model was updated.", + "format": "google-datetime" }, - "finishReason": { - "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.", - "Request was filtered by an escalation rule." + "state": { + "enum": [ + "STATE_UNSPECIFIED", + "CREATING", + "ACTIVE", + "FAILED" ], + "description": "Output only. The state of the tuned model.", "readOnly": true, - "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", - "ESCALATION" + "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." ], "type": "string" }, - "safetyRatings": { + "readerProjectNumbers": { + "type": "array", "items": { - "$ref": "#/components/schemas/SafetyRating" + "format": "int64", + "type": "string" }, - "description": "List of ratings for the safety of a response candidate. There is at most one rating per category.", - "type": "array" + "description": "Optional. List of project numbers that have read access to the tuned model." }, - "index": { - "readOnly": true, - "type": "integer", - "format": "int32", - "description": "Output only. Index of the candidate in the list of response candidates." + "baseModel": { + "description": "Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001`", + "type": "string" }, - "finishMessage": { - "description": "Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.", - "readOnly": true, + "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" }, - "content": { - "readOnly": true, - "$ref": "#/components/schemas/Content", - "description": "Output only. Generated content returned from the model." + "tuningTask": { + "description": "Required. The tuning task that creates the tuned model.", + "$ref": "#/components/schemas/TuningTask" }, - "logprobsResult": { - "description": "Output only. Log-likelihood scores for the response tokens and top tokens", - "$ref": "#/components/schemas/LogprobsResult", - "readOnly": true + "temperature": { + "type": "number", + "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" }, - "tokenCount": { - "description": "Output only. Token count for this candidate.", - "readOnly": true, - "type": "integer", - "format": "int32" + "tunedModelSource": { + "description": "Optional. TunedModel to use as the starting point for training the new model.", + "$ref": "#/components/schemas/TunedModelSource" + }, + "description": { + "type": "string", + "description": "Optional. A short description of this model." } - } + }, + "type": "object", + "description": "A fine-tuned model created using ModelService.CreateTunedModel." }, - "InputConfig": { + "RetrievalConfig": { "type": "object", + "description": "Retrieval config.", "properties": { - "fileName": { - "description": "The name of the `File` containing the input requests.", + "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" + } + } + }, + "ImageConfig": { + "properties": { + "aspectRatio": { + "type": "string", + "description": "Optional. The aspect ratio of the image to generate. Supported aspect ratios: `1:1`, `1:4`, `4:1`, `1:8`, `8:1`, `2:3`, `3:2`, `3:4`, `4:3`, `4:5`, `5:4`, `9:16`, `16:9`, or `21:9`. If not specified, the model will choose a default aspect ratio based on any reference images provided." }, - "requests": { - "description": "The requests to be processed in the batch.", - "$ref": "#/components/schemas/InlinedRequests" + "imageSize": { + "description": "Optional. Specifies the size of generated images. Supported values are `512`, `1K`, `2K`, `4K`. If not specified, the model will use default value `1K`.", + "type": "string" } }, - "description": "Configures the input to the batch request." - }, - "InlinedEmbedContentResponses": { "type": "object", + "description": "Config for image generation features." + }, + "BatchEmbedContentsResponse": { "properties": { - "inlinedResponses": { - "readOnly": true, + "embeddings": { + "description": "Output only. The embeddings for each request, in the same order as provided in the batch request.", "type": "array", "items": { - "$ref": "#/components/schemas/InlinedEmbedContentResponse" + "$ref": "#/components/schemas/ContentEmbedding" }, - "description": "Output only. The responses to the requests in the batch." + "readOnly": true + }, + "usageMetadata": { + "$ref": "#/components/schemas/EmbeddingUsageMetadata", + "readOnly": true, + "description": "Output only. The usage metadata for the request." } }, - "description": "The responses to the requests in the batch." + "description": "The response to a `BatchEmbedContentsRequest`.", + "type": "object" }, - "MultiSpeakerVoiceConfig": { - "description": "The configuration for the multi-speaker setup.", + "ExecutableCode": { "properties": { - "speakerVoiceConfigs": { - "description": "Required. All the enabled speaker voices.", - "items": { - "$ref": "#/components/schemas/SpeakerVoiceConfig" - }, - "type": "array" + "id": { + "type": "string", + "description": "Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`." + }, + "code": { + "description": "Required. The code to be executed.", + "type": "string" + }, + "language": { + "type": "string", + "description": "Required. Programming language of the `code`.", + "enum": [ + "LANGUAGE_UNSPECIFIED", + "PYTHON" + ], + "x-enum-descriptions": [ + "Unspecified language. This value should not be used.", + "Python >= 3.10, with numpy and simpy available. Python is the default language." + ] } }, + "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" }, - "BatchEmbedContentsResponse": { + "WebSearch": { "type": "object", + "description": "Standard web search for grounding and related configurations.", + "properties": {} + }, + "FunctionResponsePart": { "properties": { - "usageMetadata": { - "readOnly": true, - "description": "Output only. The usage metadata for the request.", - "$ref": "#/components/schemas/EmbeddingUsageMetadata" - }, - "embeddings": { - "description": "Output only. The embeddings for each request, in the same order as provided in the batch request.", - "items": { - "$ref": "#/components/schemas/ContentEmbedding" - }, - "readOnly": true, - "type": "array" + "inlineData": { + "description": "Inline media bytes.", + "$ref": "#/components/schemas/FunctionResponseBlob" } }, - "description": "The response to a `BatchEmbedContentsRequest`." + "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." }, - "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`.", + "InlinedEmbedContentRequests": { "type": "object", + "description": "The requests to be processed in the batch if provided as part of the batch creation request.", "properties": { - "usageMetadata": { - "$ref": "#/components/schemas/UsageMetadata", - "description": "Output only. Metadata on the generation requests' token usage.", - "readOnly": true - }, - "responseId": { - "readOnly": true, - "type": "string", - "description": "Output only. response_id is used to identify each response." - }, - "promptFeedback": { - "description": "Returns the prompt's feedback related to the content filters.", - "$ref": "#/components/schemas/PromptFeedback" - }, - "candidates": { + "requests": { "type": "array", - "description": "Candidate responses from the model.", "items": { - "$ref": "#/components/schemas/Candidate" - } - }, - "modelStatus": { - "readOnly": true, - "description": "Output only. The current model status of this model.", - "$ref": "#/components/schemas/ModelStatus" - }, - "modelVersion": { - "readOnly": true, - "type": "string", - "description": "Output only. The model version used to generate the response." + "$ref": "#/components/schemas/InlinedEmbedContentRequest" + }, + "description": "Required. The requests to be processed in the batch." } } }, - "TranslationConfig": { - "type": "object", + "ListTunedModelsResponse": { "properties": { - "targetLanguageCode": { - "description": "Required. The target language for translation. Supported values are BCP-47 language codes (e.g. \"en\", \"es\", \"fr\").", - "type": "string" + "tunedModels": { + "type": "array", + "items": { + "$ref": "#/components/schemas/TunedModel" + }, + "description": "The returned Models." }, - "echoTargetLanguage": { - "description": "Optional. If true, the model will generate audio when the target language is spoken, essentially it will parrot the input. If false, we will not produce audio for the target language.", - "type": "boolean" + "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": "Config for translation features." + "description": "Response from `ListTunedModels` containing a paginated list of Models.", + "type": "object" }, - "FunctionResponsePart": { - "description": "A datatype containing media that is part of a `FunctionResponse` message. A `FunctionResponsePart` consists of data which has an associated datatype. A `FunctionResponsePart` can only contain one of the accepted types in `FunctionResponsePart.data`. A `FunctionResponsePart` must have a fixed IANA MIME type identifying the type and subtype of the media if the `inline_data` field is filled with raw bytes.", - "type": "object", + "Status": { "properties": { - "inlineData": { - "description": "Inline media bytes.", - "$ref": "#/components/schemas/FunctionResponseBlob" + "code": { + "type": "integer", + "description": "The status code, which should be an enum value of google.rpc.Code.", + "format": "int32" + }, + "message": { + "type": "string", + "description": "A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client." + }, + "details": { + "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use.", + "type": "array", + "items": { + "type": "object", + "additionalProperties": { + "description": "Properties of the object. Contains field @type with type URL." + } + } } - } + }, + "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)." }, - "GenerateContentBatch": { - "description": "A resource representing a batch of `GenerateContent` requests.", + "Permission": { + "type": "object", + "description": "Permission resource grants user, group or the rest of the world access to the PaLM API resource (e.g. a tuned model, corpus). A role is a collection of permitted operations that allows users to perform specific actions on PaLM API resources. To make them available to users, groups, or service accounts, you assign roles. When you assign a role, you grant permissions that the role contains. There are three concentric roles. Each role is a superset of the previous role's permitted operations: - reader can use the resource (e.g. tuned model, corpus) for inference - writer has reader's permissions and additionally can edit and share - owner has writer's permissions and additionally can delete", "properties": { - "state": { - "x-enum-descriptions": [ - "The batch state is unspecified.", - "The service is preparing to run the batch.", - "The batch is in progress.", - "The batch completed successfully.", - "The batch failed.", - "The batch has been cancelled.", - "The batch has expired." - ], - "description": "Output only. The state of the batch.", - "readOnly": true, + "granteeType": { "enum": [ - "BATCH_STATE_UNSPECIFIED", - "BATCH_STATE_PENDING", - "BATCH_STATE_RUNNING", - "BATCH_STATE_SUCCEEDED", - "BATCH_STATE_FAILED", - "BATCH_STATE_CANCELLED", - "BATCH_STATE_EXPIRED" + "GRANTEE_TYPE_UNSPECIFIED", + "USER", + "GROUP", + "EVERYONE" ], - "type": "string" - }, - "inputConfig": { - "description": "Required. Input configuration of the instances on which batch processing are performed.", - "$ref": "#/components/schemas/InputConfig" + "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." + ], + "type": "string", + "description": "Optional. Immutable. The type of the grantee." }, "name": { "readOnly": true, + "description": "Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.", + "type": "string" + }, + "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." + }, + "role": { "type": "string", - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`." + "description": "Required. The role granted by this permission.", + "enum": [ + "ROLE_UNSPECIFIED", + "OWNER", + "WRITER", + "READER" + ], + "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." + ] + } + } + }, + "ContentEmbedding": { + "properties": { + "values": { + "description": "The embedding values. This is for 3P users only and will not be populated for 1P calls.", + "type": "array", + "items": { + "format": "float", + "type": "number" + } }, + "shape": { + "type": "array", + "items": { + "type": "integer", + "format": "int32" + }, + "description": "This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048])." + } + }, + "type": "object", + "description": "A list of floats representing an embedding." + }, + "Corpus": { + "properties": { "createTime": { "readOnly": true, - "type": "string", + "description": "Output only. The Timestamp of when the `Corpus` was created.", "format": "google-datetime", - "description": "Output only. The time at which the batch was created." + "type": "string" }, - "output": { + "name": { "readOnly": true, - "description": "Output only. The output of the batch request.", - "$ref": "#/components/schemas/GenerateContentBatchOutput" - }, - "model": { - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "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`", "type": "string" }, - "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.", + "displayName": { "type": "string", - "format": "int64" + "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\"" }, "updateTime": { - "readOnly": true, - "type": "string", + "description": "Output only. The Timestamp of when the `Corpus` was last updated.", "format": "google-datetime", - "description": "Output only. The time at which the batch was last updated." - }, - "batchStats": { - "readOnly": true, - "description": "Output only. Stats about the batch.", - "$ref": "#/components/schemas/BatchStats" - }, - "displayName": { - "description": "Required. The user-defined name of this batch.", - "type": "string" - }, - "endTime": { - "description": "Output only. The time at which the batch processing completed.", - "readOnly": true, "type": "string", - "format": "google-datetime" + "readOnly": true } }, - "type": "object" - }, - "WhiteSpaceConfig": { "type": "object", - "properties": { - "maxOverlapTokens": { - "description": "Maximum number of overlapping tokens between two adjacent chunks.", - "type": "integer", - "format": "int32" - }, - "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" - } - }, - "description": "Configuration for a white space chunking algorithm [white space delimited]." + "description": "A `Corpus` is a collection of `Document`s. A project can create up to 10 corpora." }, "LogprobsResultCandidate": { - "type": "object", "properties": { - "token": { - "description": "The candidate\u2019s token string value.", - "type": "string" + "tokenId": { + "description": "The candidate\u2019s token id value.", + "format": "int32", + "type": "integer" }, "logProbability": { - "description": "The candidate's log probability.", "type": "number", + "description": "The candidate's log probability.", "format": "float" }, - "tokenId": { - "type": "integer", - "format": "int32", - "description": "The candidate\u2019s token id value." + "token": { + "type": "string", + "description": "The candidate\u2019s token string value." } }, + "type": "object", "description": "Candidate for the logprobs token and score." }, - "FileData": { - "description": "URI based data.", + "GenerateContentBatchOutput": { "properties": { - "mimeType": { - "description": "Optional. The IANA standard MIME type of the source data.", - "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/InlinedResponses", + "readOnly": true }, - "fileUri": { - "description": "Required. URI.", - "type": "string" + "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." } }, + "description": "The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field.", "type": "object" }, - "Model": { - "description": "Information about a Generative Language Model.", + "Image": { "properties": { - "version": { - "description": "Required. The version number of the model. This represents the major version (`1.0` or `1.5`)", - "type": "string" - }, - "inputTokenLimit": { - "type": "integer", - "format": "int32", - "description": "Maximum number of input tokens allowed for this model." - }, - "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." - }, - "outputTokenLimit": { - "description": "Maximum number of output tokens available for this model.", - "type": "integer", - "format": "int32" - }, - "supportedGenerationMethods": { - "type": "array", - "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" - } - }, - "description": { - "description": "A short description of the model.", - "type": "string" - }, - "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" - }, - "thinking": { - "description": "Whether the model supports thinking.", - "type": "boolean" + "sourceUri": { + "type": "string", + "description": "The web page URI for attribution." }, - "baseModelId": { - "description": "Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash`", - "type": "string" + "title": { + "type": "string", + "description": "The title of the web page that the image is from." }, - "temperature": { - "type": "number", - "format": "float", - "description": "Controls the randomness of the output. Values can range over `[0.0,max_temperature]`, inclusive. A higher value will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be used by the backend while making the call to the model." + "imageUri": { + "type": "string", + "description": "The image asset URL." }, - "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`", + "domain": { + "description": "The root domain of the web page that the image is from, e.g. \"example.com\".", "type": "string" - }, - "maxTemperature": { - "type": "number", - "format": "float", - "description": "The maximum temperature this model can use." - }, - "topK": { - "type": "integer", - "format": "int32", - "description": "For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. If empty, indicates the model doesn't use top-k sampling, and `top_k` isn't allowed as a generation parameter." } }, + "description": "Chunk from image search.", "type": "object" }, - "TuningTask": { - "description": "Tuning tasks that create tuned models.", + "TunedModelSource": { + "description": "Tuned model as a source for training a new model.", + "type": "object", "properties": { - "hyperparameters": { - "description": "Immutable. Hyperparameters controlling the tuning process. If not provided, default values will be used.", - "$ref": "#/components/schemas/Hyperparameters" + "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" }, - "startTime": { - "description": "Output only. The timestamp when tuning this model started.", + "baseModel": { "readOnly": true, + "description": "Output only. The name of the base `Model` this `TunedModel` was tuned from. Example: `models/gemini-1.5-flash-001`", + "type": "string" + } + } + }, + "FunctionCallingConfig": { + "type": "object", + "description": "Configuration for specifying function calling behavior.", + "properties": { + "mode": { "type": "string", - "format": "google-datetime" + "description": "Optional. Specifies the mode in which function calling should execute. If unspecified, the default value will be set to AUTO.", + "enum": [ + "MODE_UNSPECIFIED", + "AUTO", + "ANY", + "NONE", + "VALIDATED" + ], + "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\"." + ] }, - "completeTime": { - "readOnly": true, + "allowedFunctionNames": { + "description": "Optional. A set of function names that, when provided, limits the functions the model will call. This should only be set when the Mode is ANY or VALIDATED. Function names should match [FunctionDeclaration.name]. When set, model will predict a function call from only allowed function names.", + "type": "array", + "items": { + "type": "string" + } + } + } + }, + "ListPermissionsResponse": { + "properties": { + "permissions": { + "type": "array", + "items": { + "$ref": "#/components/schemas/Permission" + }, + "description": "Returned permissions." + }, + "nextPageToken": { + "type": "string", + "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages." + } + }, + "type": "object", + "description": "Response from `ListPermissions` containing a paginated list of permissions." + }, + "ListFilesResponse": { + "properties": { + "nextPageToken": { "type": "string", - "format": "google-datetime", - "description": "Output only. The timestamp when tuning this model completed." - }, - "trainingData": { - "description": "Required. Input only. Immutable. The model training data.", - "$ref": "#/components/schemas/Dataset" + "description": "A token that can be sent as a `page_token` into a subsequent `ListFiles` call." }, - "snapshots": { - "readOnly": true, + "files": { + "description": "The list of `File`s.", "type": "array", - "description": "Output only. Metrics collected during tuning.", "items": { - "$ref": "#/components/schemas/TuningSnapshot" + "$ref": "#/components/schemas/File" } } }, + "description": "Response for `ListFiles`.", "type": "object" }, - "FunctionResponseBlob": { - "type": "object", + "GroundingAttribution": { "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" + "sourceId": { + "$ref": "#/components/schemas/AttributionSourceId", + "readOnly": true, + "description": "Output only. Identifier for the source contributing to this attribution." }, - "data": { - "type": "string", - "format": "byte", - "description": "Raw bytes for media formats." + "content": { + "$ref": "#/components/schemas/Content", + "description": "Grounding source content that makes up this attribution." } }, - "description": "Raw media bytes for function response. Text should not be sent as raw bytes, use the 'FunctionResponse.response' field." + "description": "Attribution for a source that contributed to an answer.", + "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`.", + "AudioResponseFormat": { "properties": { - "toolType": { - "description": "Required. The type of tool that was called.", + "sampleRate": { + "type": "integer", + "description": "Optional. Sample rate in Hz.", + "format": "int32" + }, + "mimeType": { + "description": "Optional. The MIME type of the audio output.", + "type": "string", "x-enum-descriptions": [ - "Unspecified tool type.", - "Google search tool, maps to Tool.google_search.search_types.web_search.", - "Image search tool, maps to Tool.google_search.search_types.image_search.", - "URL context tool, maps to Tool.url_context.", - "Google maps tool, maps to Tool.google_maps.", - "File search tool, maps to Tool.file_search." + "Default value. This value is unused.", + "MP3 audio format.", + "OGG Opus audio format.", + "Raw PCM (L16) audio format.", + "WAV audio format.", + "A-law audio format.", + "Mu-law audio format." ], - "type": "string", "enum": [ - "TOOL_TYPE_UNSPECIFIED", - "GOOGLE_SEARCH_WEB", - "GOOGLE_SEARCH_IMAGE", - "URL_CONTEXT", - "GOOGLE_MAPS", - "FILE_SEARCH" + "MIME_TYPE_UNSPECIFIED", + "AUDIO_MP3", + "AUDIO_OGG_OPUS", + "AUDIO_L16", + "AUDIO_WAV", + "AUDIO_ALAW", + "AUDIO_MULAW" ] }, - "id": { - "description": "Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`.", - "type": "string" + "bitRate": { + "description": "Optional. Bit rate in bits per second (bps). Only applicable for compressed formats (MP3, Opus).", + "format": "int32", + "type": "integer" }, - "args": { - "additionalProperties": { - "description": "Properties of the object." - }, - "type": "object", - "description": "Optional. The tool call arguments. Example: {\"arg1\" : \"value1\", \"arg2\" : \"value2\" , ...}" - } - }, - "type": "object" - }, - "Document": { - "description": "A `Document` is a collection of `Chunk`s.", - "properties": { - "state": { + "delivery": { + "description": "Optional. The delivery mode for the audio output.", "type": "string", "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." + "Default value. This value is unused.", + "Audio data is returned inline in the response.", + "Audio data is returned as a URI." ], - "description": "Output only. Current state of the `Document`.", - "readOnly": true, "enum": [ - "STATE_UNSPECIFIED", - "STATE_PENDING", - "STATE_ACTIVE", - "STATE_FAILED" + "DELIVERY_UNSPECIFIED", + "INLINE", + "URI" ] - }, - "sizeBytes": { - "readOnly": true, - "type": "string", - "format": "int64", - "description": "Output only. The size of raw bytes ingested into the Document." - }, - "mimeType": { - "description": "Output only. The mime type of the Document.", - "readOnly": true, - "type": "string" - }, - "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" - }, - "updateTime": { - "description": "Output only. The Timestamp of when the `Document` was last updated.", - "readOnly": true, - "type": "string", - "format": "google-datetime" - }, - "displayName": { - "description": "Optional. The human-readable display name for the `Document`. The display name must be no more than 512 characters in length, including spaces. Example: \"Semantic Retriever Documentation\"", - "type": "string" - }, - "customMetadata": { - "type": "array", - "items": { - "$ref": "#/components/schemas/CustomMetadata" - }, - "description": "Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`." - }, - "createTime": { - "description": "Output only. The Timestamp of when the `Document` was created.", - "readOnly": true, - "type": "string", - "format": "google-datetime" } }, + "description": "Configuration for audio output format.", "type": "object" }, - "BatchStats": { - "description": "Stats about the batch.", + "ListCachedContentsResponse": { "type": "object", + "description": "Response with CachedContents list.", "properties": { - "successfulRequestCount": { - "description": "Output only. The number of requests that were successfully processed.", - "readOnly": true, - "type": "string", - "format": "int64" - }, - "requestCount": { - "description": "Output only. The number of requests in the batch.", - "readOnly": true, - "type": "string", - "format": "int64" - }, - "failedRequestCount": { - "description": "Output only. The number of requests that failed to be processed.", - "readOnly": true, - "type": "string", - "format": "int64" + "cachedContents": { + "description": "List of cached contents.", + "type": "array", + "items": { + "$ref": "#/components/schemas/CachedContent" + } }, - "pendingRequestCount": { - "readOnly": true, + "nextPageToken": { "type": "string", - "format": "int64", - "description": "Output only. The number of requests that are still pending processing." + "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." } } }, - "StreamableHttpTransport": { + "SafetySetting": { + "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", "properties": { - "headers": { - "description": "Optional: Fields for authentication headers, timeouts, etc., if needed.", - "type": "object", - "additionalProperties": { - "type": "string" - } - }, - "url": { - "description": "The full URL for the MCPServer endpoint. Example: \"https://api.example.com/mcp\"", - "type": "string" - }, - "timeout": { + "category": { + "description": "Required. The category for this setting.", + "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" + ], "type": "string", - "format": "google-duration", - "description": "HTTP timeout for regular operations." + "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." + ] }, - "sseReadTimeout": { + "threshold": { + "enum": [ + "HARM_BLOCK_THRESHOLD_UNSPECIFIED", + "BLOCK_LOW_AND_ABOVE", + "BLOCK_MEDIUM_AND_ABOVE", + "BLOCK_ONLY_HIGH", + "BLOCK_NONE", + "OFF" + ], + "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." + ], "type": "string", - "format": "google-duration", - "description": "Timeout for SSE read operations." - }, - "terminateOnClose": { - "description": "Whether to close the client session when the transport closes.", - "type": "boolean" + "description": "Required. Controls the probability threshold at which harm is blocked." + } + } + }, + "UrlContext": { + "description": "Tool to support URL context retrieval.", + "type": "object", + "properties": {} + }, + "BatchGenerateContentRequest": { + "properties": { + "batch": { + "$ref": "#/components/schemas/GenerateContentBatch", + "description": "Required. The batch to create." } }, "type": "object", - "description": "A transport that can stream HTTP requests and responses. Next ID: 6" + "description": "Request for a `BatchGenerateContent` operation." }, - "SpeechConfig": { + "StringList": { + "description": "User provided string values assigned to a single metadata key.", "type": "object", "properties": { - "multiSpeakerVoiceConfig": { - "description": "Optional. The configuration for the multi-speaker setup. It is mutually exclusive with the voice_config field.", - "$ref": "#/components/schemas/MultiSpeakerVoiceConfig" - }, - "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" + "values": { + "type": "array", + "items": { + "type": "string" + }, + "description": "The string values of the metadata to store." + } + } + }, + "InputConfig": { + "type": "object", + "description": "Configures the input to the batch request.", + "properties": { + "fileName": { + "type": "string", + "description": "The name of the `File` containing the input requests." }, - "voiceConfig": { - "description": "The configuration in case of single-voice output.", - "$ref": "#/components/schemas/VoiceConfig" + "requests": { + "description": "The requests to be processed in the batch.", + "$ref": "#/components/schemas/InlinedRequests" } - }, - "description": "Config for speech generation and transcription." + } }, - "EmbedContentResponse": { + "CreateFileRequest": { + "description": "Request for `CreateFile`.", "type": "object", + "properties": { + "file": { + "$ref": "#/components/schemas/File", + "description": "Optional. Metadata for the file to create." + } + } + }, + "GenerateContentResponse": { "properties": { "usageMetadata": { + "description": "Output only. Metadata on the generation requests' token usage.", "readOnly": true, - "description": "Output only. The usage metadata for the request.", - "$ref": "#/components/schemas/EmbeddingUsageMetadata" + "$ref": "#/components/schemas/UsageMetadata" }, - "embedding": { - "description": "Output only. The embedding generated from the input content.", - "$ref": "#/components/schemas/ContentEmbedding", + "modelStatus": { + "readOnly": true, + "$ref": "#/components/schemas/ModelStatus", + "description": "Output only. The current model status of this model." + }, + "promptFeedback": { + "description": "Returns the prompt's feedback related to the content filters.", + "$ref": "#/components/schemas/PromptFeedback" + }, + "responseId": { + "readOnly": true, + "type": "string", + "description": "Output only. response_id is used to identify each response." + }, + "candidates": { + "type": "array", + "items": { + "$ref": "#/components/schemas/Candidate" + }, + "description": "Candidate responses from the model." + }, + "modelVersion": { + "description": "Output only. The model version used to generate the response.", + "type": "string", "readOnly": true } }, - "description": "The response to an `EmbedContentRequest`." + "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" }, - "UsageMetadata": { + "ListGeneratedFilesResponse": { + "type": "object", + "description": "Response for `ListGeneratedFiles`.", "properties": { - "candidatesTokenCount": { - "type": "integer", - "format": "int32", - "description": "Total number of tokens across all the generated response candidates." - }, - "totalTokenCount": { - "description": "Total token count for the generation request (prompt + thoughts + response candidates).", - "type": "integer", - "format": "int32" - }, - "candidatesTokensDetails": { - "readOnly": true, + "generatedFiles": { "type": "array", - "description": "Output only. List of modalities that were returned in the response.", "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - } + "$ref": "#/components/schemas/GeneratedFile" + }, + "description": "The list of `GeneratedFile`s." }, - "cacheTokensDetails": { - "description": "Output only. List of modalities of the cached content in the request input.", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" + "nextPageToken": { + "type": "string", + "description": "A token that can be sent as a `page_token` into a subsequent `ListGeneratedFiles` call." + } + } + }, + "Operation": { + "description": "This resource represents a long-running operation that is the result of a network API call.", + "type": "object", + "properties": { + "metadata": { + "additionalProperties": { + "description": "Properties of the object. Contains field @type with type URL." }, - "readOnly": true, - "type": "array" + "type": "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." }, - "promptTokensDetails": { - "readOnly": true, - "type": "array", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" + "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." + }, + "response": { + "additionalProperties": { + "description": "Properties of the object. Contains field @type with type URL." }, - "description": "Output only. List of modalities that were processed in the request input." + "type": "object", + "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`." }, - "thoughtsTokenCount": { - "description": "Output only. Number of tokens of thoughts for thinking models.", - "readOnly": true, + "error": { + "$ref": "#/components/schemas/Status", + "description": "The error result of the operation in case of failure or cancellation." + } + } + }, + "UsageMetadata": { + "description": "Metadata on the generation request's token usage.", + "type": "object", + "properties": { + "promptTokenCount": { "type": "integer", + "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.", "format": "int32" }, - "promptTokenCount": { - "type": "integer", + "toolUsePromptTokenCount": { + "readOnly": true, + "description": "Output only. Number of tokens present in tool-use prompt(s).", "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." + "type": "integer" }, "serviceTier": { - "type": "string", - "readOnly": true, "enum": [ "unspecified", "standard", "flex", "priority" ], + "description": "Output only. Service tier of the request.", + "readOnly": true, "x-enum-descriptions": [ "Default service tier, which is standard.", "Standard service tier.", "Flex service tier.", "Priority service tier." ], - "description": "Output only. Service tier of the request." + "type": "string" }, - "cachedContentTokenCount": { + "thoughtsTokenCount": { "type": "integer", + "description": "Output only. Number of tokens of thoughts for thinking models.", "format": "int32", - "description": "Number of tokens in the cached part of the prompt (the cached content)" + "readOnly": true + }, + "candidatesTokensDetails": { + "readOnly": true, + "description": "Output only. List of modalities that were returned in the response.", + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + } }, "toolUsePromptTokensDetails": { + "readOnly": true, "description": "Output only. List of modalities that were processed for tool-use request inputs.", + "type": "array", "items": { "$ref": "#/components/schemas/ModalityTokenCount" - }, - "readOnly": true, - "type": "array" + } }, - "toolUsePromptTokenCount": { - "readOnly": true, + "cachedContentTokenCount": { "type": "integer", + "description": "Number of tokens in the cached part of the prompt (the cached content)", + "format": "int32" + }, + "promptTokensDetails": { + "readOnly": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + }, + "description": "Output only. List of modalities that were processed in the request input." + }, + "cacheTokensDetails": { + "description": "Output only. List of modalities of the cached content in the request input.", + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + }, + "readOnly": true + }, + "candidatesTokenCount": { + "description": "Total number of tokens across all the generated response candidates.", + "format": "int32", + "type": "integer" + }, + "totalTokenCount": { + "description": "Total token count for the generation request (prompt + thoughts + response candidates).", "format": "int32", - "description": "Output only. Number of tokens present in tool-use prompt(s)." + "type": "integer" }, "responseTokenCount": { "description": "Output only. Number of tokens in the response. Used by Gemini 3.1+ Live API models instead of candidatesTokenCount.", @@ -5681,1249 +5704,1226 @@ "$ref": "#/components/schemas/ModalityTokenCount" } } + } + }, + "TransferOwnershipResponse": { + "properties": {}, + "type": "object", + "description": "Response from `TransferOwnership`." + }, + "ModalityTokenCount": { + "properties": { + "tokenCount": { + "type": "integer", + "description": "Number of tokens.", + "format": "int32" + }, + "modality": { + "enum": [ + "MODALITY_UNSPECIFIED", + "TEXT", + "IMAGE", + "VIDEO", + "AUDIO", + "DOCUMENT" + ], + "x-enum-descriptions": [ + "Unspecified modality.", + "Plain text.", + "Image.", + "Video.", + "Audio.", + "Document, e.g. PDF." + ], + "type": "string", + "description": "The modality associated with this token count." + } }, "type": "object", - "description": "Metadata on the generation request's token usage." + "description": "Represents token counting info for a single modality." }, - "TuningSnapshot": { - "description": "Record for a single tuning step.", + "BatchStats": { "properties": { - "computeTime": { - "description": "Output only. The timestamp when this metric was computed.", - "readOnly": true, + "successfulRequestCount": { + "description": "Output only. The number of requests that were successfully processed.", + "format": "int64", "type": "string", - "format": "google-datetime" + "readOnly": true }, - "epoch": { - "readOnly": true, - "type": "integer", - "format": "int32", - "description": "Output only. The epoch this step was part of." + "failedRequestCount": { + "description": "Output only. The number of requests that failed to be processed.", + "format": "int64", + "type": "string", + "readOnly": true }, - "step": { - "description": "Output only. The tuning step.", - "readOnly": true, - "type": "integer", - "format": "int32" + "requestCount": { + "type": "string", + "description": "Output only. The number of requests in the batch.", + "format": "int64", + "readOnly": true }, - "meanLoss": { - "readOnly": true, - "type": "number", - "format": "float", - "description": "Output only. The mean loss of the training examples for this step." + "pendingRequestCount": { + "description": "Output only. The number of requests that are still pending processing.", + "format": "int64", + "type": "string", + "readOnly": true } }, - "type": "object" - }, - "VideoFileMetadata": { - "description": "Metadata for a video `File`.", "type": "object", + "description": "Stats about the batch." + }, + "GoogleSearchRetrieval": { "properties": { - "videoDuration": { - "description": "Duration of the video.", - "type": "string", - "format": "google-duration" + "dynamicRetrievalConfig": { + "description": "Specifies the dynamic retrieval configuration for the given source.", + "$ref": "#/components/schemas/DynamicRetrievalConfig" } - } + }, + "type": "object", + "description": "Tool to retrieve public web data for grounding, powered by Google." }, - "EmbedContentRequest": { + "FileData": { "properties": { - "embedContentConfig": { - "$ref": "#/components/schemas/EmbedContentConfig", - "description": "Optional. Configuration for the EmbedContent request." - }, - "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" - }, - "taskType": { + "mimeType": { "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." - ], - "deprecated": true, - "enum": [ - "TASK_TYPE_UNSPECIFIED", - "RETRIEVAL_QUERY", - "RETRIEVAL_DOCUMENT", - "SEMANTIC_SIMILARITY", - "CLASSIFICATION", - "CLUSTERING", - "QUESTION_ANSWERING", - "FACT_VERIFICATION", - "CODE_RETRIEVAL_QUERY" - ] - }, - "outputDimensionality": { - "deprecated": true, - "type": "integer", - "format": "int32", - "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`)." - }, - "content": { - "description": "Required. The content to embed. Only the `parts.text` fields will be counted.", - "$ref": "#/components/schemas/Content" + "description": "Optional. The IANA standard MIME type of the source data." }, - "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, + "fileUri": { + "description": "Required. URI.", "type": "string" } }, "type": "object", - "description": "Request containing the `Content` for the model to embed." + "description": "URI based data." }, - "Status": { - "type": "object", + "Dataset": { "properties": { - "details": { - "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." - } - } - }, - "code": { - "type": "integer", - "format": "int32", - "description": "The status code, which should be an enum value of google.rpc.Code." - }, - "message": { - "description": "A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client.", - "type": "string" + "examples": { + "$ref": "#/components/schemas/TuningExamples", + "description": "Optional. Inline examples with simple input/output text." } }, - "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)." + "type": "object", + "description": "Dataset for training or validation." }, "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", "properties": { - "codeExecutionResult": { - "$ref": "#/components/schemas/CodeExecutionResult", - "description": "Result of executing the `ExecutableCode`." - }, - "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." - }, - "type": "object" + } }, - "text": { - "description": "Inline text.", - "type": "string" + "toolResponse": { + "description": "The output from a server-side `ToolCall` execution. This field is populated by the client with the results of executing the corresponding `ToolCall`.", + "$ref": "#/components/schemas/ToolResponse" }, - "functionResponse": { - "$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." + "thoughtSignature": { + "description": "Optional. An opaque signature for the thought so it can be reused in subsequent requests.", + "format": "byte", + "type": "string" }, - "inlineData": { - "description": "Inline media bytes.", - "$ref": "#/components/schemas/Blob" + "fileData": { + "$ref": "#/components/schemas/FileData", + "description": "URI based data." }, "mediaResolution": { "description": "Optional. Media resolution for the input media.", "$ref": "#/components/schemas/MediaResolution" }, - "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`." + "text": { + "description": "Inline text.", + "type": "string" }, - "executableCode": { - "$ref": "#/components/schemas/ExecutableCode", - "description": "Code generated by the model that is meant to be executed." + "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" + }, + "videoMetadata": { + "$ref": "#/components/schemas/VideoMetadata", + "description": "Optional. Video metadata. The metadata should only be specified while the video data is presented in inline_data or file_data." + }, + "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" }, "toolCall": { "description": "Server-side tool call. This field is populated when the model predicts a tool invocation that should be executed on the server. The client is expected to echo this message back to the API.", "$ref": "#/components/schemas/ToolCall" }, - "thoughtSignature": { - "type": "string", - "format": "byte", - "description": "Optional. An opaque signature for the thought so it can be reused in subsequent requests." + "inlineData": { + "description": "Inline media bytes.", + "$ref": "#/components/schemas/Blob" }, - "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" + "executableCode": { + "description": "Code generated by the model that is meant to be executed.", + "$ref": "#/components/schemas/ExecutableCode" + }, + "codeExecutionResult": { + "$ref": "#/components/schemas/CodeExecutionResult", + "description": "Result of executing the `ExecutableCode`." }, "thought": { "description": "Optional. Indicates if the part is thought from the model.", "type": "boolean" + } + } + }, + "SpeakerVoiceConfig": { + "type": "object", + "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" }, - "functionCall": { - "$ref": "#/components/schemas/FunctionCall", - "description": "A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values." + "voiceConfig": { + "description": "Required. The configuration for the voice to use.", + "$ref": "#/components/schemas/VoiceConfig" + } + } + }, + "Maps": { + "properties": { + "title": { + "description": "Title of the place.", + "type": "string" + }, + "placeId": { + "description": "The ID of the place, in `places/{place_id}` format. A user can use this ID to look up that place.", + "type": "string" + }, + "placeAnswerSources": { + "description": "Sources that provide answers about the features of a given place in Google Maps.", + "$ref": "#/components/schemas/PlaceAnswerSources" + }, + "uri": { + "type": "string", + "description": "URI reference of the place." + }, + "text": { + "description": "Text description of the place answer.", + "type": "string" + } + }, + "type": "object", + "description": "A grounding chunk from Google Maps. A Maps chunk corresponds to a single place." + }, + "SemanticRetrieverChunk": { + "description": "Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`.", + "type": "object", + "properties": { + "source": { + "description": "Output only. Name of the source matching the request's `SemanticRetrieverConfig.source`. Example: `corpora/123` or `corpora/123/documents/abc`", + "type": "string", + "readOnly": true + }, + "chunk": { + "type": "string", + "description": "Output only. Name of the `Chunk` containing the attributed text. Example: `corpora/123/documents/abc/chunks/xyz`", + "readOnly": true + } + } + }, + "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", + "properties": { + "id": { + "description": "Optional. The identifier of the tool call this response is for.", + "type": "string" + }, + "toolType": { + "enum": [ + "TOOL_TYPE_UNSPECIFIED", + "GOOGLE_SEARCH_WEB", + "GOOGLE_SEARCH_IMAGE", + "URL_CONTEXT", + "GOOGLE_MAPS", + "FILE_SEARCH" + ], + "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." + ], + "type": "string", + "description": "Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`." + }, + "response": { + "additionalProperties": { + "description": "Properties of the object." + }, + "description": "Optional. The tool response.", + "type": "object" + } + } + }, + "UploadToFileSearchStoreRequest": { + "description": "Request for `UploadToFileSearchStore`.", + "type": "object", + "properties": { + "chunkingConfig": { + "description": "Optional. Config for telling the service how to chunk the data. If not provided, the service will use default parameters.", + "$ref": "#/components/schemas/ChunkingConfig" + }, + "displayName": { + "description": "Optional. Display name of the created document.", + "type": "string" + }, + "customMetadata": { + "description": "Custom metadata to be associated with the data.", + "type": "array", + "items": { + "$ref": "#/components/schemas/CustomMetadata" + } + }, + "mimeType": { + "type": "string", + "description": "Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content." + } + } + }, + "RegisterFilesRequest": { + "properties": { + "uris": { + "description": "Required. The Google Cloud Storage URIs to register. Example: `gs://bucket/object`.", + "type": "array", + "items": { + "type": "string" + } } }, - "type": "object" + "type": "object", + "description": "Request for `RegisterFiles`." }, - "CountTokensRequest": { + "TuningTask": { "type": "object", + "description": "Tuning tasks that create tuned models.", "properties": { - "contents": { - "description": "Optional. The input given to the model as a prompt. This field is ignored when `generate_content_request` is set.", + "snapshots": { + "description": "Output only. Metrics collected during tuning.", + "type": "array", "items": { - "$ref": "#/components/schemas/Content" + "$ref": "#/components/schemas/TuningSnapshot" }, - "type": "array" + "readOnly": true }, - "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" + "completeTime": { + "description": "Output only. The timestamp when tuning this model completed.", + "format": "google-datetime", + "type": "string", + "readOnly": true + }, + "startTime": { + "description": "Output only. The timestamp when tuning this model started.", + "format": "google-datetime", + "type": "string", + "readOnly": true + }, + "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" } - }, - "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`." + } }, - "TunedModel": { - "description": "A fine-tuned model created using ModelService.CreateTunedModel.", - "type": "object", + "GenerateContentBatch": { "properties": { - "baseModel": { - "description": "Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001`", - "type": "string" - }, - "description": { - "description": "Optional. A short description of this model.", - "type": "string" + "inputConfig": { + "description": "Required. Input configuration of the instances on which batch processing are performed.", + "$ref": "#/components/schemas/InputConfig" }, - "state": { + "displayName": { "type": "string", - "x-enum-descriptions": [ - "The default value. This value is unused.", - "The model is being created.", - "The model is ready to be used.", - "The model failed to be created." - ], - "description": "Output only. The state of the tuned model.", - "readOnly": true, - "enum": [ - "STATE_UNSPECIFIED", - "CREATING", - "ACTIVE", - "FAILED" - ] - }, - "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" - }, - "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.", - "type": "number", - "format": "float" + "description": "Required. The user-defined name of this batch." }, "createTime": { - "description": "Output only. The timestamp when this model was created.", "readOnly": true, "type": "string", + "description": "Output only. The time at which the batch was created.", "format": "google-datetime" }, - "name": { - "description": "Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`", - "readOnly": true, + "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" }, - "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." + "name": { + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", + "type": "string", + "readOnly": true }, - "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" + "batchStats": { + "description": "Output only. Stats about the batch.", + "readOnly": true, + "$ref": "#/components/schemas/BatchStats" }, "updateTime": { "readOnly": true, + "description": "Output only. The time at which the batch was last updated.", + "format": "google-datetime", + "type": "string" + }, + "endTime": { "type": "string", + "description": "Output only. The time at which the batch processing completed.", "format": "google-datetime", - "description": "Output only. The timestamp when this model was updated." + "readOnly": true }, - "readerProjectNumbers": { + "model": { + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "type": "string" + }, + "state": { + "enum": [ + "BATCH_STATE_UNSPECIFIED", + "BATCH_STATE_PENDING", + "BATCH_STATE_RUNNING", + "BATCH_STATE_SUCCEEDED", + "BATCH_STATE_FAILED", + "BATCH_STATE_CANCELLED", + "BATCH_STATE_EXPIRED" + ], + "description": "Output only. The state of the batch.", + "readOnly": true, + "x-enum-descriptions": [ + "The batch state is unspecified.", + "The service is preparing to run the batch.", + "The batch is in progress.", + "The batch completed successfully.", + "The batch failed.", + "The batch has been cancelled.", + "The batch has expired." + ], + "type": "string" + }, + "output": { + "description": "Output only. The output of the batch request.", + "readOnly": true, + "$ref": "#/components/schemas/GenerateContentBatchOutput" + } + }, + "description": "A resource representing a batch of `GenerateContent` requests.", + "type": "object" + }, + "CitationMetadata": { + "type": "object", + "description": "A collection of source attributions for a piece of content.", + "properties": { + "citationSources": { + "type": "array", "items": { - "type": "string", - "format": "int64" + "$ref": "#/components/schemas/CitationSource" }, - "description": "Optional. List of project numbers that have read access to the tuned model.", - "type": "array" - }, - "tunedModelSource": { - "description": "Optional. TunedModel to use as the starting point for training the new model.", - "$ref": "#/components/schemas/TunedModelSource" + "description": "Citations to sources for a specific response." } } }, - "Content": { + "FileSearch": { "properties": { - "parts": { + "fileSearchStoreNames": { + "description": "Required. The names of the file_search_stores to retrieve from. Example: `fileSearchStores/my-file-search-store-123`", "type": "array", - "description": "Ordered `Parts` that constitute a single message. Parts may have different MIME types.", "items": { - "$ref": "#/components/schemas/Part" + "type": "string" } }, - "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.", + "metadataFilter": { + "description": "Optional. Metadata filter to apply to the semantic retrieval documents and chunks.", "type": "string" + }, + "topK": { + "type": "integer", + "description": "Optional. The number of semantic retrieval chunks to retrieve.", + "format": "int32" } }, - "type": "object", - "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." + "description": "The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API.", + "type": "object" }, - "ExecutableCode": { - "type": "object", + "ListModelsResponse": { "properties": { - "id": { - "description": "Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`.", - "type": "string" + "models": { + "description": "The returned Models.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Model" + } }, - "language": { + "nextPageToken": { "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": { - "description": "Required. The code to be executed.", - "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": "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." + "description": "Response from `ListModel` containing a paginated list of Models.", + "type": "object" }, - "FunctionDeclaration": { + "EmbeddingUsageMetadata": { + "type": "object", + "description": "Metadata on the usage of the embedding request.", "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" + "promptTokenCount": { + "readOnly": true, + "description": "Output only. Number of tokens in the prompt.", + "format": "int32", + "type": "integer" }, - "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`." + "promptTokenDetails": { + "readOnly": true, + "description": "Output only. List of modalities that were processed in the request input.", + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + } + } + } + }, + "CodeExecutionResult": { + "properties": { + "id": { + "description": "Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id.", + "type": "string" }, - "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" + "output": { + "description": "Optional. Contains stdout when code execution is successful, stderr or other description otherwise.", + "type": "string" }, - "behavior": { + "outcome": { + "description": "Required. Outcome of the code execution.", "type": "string", - "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." - ] - }, - "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" - }, - "description": { - "description": "Required. A brief description of the function.", - "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`." + "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": "object", - "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." + "description": "Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used.", + "type": "object" }, - "CitationSource": { - "description": "A citation to a source for a portion of a specific response.", + "GroundingChunk": { "properties": { - "startIndex": { - "type": "integer", - "format": "int32", - "description": "Optional. Start of segment of the response that is attributed to this source. Index indicates the start of the segment, measured in bytes." + "image": { + "description": "Optional. Grounding chunk from image search.", + "$ref": "#/components/schemas/Image" }, - "license": { - "description": "Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations.", - "type": "string" + "maps": { + "description": "Optional. Grounding chunk from Google Maps.", + "$ref": "#/components/schemas/Maps" }, - "endIndex": { - "description": "Optional. End of the attributed segment, exclusive.", - "type": "integer", - "format": "int32" + "web": { + "$ref": "#/components/schemas/Web", + "description": "Grounding chunk from the web." }, - "uri": { - "description": "Optional. URI that is attributed as a source for a portion of the text.", - "type": "string" + "retrievedContext": { + "description": "Optional. Grounding chunk from context retrieved by the file search tool.", + "$ref": "#/components/schemas/RetrievedContext" } }, - "type": "object" + "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." }, - "AudioResponseFormat": { - "description": "Configuration for audio output format.", + "EmbedContentConfig": { + "description": "Configurations for the EmbedContent request.", "type": "object", "properties": { - "delivery": { - "type": "string", + "title": { + "description": "Optional. The title for the text.", + "type": "string" + }, + "taskType": { "enum": [ - "DELIVERY_UNSPECIFIED", - "INLINE", - "URI" + "TASK_TYPE_UNSPECIFIED", + "RETRIEVAL_QUERY", + "RETRIEVAL_DOCUMENT", + "SEMANTIC_SIMILARITY", + "CLASSIFICATION", + "CLUSTERING", + "QUESTION_ANSWERING", + "FACT_VERIFICATION", + "CODE_RETRIEVAL_QUERY" ], "x-enum-descriptions": [ - "Default value. This value is unused.", - "Audio data is returned inline in the response.", - "Audio data is returned as a URI." + "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": "Optional. The delivery mode for the audio output." + "type": "string", + "description": "Optional. The task type of the embedding." }, - "sampleRate": { - "description": "Optional. Sample rate in Hz.", - "type": "integer", - "format": "int32" + "documentOcr": { + "description": "Optional. Whether to enable OCR for document content.", + "type": "boolean" }, - "mimeType": { - "description": "Optional. The MIME type of the audio output.", - "x-enum-descriptions": [ - "Default value. This value is unused.", - "MP3 audio format.", - "OGG Opus audio format.", - "Raw PCM (L16) audio format.", - "WAV audio format.", - "A-law audio format.", - "Mu-law audio format." - ], - "type": "string", - "enum": [ - "MIME_TYPE_UNSPECIFIED", - "AUDIO_MP3", - "AUDIO_OGG_OPUS", - "AUDIO_L16", - "AUDIO_WAV", - "AUDIO_ALAW", - "AUDIO_MULAW" - ] + "autoTruncate": { + "description": "Optional. Whether to silently truncate the input content if it's longer than the maximum sequence length.", + "type": "boolean" }, - "bitRate": { + "outputDimensionality": { "type": "integer", - "format": "int32", - "description": "Optional. Bit rate in bits per second (bps). Only applicable for compressed formats (MP3, Opus)." + "description": "Optional. Reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end.", + "format": "int32" + }, + "audioTrackExtraction": { + "type": "boolean", + "description": "Optional. Whether to extract audio from video content." } } }, - "GenerationConfig": { + "StreamableHttpTransport": { "properties": { - "maxOutputTokens": { - "description": "Optional. The maximum number of tokens to include in a response candidate. Note: The default value varies by model, see the `Model.output_token_limit` attribute of the `Model` returned from the `getModel` function.", - "type": "integer", - "format": "int32" - }, - "frequencyPenalty": { - "description": "Optional. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit.", - "type": "number", - "format": "float" - }, - "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." - }, - "responseJsonSchema": { - "description": "Optional. An internal detail. Use `responseJsonSchema` rather than this field." + "url": { + "type": "string", + "description": "The full URL for the MCPServer endpoint. Example: \"https://api.example.com/mcp\"" }, - "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" + "sseReadTimeout": { + "description": "Timeout for SSE read operations.", + "format": "google-duration", + "type": "string" }, - "responseSchema": { - "$ref": "#/components/schemas/Schema", - "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." + "headers": { + "description": "Optional: Fields for authentication headers, timeouts, etc., if needed.", + "type": "object", + "additionalProperties": { + "type": "string" + } }, - "logprobs": { - "type": "integer", - "format": "int32", - "description": "Optional. Only valid if response_logprobs=True. This sets the number of top logprobs, including the chosen candidate, to return at each decoding step in the Candidate.logprobs_result. The number must be in the range of [0, 20]." + "timeout": { + "type": "string", + "description": "HTTP timeout for regular operations.", + "format": "google-duration" }, - "responseLogprobs": { - "description": "Optional. If true, export the logprobs results in response.", + "terminateOnClose": { + "description": "Whether to close the client session when the transport closes.", "type": "boolean" + } + }, + "description": "A transport that can stream HTTP requests and responses. Next ID: 6", + "type": "object" + }, + "WhiteSpaceConfig": { + "properties": { + "maxTokensPerChunk": { + "type": "integer", + "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.", + "format": "int32" }, - "seed": { - "description": "Optional. Seed used in decoding. If not set, the request uses a randomly generated seed.", + "maxOverlapTokens": { "type": "integer", + "description": "Maximum number of overlapping tokens between two adjacent chunks.", "format": "int32" + } + }, + "description": "Configuration for a white space chunking algorithm [white space delimited].", + "type": "object" + }, + "ComputerUse": { + "type": "object", + "description": "Computer Use tool type.", + "properties": { + "enablePromptInjectionDetection": { + "description": "Optional. Whether enable the prompt injection detection check on computer-use request.", + "type": "boolean" }, - "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.", + "disabledSafetyPolicies": { + "type": "array", "items": { - "type": "string" + "type": "string", + "x-enum-descriptions": [ + "Unspecified safety policy.", + "Safety policy for financial transactions.", + "Safety policy for sensitive data modification.", + "Safety policy for communication tools (e.g. Gmail, Chat, Meet).", + "Safety policy for account creation.", + "Safety policy for data modification.", + "Safety policy for user consent management.", + "Safety policy for legal terms and agreements." + ], + "enum": [ + "SAFETY_POLICY_UNSPECIFIED", + "FINANCIAL_TRANSACTIONS", + "SENSITIVE_DATA_MODIFICATION", + "COMMUNICATION_TOOL", + "ACCOUNT_CREATION", + "DATA_MODIFICATION", + "USER_CONSENT_MANAGEMENT", + "LEGAL_TERMS_AND_AGREEMENTS" + ] }, - "type": "array" - }, - "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." + "description": "Optional. Disabled safety policies for computer use." }, - "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)." - ], + "environment": { "type": "string", + "description": "Required. The environment being operated.", "enum": [ - "MEDIA_RESOLUTION_UNSPECIFIED", - "MEDIA_RESOLUTION_LOW", - "MEDIA_RESOLUTION_MEDIUM", - "MEDIA_RESOLUTION_HIGH" + "ENVIRONMENT_UNSPECIFIED", + "ENVIRONMENT_BROWSER", + "ENVIRONMENT_MOBILE", + "ENVIRONMENT_DESKTOP" + ], + "x-enum-descriptions": [ + "Defaults to browser.", + "Operates in a web browser.", + "Operates in a mobile environment.", + "Operates in a desktop environment." ] }, - "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" - }, - "responseMimeType": { - "description": "Optional. MIME type of the generated candidate text. Supported MIME types are: `text/plain`: (default) Text output. `application/json`: JSON response in the response candidates. `text/x.enum`: ENUM as a string response in the response candidates. Refer to the [docs](https://ai.google.dev/gemini-api/docs/prompting_with_media#plain_text_formats) for a list of all supported text MIME types.", - "type": "string" - }, - "responseFormat": { - "$ref": "#/components/schemas/ResponseFormatConfig", - "description": "Optional. Configuration for the response output format. Allows specifying output configuration per modality (text, audio, image) in a flat structure." - }, - "enableEnhancedCivicAnswers": { - "description": "Optional. Enables enhanced civic answers. It may not be available for all models.", - "type": "boolean" - }, - "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." - }, - "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)" - }, - "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." - }, - "responseModalities": { + "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", - "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." - ], - "type": "string", - "enum": [ - "MODALITY_UNSPECIFIED", - "TEXT", - "IMAGE", - "AUDIO", - "VIDEO" - ] + "type": "string" } - }, - "translationConfig": { - "description": "Optional. Config for translation.", - "$ref": "#/components/schemas/TranslationConfig" - }, - "speechConfig": { - "$ref": "#/components/schemas/SpeechConfig", - "description": "Optional. The speech generation config." } - }, - "type": "object", - "description": "Configuration options for model generation and outputs. Not all parameters are configurable for every model." + } }, - "ListCachedContentsResponse": { - "description": "Response with CachedContents list.", + "UrlContextMetadata": { "properties": { - "cachedContents": { + "urlMetadata": { + "type": "array", "items": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/UrlMetadata" }, - "description": "List of cached contents.", - "type": "array" - }, - "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" + "description": "List of url context." } }, + "description": "Metadata related to url context retrieval tool.", "type": "object" }, - "GroundingAttribution": { + "Hyperparameters": { "type": "object", + "description": "Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance", "properties": { - "sourceId": { - "readOnly": true, - "description": "Output only. Identifier for the source contributing to this attribution.", - "$ref": "#/components/schemas/AttributionSourceId" + "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.", + "format": "float", + "type": "number" }, - "content": { - "$ref": "#/components/schemas/Content", - "description": "Grounding source content that makes up this attribution." + "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" + }, + "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.", + "format": "float", + "type": "number" + }, + "batchSize": { + "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" } - }, - "description": "Attribution for a source that contributed to an answer." + } }, - "RegisterFilesResponse": { - "description": "Response for `RegisterFiles`.", + "ImageSearch": { + "properties": {}, + "description": "Image search for grounding and related configurations.", + "type": "object" + }, + "CountTokensResponse": { "type": "object", + "description": "A response from `CountTokens`. It returns the model's `token_count` for the `prompt`.", "properties": { - "files": { + "cachedContentTokenCount": { + "type": "integer", + "description": "Number of tokens in the cached part of the prompt (the cached content).", + "format": "int32" + }, + "promptTokensDetails": { "type": "array", "items": { - "$ref": "#/components/schemas/File" + "$ref": "#/components/schemas/ModalityTokenCount" }, - "description": "The registered files to be used when calling GenerateContent." - } - } - }, - "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": { - "name": { - "description": "The name of the MCPServer.", - "type": "string" + "description": "Output only. List of modalities that were processed in the request input.", + "readOnly": true }, - "streamableHttpTransport": { - "description": "A transport that can stream HTTP requests and responses.", - "$ref": "#/components/schemas/StreamableHttpTransport" + "cacheTokensDetails": { + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + }, + "description": "Output only. List of modalities that were processed in the cached content.", + "readOnly": true + }, + "totalTokens": { + "description": "The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative.", + "format": "int32", + "type": "integer" } } }, - "ListCorporaResponse": { + "TuningExample": { "properties": { - "corpora": { - "description": "The returned corpora.", - "items": { - "$ref": "#/components/schemas/Corpus" - }, - "type": "array" + "textInput": { + "description": "Optional. Text model input.", + "type": "string" }, - "nextPageToken": { - "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", + "output": { + "description": "Required. The expected model output.", "type": "string" } }, "type": "object", - "description": "Response from `ListCorpora` containing a paginated list of `Corpora`. The results are sorted by ascending `corpus.create_time`." + "description": "A single example for tuning." }, - "Schema": { + "GenerationConfig": { + "description": "Configuration options for model generation and outputs. Not all parameters are configurable for every model.", + "type": "object", "properties": { - "maxItems": { - "type": "string", - "format": "int64", - "description": "Optional. Maximum number of the elements for Type.ARRAY." + "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" }, - "title": { - "description": "Optional. The title of the schema.", - "type": "string" + "presencePenalty": { + "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.", + "format": "float" }, - "minLength": { - "type": "string", - "format": "int64", - "description": "Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING" + "topK": { + "description": "Optional. The maximum number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests.", + "format": "int32", + "type": "integer" }, - "format": { - "description": "Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality.", - "type": "string" + "enableEnhancedCivicAnswers": { + "type": "boolean", + "description": "Optional. Enables enhanced civic answers. It may not be available for all models." }, - "required": { - "type": "array", - "description": "Optional. Required properties of Type.OBJECT.", - "items": { - "type": "string" - } + "maxOutputTokens": { + "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.", + "format": "int32", + "type": "integer" }, - "pattern": { - "description": "Optional. Pattern of the Type.STRING to restrict a string to a regular expression.", - "type": "string" + "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.", + "format": "float", + "type": "number" }, - "anyOf": { + "candidateCount": { + "type": "integer", + "description": "Optional. Number of generated responses to return. If unset, this will default to 1. Please note that this doesn't work for previous generation models (Gemini 1.0 family)", + "format": "int32" + }, + "responseModalities": { "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" - } - }, - "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." - }, - "nullable": { - "description": "Optional. Indicates if the value may be null.", - "type": "boolean" + "enum": [ + "MODALITY_UNSPECIFIED", + "TEXT", + "IMAGE", + "AUDIO", + "VIDEO" + ], + "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." + ], + "type": "string" + }, + "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." }, - "minProperties": { - "type": "string", - "format": "int64", - "description": "Optional. Minimum number of the properties for Type.OBJECT." + "seed": { + "description": "Optional. Seed used in decoding. If not set, the request uses a randomly generated seed.", + "format": "int32", + "type": "integer" }, - "maxLength": { - "description": "Optional. Maximum length of the Type.STRING", - "type": "string", - "format": "int64" + "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].", + "format": "int32", + "type": "integer" }, - "type": { - "type": "string", - "enum": [ - "TYPE_UNSPECIFIED", - "STRING", - "NUMBER", - "INTEGER", - "BOOLEAN", - "ARRAY", - "OBJECT", - "NULL" - ], - "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." - ] + "responseFormat": { + "description": "Optional. Configuration for the response output format. Allows specifying output configuration per modality (text, audio, image) in a flat structure.", + "$ref": "#/components/schemas/ResponseFormatConfig" }, - "maxProperties": { - "type": "string", - "format": "int64", - "description": "Optional. Maximum number of the properties for Type.OBJECT." + "responseJsonSchema": { + "description": "Optional. An internal detail. Use `responseJsonSchema` rather than this field." }, - "properties": { - "additionalProperties": { - "$ref": "#/components/schemas/Schema" - }, - "type": "object", - "description": "Optional. Properties of Type.OBJECT." + "speechConfig": { + "$ref": "#/components/schemas/SpeechConfig", + "description": "Optional. The speech generation config." }, - "items": { - "description": "Optional. Schema of the elements of Type.ARRAY.", - "$ref": "#/components/schemas/Schema" + "frequencyPenalty": { + "type": "number", + "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" }, - "maximum": { - "description": "Optional. Maximum value of the Type.INTEGER and Type.NUMBER", + "temperature": { "type": "number", - "format": "double" + "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].", + "format": "float" }, - "propertyOrdering": { + "stopSequences": { + "description": "Optional. The set of character sequences (up to 5) that will stop output generation. If specified, the API will stop at the first appearance of a `stop_sequence`. The stop sequence will not be included as part of the response.", "type": "array", "items": { "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." + } }, - "example": { - "description": "Optional. Example of the object. Will only populated when the object is the root." + "responseSchema": { + "$ref": "#/components/schemas/Schema", + "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." }, - "minimum": { - "description": "Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER", - "type": "number", - "format": "double" + "translationConfig": { + "description": "Optional. Config for translation.", + "$ref": "#/components/schemas/TranslationConfig" }, - "minItems": { + "responseMimeType": { "type": "string", - "format": "int64", - "description": "Optional. Minimum number of the elements for Type.ARRAY." + "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." }, - "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" - } + "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." }, - "description": { - "description": "Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown.", - "type": "string" + "responseLogprobs": { + "description": "Optional. If true, export the logprobs results in response.", + "type": "boolean" + }, + "mediaResolution": { + "description": "Optional. If specified, the media resolution specified will be used.", + "type": "string", + "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": "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)." + } }, - "SearchTypes": { + "DynamicRetrievalConfig": { "properties": { - "webSearch": { - "$ref": "#/components/schemas/WebSearch", - "description": "Optional. Enables web search. Only text results are returned." + "mode": { + "enum": [ + "MODE_UNSPECIFIED", + "MODE_DYNAMIC" + ], + "x-enum-descriptions": [ + "Always trigger retrieval.", + "Run retrieval only when system decides it is necessary." + ], + "type": "string", + "description": "The mode of the predictor to be used in dynamic retrieval." }, - "imageSearch": { - "$ref": "#/components/schemas/ImageSearch", - "description": "Optional. Enables image search. Image bytes are returned." + "dynamicThreshold": { + "description": "The threshold to be used in dynamic retrieval. If not set, a system default value is used.", + "format": "float", + "type": "number" } }, "type": "object", - "description": "Different types of search that can be enabled on the GoogleSearch tool." + "description": "Describes the options to customize dynamic retrieval." }, - "LatLng": { - "type": "object", + "GeneratedFile": { "properties": { - "longitude": { - "description": "The longitude in degrees. It must be in the range [-180.0, +180.0].", - "type": "number", - "format": "double" + "name": { + "type": "string", + "description": "Identifier. The name of the generated file. Example: `generatedFiles/abc-123`" }, - "latitude": { - "type": "number", - "format": "double", - "description": "The latitude in degrees. It must be in the range [-90.0, +90.0]." - } - }, - "description": "An object that represents a latitude/longitude pair. This is expressed as a pair of doubles to represent degrees latitude and degrees longitude. Unless specified otherwise, this object must conform to the WGS84 standard. Values must be within normalized ranges." - }, - "ResponseFormatConfig": { - "description": "Configuration for the response output format. This is a flat object where each optional sub-field configures a specific output modality.", - "properties": { - "audio": { - "description": "Optional. Audio output format configuration.", - "$ref": "#/components/schemas/AudioResponseFormat" + "state": { + "readOnly": true, + "x-enum-descriptions": [ + "The default value. This value is used if the state is omitted.", + "Being generated.", + "Generated and is ready for download.", + "Failed to generate the GeneratedFile." + ], + "type": "string", + "enum": [ + "STATE_UNSPECIFIED", + "GENERATING", + "GENERATED", + "FAILED" + ], + "description": "Output only. The state of the GeneratedFile." }, - "image": { - "description": "Optional. Image output format configuration.", - "$ref": "#/components/schemas/ImageResponseFormat" + "error": { + "description": "Error details if the GeneratedFile ends up in the STATE_FAILED state.", + "$ref": "#/components/schemas/Status" }, - "text": { - "description": "Optional. Text output format configuration.", - "$ref": "#/components/schemas/TextResponseFormat" + "mimeType": { + "type": "string", + "description": "MIME type of the generatedFile." } }, + "description": "A file generated on behalf of a user.", "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.", + "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": { - "name": { - "description": "Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128.", - "type": "string" - }, - "args": { - "description": "Optional. The function parameters and values in JSON object format.", - "additionalProperties": { - "description": "Properties of the object." - }, - "type": "object" - }, - "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" + "whiteSpaceConfig": { + "$ref": "#/components/schemas/WhiteSpaceConfig", + "description": "White space chunking configuration." } } }, - "ImportFileRequest": { + "GroundingMetadata": { "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" - }, - "customMetadata": { + "imageSearchQueries": { + "description": "Image search queries used for grounding.", "type": "array", - "description": "Custom metadata to be associated with the file.", "items": { - "$ref": "#/components/schemas/CustomMetadata" + "type": "string" } }, - "fileName": { - "description": "Required. The name of the `File` to import. Example: `files/abc-123`", + "searchEntryPoint": { + "$ref": "#/components/schemas/SearchEntryPoint", + "description": "Optional. Google search entry for the following-up web searches." + }, + "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" - } - }, - "type": "object", - "description": "Request for `ImportFile` to import a File API file with a `FileSearchStore`." - }, - "ContentEmbedding": { - "type": "object", - "properties": { - "shape": { - "description": "This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048]).", + }, + "groundingChunks": { + "type": "array", "items": { - "type": "integer", - "format": "int32" + "$ref": "#/components/schemas/GroundingChunk" }, - "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." }, - "values": { + "groundingSupports": { + "description": "List of grounding support.", "type": "array", "items": { - "type": "number", - "format": "float" - }, - "description": "The embedding values. This is for 3P users only and will not be populated for 1P calls." + "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaGroundingSupport" + } + }, + "retrievalMetadata": { + "description": "Metadata related to retrieval in the grounding flow.", + "$ref": "#/components/schemas/RetrievalMetadata" + }, + "webSearchQueries": { + "description": "Web search queries for the following-up web search.", + "type": "array", + "items": { + "type": "string" + } } }, - "description": "A list of floats representing an embedding." + "type": "object", + "description": "Metadata returned to client when grounding is enabled." }, - "ImageResponseFormat": { - "description": "Configuration for image output format.", + "InlinedResponse": { "type": "object", + "description": "The response to a single request in the batch.", "properties": { - "delivery": { - "type": "string", - "enum": [ - "DELIVERY_UNSPECIFIED", - "INLINE", - "URI" - ], - "description": "Optional. The delivery mode for the image output.", - "x-enum-descriptions": [ - "Default value. This value is unused.", - "Image data is returned inline in the response.", - "Image data is returned as a URI." - ] - }, - "mimeType": { - "x-enum-descriptions": [ - "Default value. This value is unused.", - "JPEG image format." - ], - "description": "Optional. The MIME type of the image output.", - "type": "string", - "enum": [ - "MIME_TYPE_UNSPECIFIED", - "IMAGE_JPEG" - ] - }, - "aspectRatio": { - "type": "string", - "enum": [ - "ASPECT_RATIO_UNSPECIFIED", - "ASPECT_RATIO_ONE_BY_ONE", - "ASPECT_RATIO_TWO_BY_THREE", - "ASPECT_RATIO_THREE_BY_TWO", - "ASPECT_RATIO_THREE_BY_FOUR", - "ASPECT_RATIO_FOUR_BY_THREE", - "ASPECT_RATIO_FOUR_BY_FIVE", - "ASPECT_RATIO_FIVE_BY_FOUR", - "ASPECT_RATIO_NINE_BY_SIXTEEN", - "ASPECT_RATIO_SIXTEEN_BY_NINE", - "ASPECT_RATIO_TWENTY_ONE_BY_NINE", - "ASPECT_RATIO_ONE_BY_EIGHT", - "ASPECT_RATIO_EIGHT_BY_ONE", - "ASPECT_RATIO_ONE_BY_FOUR", - "ASPECT_RATIO_FOUR_BY_ONE" - ], - "description": "Optional. The aspect ratio for the image output.", - "x-enum-descriptions": [ - "Default value. This value is unused.", - "1:1 aspect ratio.", - "2:3 aspect ratio.", - "3:2 aspect ratio.", - "3:4 aspect ratio.", - "4:3 aspect ratio.", - "4:5 aspect ratio.", - "5:4 aspect ratio.", - "9:16 aspect ratio.", - "16:9 aspect ratio.", - "21:9 aspect ratio.", - "1:8 aspect ratio.", - "8:1 aspect ratio.", - "1:4 aspect ratio.", - "4:1 aspect ratio." - ] + "error": { + "readOnly": true, + "$ref": "#/components/schemas/Status", + "description": "Output only. The error encountered while processing the request." }, - "imageSize": { - "description": "Optional. The size of the image output.", - "x-enum-descriptions": [ - "Default value. This value is unused.", - "512px image size.", - "1K image size.", - "2K image size.", - "4K image size." - ], - "type": "string", - "enum": [ - "IMAGE_SIZE_UNSPECIFIED", - "IMAGE_SIZE_FIVE_TWELVE", - "IMAGE_SIZE_ONE_K", - "IMAGE_SIZE_TWO_K", - "IMAGE_SIZE_FOUR_K" - ] + "response": { + "description": "Output only. The response to the request.", + "$ref": "#/components/schemas/GenerateContentResponse", + "readOnly": true + }, + "metadata": { + "type": "object", + "description": "Output only. The metadata associated with the request.", + "additionalProperties": { + "description": "Properties of the object." + }, + "readOnly": true } } }, - "TransferOwnershipResponse": { - "description": "Response from `TransferOwnership`.", + "Empty": { "properties": {}, - "type": "object" + "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); }" }, - "GeneratedFile": { + "EmbedContentRequest": { "type": "object", + "description": "Request containing the `Content` for the model to embed.", "properties": { - "name": { - "description": "Identifier. The name of the generated file. Example: `generatedFiles/abc-123`", - "type": "string" - }, - "error": { - "$ref": "#/components/schemas/Status", - "description": "Error details if the GeneratedFile ends up in the STATE_FAILED state." + "outputDimensionality": { + "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`).", + "format": "int32", + "type": "integer", + "deprecated": true }, - "mimeType": { - "description": "MIME type of the generatedFile.", + "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" }, - "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, + "content": { + "description": "Required. The content to embed. Only the `parts.text` fields will be counted.", + "$ref": "#/components/schemas/Content" + }, + "taskType": { "enum": [ - "STATE_UNSPECIFIED", - "GENERATING", - "GENERATED", - "FAILED" + "TASK_TYPE_UNSPECIFIED", + "RETRIEVAL_QUERY", + "RETRIEVAL_DOCUMENT", + "SEMANTIC_SIMILARITY", + "CLASSIFICATION", + "CLUSTERING", + "QUESTION_ANSWERING", + "FACT_VERIFICATION", + "CODE_RETRIEVAL_QUERY" + ], + "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`).", + "deprecated": true, + "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." ], - "type": "string" - } - }, - "description": "A file generated on behalf of a user." - }, - "ReviewSnippet": { - "type": "object", - "properties": { - "googleMapsUri": { - "description": "A link that corresponds to the user review on Google Maps.", "type": "string" }, "title": { - "description": "Title of the review.", - "type": "string" + "type": "string", + "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 }, - "reviewId": { - "description": "The ID of the review snippet.", - "type": "string" + "embedContentConfig": { + "$ref": "#/components/schemas/EmbedContentConfig", + "description": "Optional. Configuration for the EmbedContent request." } - }, - "description": "Encapsulates a snippet of a user review that answers a question about the features of a specific place in Google Maps." + } }, - "GoogleAiGenerativelanguageV1betaSegment": { - "description": "Segment of the content.", + "Content": { + "type": "object", + "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": { - "partIndex": { - "type": "integer", - "format": "int32", - "description": "The index of a Part object within its parent Content object." - }, - "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." - }, - "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" + "parts": { + "type": "array", + "items": { + "$ref": "#/components/schemas/Part" + }, + "description": "Ordered `Parts` that constitute a single message. Parts may have different MIME types." }, - "text": { - "description": "The text corresponding to the segment from the response.", - "type": "string" + "role": { + "type": "string", + "description": "Optional. The producer of the content. Must be either 'user' or 'model'. Useful to set for multi-turn conversations, otherwise can be left blank or unset." } - }, - "type": "object" + } }, - "EmbedContentBatchStats": { - "description": "Stats about the batch.", + "ImportFileRequest": { "properties": { - "requestCount": { - "readOnly": true, - "type": "string", - "format": "int64", - "description": "Output only. The number of requests in the batch." - }, - "failedRequestCount": { - "readOnly": true, - "type": "string", - "format": "int64", - "description": "Output only. The number of requests that failed to be processed." + "customMetadata": { + "type": "array", + "items": { + "$ref": "#/components/schemas/CustomMetadata" + }, + "description": "Custom metadata to be associated with the file." }, - "pendingRequestCount": { - "description": "Output only. The number of requests that are still pending processing.", - "readOnly": true, + "fileName": { "type": "string", - "format": "int64" + "description": "Required. The name of the `File` to import. Example: `files/abc-123`" }, - "successfulRequestCount": { - "description": "Output only. The number of requests that were successfully processed.", - "readOnly": true, - "type": "string", - "format": "int64" + "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" } }, - "type": "object" + "type": "object", + "description": "Request for `ImportFile` to import a File API file with a `FileSearchStore`." }, - "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.", + "ResponseFormatConfig": { "properties": { - "reviewSnippets": { - "items": { - "$ref": "#/components/schemas/ReviewSnippet" - }, - "description": "Snippets of reviews that are used to generate answers about the features of a given place in Google Maps.", - "type": "array" + "text": { + "$ref": "#/components/schemas/TextResponseFormat", + "description": "Optional. Text output format configuration." + }, + "audio": { + "description": "Optional. Audio output format configuration.", + "$ref": "#/components/schemas/AudioResponseFormat" + }, + "image": { + "description": "Optional. Image output format configuration.", + "$ref": "#/components/schemas/ImageResponseFormat" } }, - "type": "object" + "type": "object", + "description": "Configuration for the response output format. This is a flat object where each optional sub-field configures a specific output modality." }, "GroundingChunkCustomMetadata": { "type": "object", + "description": "User provided metadata about the GroundingFact.", "properties": { - "key": { - "description": "The key of the metadata.", - "type": "string" - }, "stringValue": { "description": "Optional. The string value of the metadata.", "type": "string" }, + "key": { + "type": "string", + "description": "The key of the metadata." + }, "stringListValue": { "$ref": "#/components/schemas/GroundingChunkStringList", "description": "Optional. A list of string values for the metadata." }, "numericValue": { - "type": "number", + "description": "Optional. The numeric value of the metadata. The expected range for this value depends on the specific `key` used.", "format": "float", - "description": "Optional. The numeric value of the metadata. The expected range for this value depends on the specific `key` used." + "type": "number" } - }, - "description": "User provided metadata about the GroundingFact." + } }, - "UrlContextMetadata": { - "description": "Metadata related to url context retrieval tool.", - "type": "object", + "MultiSpeakerVoiceConfig": { "properties": { - "urlMetadata": { + "speakerVoiceConfigs": { "type": "array", "items": { - "$ref": "#/components/schemas/UrlMetadata" + "$ref": "#/components/schemas/SpeakerVoiceConfig" }, - "description": "List of url context." - } - } - }, - "EmbedContentBatchOutput": { - "description": "The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.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 `EmbedContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests." - }, - "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 - } - }, - "type": "object" - }, - "ImageConfig": { - "description": "Config for image generation features.", - "properties": { - "aspectRatio": { - "description": "Optional. The aspect ratio of the image to generate. Supported aspect ratios: `1:1`, `1:4`, `4:1`, `1:8`, `8:1`, `2:3`, `3:2`, `3:4`, `4:3`, `4:5`, `5:4`, `9:16`, `16:9`, or `21:9`. If not specified, the model will choose a default aspect ratio based on any reference images provided.", - "type": "string" - }, - "imageSize": { - "description": "Optional. Specifies the size of generated images. Supported values are `512`, `1K`, `2K`, `4K`. If not specified, the model will use default value `1K`.", - "type": "string" + "description": "Required. All the enabled speaker voices." } }, + "description": "The configuration for the multi-speaker setup.", "type": "object" }, - "RetrievedContext": { - "type": "object", - "properties": { - "mediaId": { - "description": "Optional. The media blob resource name for multimodal file search results. Format: fileSearchStores/{file_search_store_id}/media/{blob_id}", - "type": "string" - }, - "uri": { - "description": "Optional. URI reference of the semantic retrieval document.", - "type": "string" - }, - "pageNumber": { - "description": "Optional. Page number of the retrieved context, if applicable.", - "type": "integer", - "format": "int32" - }, - "text": { - "description": "Optional. Text of the chunk.", - "type": "string" - }, - "title": { - "description": "Optional. Title of the document.", - "type": "string" - }, - "fileSearchStore": { - "description": "Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123`", - "type": "string" - }, - "customMetadata": { - "description": "Optional. User-provided metadata about the retrieved context.", - "items": { - "$ref": "#/components/schemas/GroundingChunkCustomMetadata" - }, - "type": "array" - } - }, - "description": "Chunk from context retrieved by the file search tool." - }, - "ListGeneratedFilesResponse": { - "description": "Response for `ListGeneratedFiles`.", + "CachedContentUsageMetadata": { "properties": { - "generatedFiles": { - "description": "The list of `GeneratedFile`s.", - "items": { - "$ref": "#/components/schemas/GeneratedFile" - }, - "type": "array" - }, - "nextPageToken": { - "description": "A token that can be sent as a `page_token` into a subsequent `ListGeneratedFiles` call.", - "type": "string" + "totalTokenCount": { + "description": "Total number of tokens that the cached content consumes.", + "format": "int32", + "type": "integer" } }, + "description": "Metadata on the usage of the cached content.", "type": "object" } }