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 8f242380..514f57b6 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 @@ -454,8 +454,8 @@ partial void ProcessBatchesUpdateEmbedContentBatchResponseContent( /// /// 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. + /// + /// Stats about the batch. /// /// /// Required. The user-defined name of this batch. @@ -463,8 +463,8 @@ partial void ProcessBatchesUpdateEmbedContentBatchResponseContent( /// /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. /// - /// - /// Stats about the batch. + /// + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -474,10 +474,10 @@ partial void ProcessBatchesUpdateEmbedContentBatchResponseContent( string? updateMask = default, string? model = default, global::Google.Gemini.InputEmbedContentConfig? inputConfig = default, - string? priority = default, + global::Google.Gemini.EmbedContentBatchStats? batchStats = default, string? displayName = default, global::Google.Gemini.EmbedContentBatchOutput? output = default, - global::Google.Gemini.EmbedContentBatchStats? batchStats = default, + string? priority = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { @@ -485,10 +485,10 @@ partial void ProcessBatchesUpdateEmbedContentBatchResponseContent( { Model = model, InputConfig = inputConfig, - Priority = priority, + BatchStats = batchStats, DisplayName = displayName, Output = output, - BatchStats = batchStats, + Priority = priority, }; 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 21942f6b..e100ef6c 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 @@ -448,14 +448,14 @@ partial void ProcessBatchesUpdateGenerateContentBatchResponseContent( /// /// /// - /// - /// 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}`. /// /// /// Configures the input to the batch request. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// Stats about the batch. /// /// /// Required. The user-defined name of this batch. @@ -463,8 +463,8 @@ partial void ProcessBatchesUpdateGenerateContentBatchResponseContent( /// /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. /// - /// - /// Stats about the batch. + /// + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -472,23 +472,23 @@ partial void ProcessBatchesUpdateGenerateContentBatchResponseContent( public async global::System.Threading.Tasks.Task BatchesUpdateGenerateContentBatchAsync( string batchesId, string? updateMask = default, - string? priority = default, - global::Google.Gemini.InputConfig? inputConfig = default, string? model = default, + global::Google.Gemini.InputConfig? inputConfig = default, + global::Google.Gemini.BatchStats? batchStats = default, string? displayName = default, global::Google.Gemini.GenerateContentBatchOutput? output = default, - global::Google.Gemini.BatchStats? batchStats = default, + string? priority = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentBatch { - Priority = priority, - InputConfig = inputConfig, Model = model, + InputConfig = inputConfig, + BatchStats = batchStats, DisplayName = displayName, Output = output, - BatchStats = batchStats, + Priority = priority, }; 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 57ec749f..157cba4a 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,8 +425,14 @@ partial void ProcessCachedContentsCreateResponseContent( /// /// Creates CachedContent resource. /// - /// - /// 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. + /// + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` @@ -434,8 +440,11 @@ partial void ProcessCachedContentsCreateResponseContent( /// /// Input only. New TTL for this resource, input only. /// - /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// Metadata on the usage of the cached content. + /// + /// + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// /// /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. @@ -443,42 +452,33 @@ partial void ProcessCachedContentsCreateResponseContent( /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Metadata on the usage of the cached 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. - /// - /// - /// Optional. Input only. Immutable. The content to cache. - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task CachedContentsCreateAsync( - string? expireTime = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.Content? systemInstruction = default, string? model = default, string? ttl = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, + string? expireTime = default, string? displayName = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - global::Google.Gemini.Content? systemInstruction = 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.CachedContent { - ExpireTime = expireTime, + Contents = contents, + Tools = tools, + SystemInstruction = systemInstruction, Model = model, Ttl = ttl, - Tools = tools, + UsageMetadata = usageMetadata, + ExpireTime = expireTime, DisplayName = displayName, ToolConfig = toolConfig, - UsageMetadata = usageMetadata, - SystemInstruction = systemInstruction, - Contents = contents, }; 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 bf188a13..90cac7c5 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,8 +448,14 @@ partial void ProcessCachedContentsPatchResponseContent( /// /// /// - /// - /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. + /// + /// Optional. Input only. Immutable. The content to cache. + /// + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` @@ -457,8 +463,11 @@ partial void ProcessCachedContentsPatchResponseContent( /// /// Input only. New TTL for this resource, input only. /// - /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// Metadata on the usage of the cached content. + /// + /// + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// /// /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. @@ -466,44 +475,35 @@ partial void ProcessCachedContentsPatchResponseContent( /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Metadata on the usage of the cached 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. - /// - /// - /// Optional. Input only. Immutable. The content to cache. - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task CachedContentsPatchAsync( string cachedContentsId, string? updateMask = default, - string? expireTime = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.Content? systemInstruction = default, string? model = default, string? ttl = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, + string? expireTime = default, string? displayName = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - global::Google.Gemini.Content? systemInstruction = 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.CachedContent { - ExpireTime = expireTime, + Contents = contents, + Tools = tools, + SystemInstruction = systemInstruction, Model = model, Ttl = ttl, - Tools = tools, + UsageMetadata = usageMetadata, + ExpireTime = expireTime, DisplayName = displayName, ToolConfig = toolConfig, - UsageMetadata = usageMetadata, - SystemInstruction = systemInstruction, - Contents = contents, }; 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 5e53cccf..0167d56a 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 @@ -435,31 +435,31 @@ partial void ProcessCorporaPermissionsCreateResponseContent( /// Create a permission to a specific resource. /// /// - /// - /// 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 type of the grantee. + /// /// 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, string? emailAddress = default, global::Google.Gemini.PermissionRole? role = default, + global::Google.Gemini.PermissionGranteeType? granteeType = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.Permission { - GranteeType = granteeType, EmailAddress = emailAddress, Role = role, + GranteeType = granteeType, }; 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 ed2f0c85..5b7d23da 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 @@ -458,15 +458,15 @@ partial void ProcessCorporaPermissionsPatchResponseContent( /// /// /// - /// - /// 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 type of the grantee. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// @@ -474,17 +474,17 @@ partial void ProcessCorporaPermissionsPatchResponseContent( string permissionsId, string corporaId, string? updateMask = default, - global::Google.Gemini.PermissionGranteeType? granteeType = default, string? emailAddress = default, global::Google.Gemini.PermissionRole? role = default, + global::Google.Gemini.PermissionGranteeType? granteeType = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.Permission { - GranteeType = granteeType, EmailAddress = emailAddress, Role = role, + GranteeType = granteeType, }; 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 47258c94..f8f85288 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,17 +435,11 @@ 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 name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// /// Optional. The service tier of the request. @@ -456,45 +450,51 @@ partial void ProcessDynamicGenerateContentResponseContent( /// /// 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. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// /// 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, - string? model = default, - string? cachedContent = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? contents = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, + global::System.Collections.Generic.IList? tools = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Model = model, - CachedContent = cachedContent, ToolConfig = toolConfig, - Tools = tools, + GenerationConfig = generationConfig, ServiceTier = serviceTier, SystemInstruction = systemInstruction, Contents = contents, - SafetySettings = safetySettings, - GenerationConfig = generationConfig, + Tools = tools, + CachedContent = cachedContent, Store = store, + Model = model, + SafetySettings = safetySettings, }; 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 3361d37b..f0eb14aa 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,17 +435,11 @@ 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 name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// /// Optional. The service tier of the request. @@ -456,45 +450,51 @@ partial void ProcessDynamicStreamGenerateContentResponseContent( /// /// 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. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// /// 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, - string? model = default, - string? cachedContent = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? contents = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, + global::System.Collections.Generic.IList? tools = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Model = model, - CachedContent = cachedContent, ToolConfig = toolConfig, - Tools = tools, + GenerationConfig = generationConfig, ServiceTier = serviceTier, SystemInstruction = systemInstruction, Contents = contents, - SafetySettings = safetySettings, - GenerationConfig = generationConfig, + Tools = tools, + CachedContent = cachedContent, Store = store, + Model = model, + SafetySettings = safetySettings, }; 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 993199f3..7a809070 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,17 +376,11 @@ 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 name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// /// Optional. The service tier of the request. @@ -397,45 +391,51 @@ partial void ProcessDynamicStreamGenerateContentAsStreamResponse( /// /// 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. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// /// 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, - string? model = default, - string? cachedContent = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? contents = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, + global::System.Collections.Generic.IList? tools = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, [global::System.Runtime.CompilerServices.EnumeratorCancellation] global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Model = model, - CachedContent = cachedContent, ToolConfig = toolConfig, - Tools = tools, + GenerationConfig = generationConfig, ServiceTier = serviceTier, SystemInstruction = systemInstruction, Contents = contents, - SafetySettings = safetySettings, - GenerationConfig = generationConfig, + Tools = tools, + CachedContent = cachedContent, Store = store, + Model = model, + SafetySettings = safetySettings, }; var __enumerable = DynamicStreamGenerateContentAsStreamAsync( 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..05ef9bc7 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`. /// /// + /// + /// 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 /// /// /// Custom metadata to be associated with the file. /// - /// - /// Required. The name of the `File` to import. Example: `files/abc-123` - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task FileSearchStoresImportFileAsync( string fileSearchStoresId, + string? fileName = default, global::Google.Gemini.ChunkingConfig? chunkingConfig = default, global::System.Collections.Generic.IList? customMetadata = default, - string? fileName = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.ImportFileRequest { + FileName = fileName, ChunkingConfig = chunkingConfig, CustomMetadata = customMetadata, - FileName = fileName, }; return await FileSearchStoresImportFileAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.MediaUploadToFileSearchStore.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.MediaUploadToFileSearchStore.g.cs index 6f4340d9..dbe30ef1 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.MediaUploadToFileSearchStore.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.MediaUploadToFileSearchStore.g.cs @@ -438,12 +438,12 @@ partial void ProcessMediaUploadToFileSearchStoreResponseContent( /// /// Optional. Display name of the created document. /// - /// - /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto - /// /// /// Custom metadata to be associated with the data. /// + /// + /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto + /// /// /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. /// @@ -453,8 +453,8 @@ partial void ProcessMediaUploadToFileSearchStoreResponseContent( public async global::System.Threading.Tasks.Task MediaUploadToFileSearchStoreAsync( string fileSearchStoresId, string? displayName = default, - global::Google.Gemini.ChunkingConfig? chunkingConfig = default, global::System.Collections.Generic.IList? customMetadata = default, + global::Google.Gemini.ChunkingConfig? chunkingConfig = default, string? mimeType = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) @@ -462,8 +462,8 @@ partial void ProcessMediaUploadToFileSearchStoreResponseContent( var __request = new global::Google.Gemini.UploadToFileSearchStoreRequest { DisplayName = displayName, - ChunkingConfig = chunkingConfig, CustomMetadata = customMetadata, + ChunkingConfig = chunkingConfig, MimeType = mimeType, }; 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 e1d939a4..fee650dd 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. /// /// - /// - /// 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. /// + /// + /// Request to generate a completion from the model. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task ModelsCountTokensAsync( string modelsId, - global::Google.Gemini.GenerateContentRequest? generateContentRequest = default, global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.GenerateContentRequest? generateContentRequest = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.CountTokensRequest { - GenerateContentRequest = generateContentRequest, Contents = contents, + GenerateContentRequest = generateContentRequest, }; 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 6d0e9cc9..9181ee76 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 @@ -440,28 +440,28 @@ partial void ProcessModelsEmbedContentResponseContent( /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// - /// - /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` - /// /// /// Configurations for the EmbedContent request. /// + /// + /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task ModelsEmbedContentAsync( string modelsId, global::Google.Gemini.Content? content = default, - string? model = default, global::Google.Gemini.EmbedContentConfig? embedContentConfig = default, + string? model = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.EmbedContentRequest { Content = content, - Model = model, EmbedContentConfig = embedContentConfig, + Model = model, }; return await ModelsEmbedContentAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsGenerateContent.g.cs index a745030e..338b9c58 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,17 +435,11 @@ 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 name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// /// Optional. The service tier of the request. @@ -456,45 +450,51 @@ partial void ProcessModelsGenerateContentResponseContent( /// /// 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. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// /// 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, - string? model = default, - string? cachedContent = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? contents = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, + global::System.Collections.Generic.IList? tools = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Model = model, - CachedContent = cachedContent, ToolConfig = toolConfig, - Tools = tools, + GenerationConfig = generationConfig, ServiceTier = serviceTier, SystemInstruction = systemInstruction, Contents = contents, - SafetySettings = safetySettings, - GenerationConfig = generationConfig, + Tools = tools, + CachedContent = cachedContent, Store = store, + Model = model, + SafetySettings = safetySettings, }; 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 ab55223a..2786e5dc 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,17 +435,11 @@ 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 name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// /// Optional. The service tier of the request. @@ -456,45 +450,51 @@ partial void ProcessModelsStreamGenerateContentResponseContent( /// /// 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. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// /// 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, - string? model = default, - string? cachedContent = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? contents = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, + global::System.Collections.Generic.IList? tools = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Model = model, - CachedContent = cachedContent, ToolConfig = toolConfig, - Tools = tools, + GenerationConfig = generationConfig, ServiceTier = serviceTier, SystemInstruction = systemInstruction, Contents = contents, - SafetySettings = safetySettings, - GenerationConfig = generationConfig, + Tools = tools, + CachedContent = cachedContent, Store = store, + Model = model, + SafetySettings = safetySettings, }; 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 0f8a6563..773dde77 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,17 +376,11 @@ 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 name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// /// Optional. The service tier of the request. @@ -397,45 +391,51 @@ partial void ProcessModelsStreamGenerateContentAsStreamResponse( /// /// 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. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// /// 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, - string? model = default, - string? cachedContent = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? contents = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, + global::System.Collections.Generic.IList? tools = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, [global::System.Runtime.CompilerServices.EnumeratorCancellation] global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Model = model, - CachedContent = cachedContent, ToolConfig = toolConfig, - Tools = tools, + GenerationConfig = generationConfig, ServiceTier = serviceTier, SystemInstruction = systemInstruction, Contents = contents, - SafetySettings = safetySettings, - GenerationConfig = generationConfig, + Tools = tools, + CachedContent = cachedContent, Store = store, + Model = model, + SafetySettings = safetySettings, }; 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 d3ffb76f..b9544adb 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 /// /// - /// - /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. - /// - /// - /// Optional. 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. A short description of this model. + /// + /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. /// /// /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` /// - /// - /// Tuning tasks that create tuned models. + /// + /// Optional. List of project numbers that have read access to the tuned model. + /// + /// + /// Tuned model as a source for training a new model. /// /// /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Tuned model as a source for training a new model. + /// + /// Optional. A short description of this model. /// - /// - /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. + /// + /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. + /// + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// /// 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, - float? temperature = default, - string? displayName = default, - string? description = default, - string? baseModel = default, global::Google.Gemini.TuningTask? tuningTask = default, - float? topP = default, - global::Google.Gemini.TunedModelSource? tunedModelSource = default, int? topK = default, + string? baseModel = default, global::System.Collections.Generic.IList? readerProjectNumbers = default, + global::Google.Gemini.TunedModelSource? tunedModelSource = default, + float? topP = default, + string? description = default, + float? temperature = default, + string? displayName = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.TunedModel { - Temperature = temperature, - DisplayName = displayName, - Description = description, - BaseModel = baseModel, TuningTask = tuningTask, - TopP = topP, - TunedModelSource = tunedModelSource, TopK = topK, + BaseModel = baseModel, ReaderProjectNumbers = readerProjectNumbers, + TunedModelSource = tunedModelSource, + TopP = topP, + Description = description, + Temperature = temperature, + DisplayName = displayName, }; 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 bec223dc..39a9095d 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,17 +435,11 @@ 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 name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// /// Optional. The service tier of the request. @@ -456,45 +450,51 @@ partial void ProcessTunedModelsGenerateContentResponseContent( /// /// 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. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// /// 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, - string? model = default, - string? cachedContent = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? contents = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, + global::System.Collections.Generic.IList? tools = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Model = model, - CachedContent = cachedContent, ToolConfig = toolConfig, - Tools = tools, + GenerationConfig = generationConfig, ServiceTier = serviceTier, SystemInstruction = systemInstruction, Contents = contents, - SafetySettings = safetySettings, - GenerationConfig = generationConfig, + Tools = tools, + CachedContent = cachedContent, Store = store, + Model = model, + SafetySettings = safetySettings, }; 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 0e07f1cf..ca375d4d 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,32 +448,32 @@ partial void ProcessTunedModelsPatchResponseContent( /// /// /// - /// - /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. - /// - /// - /// Optional. 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. A short description of this model. + /// + /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. /// /// /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` /// - /// - /// Tuning tasks that create tuned models. + /// + /// Optional. List of project numbers that have read access to the tuned model. + /// + /// + /// Tuned model as a source for training a new model. /// /// /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Tuned model as a source for training a new model. + /// + /// Optional. A short description of this model. /// - /// - /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. + /// + /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. + /// + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -481,29 +481,29 @@ partial void ProcessTunedModelsPatchResponseContent( public async global::System.Threading.Tasks.Task TunedModelsPatchAsync( string tunedModelsId, string? updateMask = default, - float? temperature = default, - string? displayName = default, - string? description = default, - string? baseModel = default, global::Google.Gemini.TuningTask? tuningTask = default, - float? topP = default, - global::Google.Gemini.TunedModelSource? tunedModelSource = default, int? topK = default, + string? baseModel = default, global::System.Collections.Generic.IList? readerProjectNumbers = default, + global::Google.Gemini.TunedModelSource? tunedModelSource = default, + float? topP = default, + string? description = default, + float? temperature = default, + string? displayName = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.TunedModel { - Temperature = temperature, - DisplayName = displayName, - Description = description, - BaseModel = baseModel, TuningTask = tuningTask, - TopP = topP, - TunedModelSource = tunedModelSource, TopK = topK, + BaseModel = baseModel, ReaderProjectNumbers = readerProjectNumbers, + TunedModelSource = tunedModelSource, + TopP = topP, + Description = description, + Temperature = temperature, + DisplayName = displayName, }; 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 9e0209cf..58eaf040 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 @@ -435,31 +435,31 @@ partial void ProcessTunedModelsPermissionsCreateResponseContent( /// Create a permission to a specific resource. /// /// - /// - /// 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 type of the grantee. + /// /// 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, string? emailAddress = default, global::Google.Gemini.PermissionRole? role = default, + global::Google.Gemini.PermissionGranteeType? granteeType = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.Permission { - GranteeType = granteeType, EmailAddress = emailAddress, Role = role, + GranteeType = granteeType, }; 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 2e627ccb..36931011 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 @@ -458,15 +458,15 @@ partial void ProcessTunedModelsPermissionsPatchResponseContent( /// /// /// - /// - /// 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 type of the grantee. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// @@ -474,17 +474,17 @@ partial void ProcessTunedModelsPermissionsPatchResponseContent( string tunedModelsId, string permissionsId, string? updateMask = default, - global::Google.Gemini.PermissionGranteeType? granteeType = default, string? emailAddress = default, global::Google.Gemini.PermissionRole? role = default, + global::Google.Gemini.PermissionGranteeType? granteeType = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.Permission { - GranteeType = granteeType, EmailAddress = emailAddress, Role = role, + GranteeType = granteeType, }; 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 0fa12be8..f6de896f 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,17 +435,11 @@ 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 name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// /// Optional. The service tier of the request. @@ -456,45 +450,51 @@ partial void ProcessTunedModelsStreamGenerateContentResponseContent( /// /// 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. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// /// 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, - string? model = default, - string? cachedContent = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? contents = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, + global::System.Collections.Generic.IList? tools = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Model = model, - CachedContent = cachedContent, ToolConfig = toolConfig, - Tools = tools, + GenerationConfig = generationConfig, ServiceTier = serviceTier, SystemInstruction = systemInstruction, Contents = contents, - SafetySettings = safetySettings, - GenerationConfig = generationConfig, + Tools = tools, + CachedContent = cachedContent, Store = store, + Model = model, + SafetySettings = safetySettings, }; 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 ed735f51..201973fc 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,17 +376,11 @@ 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 name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// /// Optional. The service tier of the request. @@ -397,45 +391,51 @@ partial void ProcessTunedModelsStreamGenerateContentAsStreamResponse( /// /// 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. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// /// 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, - string? model = default, - string? cachedContent = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? contents = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, + global::System.Collections.Generic.IList? tools = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, [global::System.Runtime.CompilerServices.EnumeratorCancellation] global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Model = model, - CachedContent = cachedContent, ToolConfig = toolConfig, - Tools = tools, + GenerationConfig = generationConfig, ServiceTier = serviceTier, SystemInstruction = systemInstruction, Contents = contents, - SafetySettings = safetySettings, - GenerationConfig = generationConfig, + Tools = tools, + CachedContent = cachedContent, Store = store, + Model = model, + SafetySettings = safetySettings, }; 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 88ab5ebe..e199921c 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 @@ -47,8 +47,8 @@ public partial interface IGeminiClient /// /// 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. + /// + /// Stats about the batch. /// /// /// Required. The user-defined name of this batch. @@ -56,8 +56,8 @@ public partial interface IGeminiClient /// /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. /// - /// - /// Stats about the batch. + /// + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -67,10 +67,10 @@ public partial interface IGeminiClient string? updateMask = default, string? model = default, global::Google.Gemini.InputEmbedContentConfig? inputConfig = default, - string? priority = default, + global::Google.Gemini.EmbedContentBatchStats? batchStats = default, string? displayName = default, global::Google.Gemini.EmbedContentBatchOutput? output = default, - global::Google.Gemini.EmbedContentBatchStats? batchStats = default, + string? priority = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.BatchesUpdateGenerateContentBatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.BatchesUpdateGenerateContentBatch.g.cs index 9fa03aa2..2001d139 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.BatchesUpdateGenerateContentBatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.BatchesUpdateGenerateContentBatch.g.cs @@ -41,14 +41,14 @@ public partial interface IGeminiClient /// /// /// - /// - /// 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}`. /// /// /// Configures the input to the batch request. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// Stats about the batch. /// /// /// Required. The user-defined name of this batch. @@ -56,8 +56,8 @@ public partial interface IGeminiClient /// /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. /// - /// - /// Stats about the batch. + /// + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -65,12 +65,12 @@ public partial interface IGeminiClient global::System.Threading.Tasks.Task BatchesUpdateGenerateContentBatchAsync( string batchesId, string? updateMask = default, - string? priority = default, - global::Google.Gemini.InputConfig? inputConfig = default, string? model = default, + global::Google.Gemini.InputConfig? inputConfig = default, + global::Google.Gemini.BatchStats? batchStats = default, string? displayName = default, global::Google.Gemini.GenerateContentBatchOutput? output = default, - global::Google.Gemini.BatchStats? batchStats = default, + string? priority = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsCreate.g.cs index 27f62072..68ba3077 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,8 +31,14 @@ public partial interface IGeminiClient /// /// Creates CachedContent resource. /// - /// - /// 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. + /// + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` @@ -40,8 +46,11 @@ public partial interface IGeminiClient /// /// Input only. New TTL for this resource, input only. /// - /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// Metadata on the usage of the cached content. + /// + /// + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// /// /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. @@ -49,28 +58,19 @@ public partial interface IGeminiClient /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Metadata on the usage of the cached 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. - /// - /// - /// Optional. Input only. Immutable. The content to cache. - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task CachedContentsCreateAsync( - string? expireTime = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.Content? systemInstruction = default, string? model = default, string? ttl = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, + string? expireTime = default, string? displayName = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - global::Google.Gemini.Content? systemInstruction = 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.CachedContentsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsPatch.g.cs index 469e2892..f0b793a6 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,8 +41,14 @@ public partial interface IGeminiClient /// /// /// - /// - /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. + /// + /// Optional. Input only. Immutable. The content to cache. + /// + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` @@ -50,8 +56,11 @@ public partial interface IGeminiClient /// /// Input only. New TTL for this resource, input only. /// - /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// Metadata on the usage of the cached content. + /// + /// + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// /// /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. @@ -59,30 +68,21 @@ public partial interface IGeminiClient /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Metadata on the usage of the cached 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. - /// - /// - /// Optional. Input only. Immutable. The content to cache. - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task CachedContentsPatchAsync( string cachedContentsId, string? updateMask = default, - string? expireTime = default, + global::System.Collections.Generic.IList? contents = default, + global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.Content? systemInstruction = default, string? model = default, string? ttl = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, + string? expireTime = default, string? displayName = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - global::Google.Gemini.Content? systemInstruction = 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.CorporaPermissionsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsCreate.g.cs index 742c7e66..6862024b 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 @@ -36,23 +36,23 @@ public partial interface IGeminiClient /// Create a permission to a specific resource. /// /// - /// - /// 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 type of the grantee. + /// /// 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, string? emailAddress = default, global::Google.Gemini.PermissionRole? role = default, + global::Google.Gemini.PermissionGranteeType? granteeType = 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 b57a43d0..23ae22ac 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 @@ -46,15 +46,15 @@ public partial interface IGeminiClient /// /// /// - /// - /// 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 type of the grantee. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// @@ -62,9 +62,9 @@ public partial interface IGeminiClient string permissionsId, string corporaId, string? updateMask = default, - global::Google.Gemini.PermissionGranteeType? granteeType = default, string? emailAddress = default, global::Google.Gemini.PermissionRole? role = default, + global::Google.Gemini.PermissionGranteeType? granteeType = 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 ed78db6b..b881f3d0 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,17 +36,11 @@ 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 name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// /// Optional. The service tier of the request. @@ -57,30 +51,36 @@ public partial interface IGeminiClient /// /// 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. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// /// 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, - string? model = default, - string? cachedContent = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? contents = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, + global::System.Collections.Generic.IList? tools = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContent.g.cs index 87001d77..ab5f7ee0 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,17 +36,11 @@ 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 name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// /// Optional. The service tier of the request. @@ -57,30 +51,36 @@ public partial interface IGeminiClient /// /// 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. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// /// 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, - string? model = default, - string? cachedContent = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? contents = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, + global::System.Collections.Generic.IList? tools = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContentAsStream.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContentAsStream.g.cs index 9a2795fb..07922251 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,17 +22,11 @@ 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 name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// /// Optional. The service tier of the request. @@ -43,30 +37,36 @@ public partial interface IGeminiClient /// /// 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. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// /// 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, - string? model = default, - string? cachedContent = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? contents = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, + global::System.Collections.Generic.IList? tools = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresImportFile.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresImportFile.g.cs index 0b601d4b..95c834be 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`. /// /// + /// + /// 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 /// /// /// Custom metadata to be associated with the file. /// - /// - /// Required. The name of the `File` to import. Example: `files/abc-123` - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task FileSearchStoresImportFileAsync( string fileSearchStoresId, + string? fileName = default, global::Google.Gemini.ChunkingConfig? chunkingConfig = default, global::System.Collections.Generic.IList? customMetadata = default, - string? fileName = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.MediaUploadToFileSearchStore.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.MediaUploadToFileSearchStore.g.cs index 34a96add..490b5361 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.MediaUploadToFileSearchStore.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.MediaUploadToFileSearchStore.g.cs @@ -39,12 +39,12 @@ public partial interface IGeminiClient /// /// Optional. Display name of the created document. /// - /// - /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto - /// /// /// Custom metadata to be associated with the data. /// + /// + /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto + /// /// /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. /// @@ -54,8 +54,8 @@ public partial interface IGeminiClient global::System.Threading.Tasks.Task MediaUploadToFileSearchStoreAsync( string fileSearchStoresId, string? displayName = default, - global::Google.Gemini.ChunkingConfig? chunkingConfig = default, global::System.Collections.Generic.IList? customMetadata = default, + global::Google.Gemini.ChunkingConfig? chunkingConfig = default, string? mimeType = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsCountTokens.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsCountTokens.g.cs index e386931b..a6d6ed6c 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. /// /// - /// - /// 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. /// + /// + /// Request to generate a completion from the model. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task ModelsCountTokensAsync( string modelsId, - global::Google.Gemini.GenerateContentRequest? generateContentRequest = default, global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.GenerateContentRequest? generateContentRequest = 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 c9ec1671..a0ce1945 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsEmbedContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsEmbedContent.g.cs @@ -41,20 +41,20 @@ public partial interface IGeminiClient /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// - /// - /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` - /// /// /// Configurations for the EmbedContent request. /// + /// + /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task ModelsEmbedContentAsync( string modelsId, global::Google.Gemini.Content? content = default, - string? model = default, global::Google.Gemini.EmbedContentConfig? embedContentConfig = default, + string? model = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsGenerateContent.g.cs index 892a4e72..941b9128 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,17 +36,11 @@ 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 name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// /// Optional. The service tier of the request. @@ -57,30 +51,36 @@ public partial interface IGeminiClient /// /// 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. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// /// 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, - string? model = default, - string? cachedContent = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? contents = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, + global::System.Collections.Generic.IList? tools = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContent.g.cs index 529addf6..a7bec00c 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,17 +36,11 @@ 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 name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// /// Optional. The service tier of the request. @@ -57,30 +51,36 @@ public partial interface IGeminiClient /// /// 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. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// /// 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, - string? model = default, - string? cachedContent = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? contents = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, + global::System.Collections.Generic.IList? tools = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContentAsStream.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContentAsStream.g.cs index e52556a3..0722d1eb 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,17 +22,11 @@ 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 name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// /// Optional. The service tier of the request. @@ -43,30 +37,36 @@ public partial interface IGeminiClient /// /// 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. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// /// 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, - string? model = default, - string? cachedContent = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? contents = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, + global::System.Collections.Generic.IList? tools = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsCreate.g.cs index f49b4cec..fa8a5a24 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 /// /// - /// - /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. - /// - /// - /// Optional. 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. A short description of this model. + /// + /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. /// /// /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` /// - /// - /// Tuning tasks that create tuned models. + /// + /// Optional. List of project numbers that have read access to the tuned model. + /// + /// + /// Tuned model as a source for training a new model. /// /// /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Tuned model as a source for training a new model. + /// + /// Optional. A short description of this model. /// - /// - /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. + /// + /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. + /// + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// /// 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, - float? temperature = default, - string? displayName = default, - string? description = default, - string? baseModel = default, global::Google.Gemini.TuningTask? tuningTask = default, - float? topP = default, - global::Google.Gemini.TunedModelSource? tunedModelSource = default, int? topK = default, + string? baseModel = default, global::System.Collections.Generic.IList? readerProjectNumbers = default, + global::Google.Gemini.TunedModelSource? tunedModelSource = default, + float? topP = default, + string? description = default, + float? temperature = default, + string? displayName = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsGenerateContent.g.cs index 8d98d035..dd37b772 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,17 +36,11 @@ 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 name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// /// Optional. The service tier of the request. @@ -57,30 +51,36 @@ public partial interface IGeminiClient /// /// 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. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// /// 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, - string? model = default, - string? cachedContent = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? contents = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, + global::System.Collections.Generic.IList? tools = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPatch.g.cs index 1b0c6769..72ef37d2 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,32 +41,32 @@ public partial interface IGeminiClient /// /// /// - /// - /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. - /// - /// - /// Optional. 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. A short description of this model. + /// + /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. /// /// /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` /// - /// - /// Tuning tasks that create tuned models. + /// + /// Optional. List of project numbers that have read access to the tuned model. + /// + /// + /// Tuned model as a source for training a new model. /// /// /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Tuned model as a source for training a new model. + /// + /// Optional. A short description of this model. /// - /// - /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. + /// + /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. + /// + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -74,15 +74,15 @@ public partial interface IGeminiClient global::System.Threading.Tasks.Task TunedModelsPatchAsync( string tunedModelsId, string? updateMask = default, - float? temperature = default, - string? displayName = default, - string? description = default, - string? baseModel = default, global::Google.Gemini.TuningTask? tuningTask = default, - float? topP = default, - global::Google.Gemini.TunedModelSource? tunedModelSource = default, int? topK = default, + string? baseModel = default, global::System.Collections.Generic.IList? readerProjectNumbers = default, + global::Google.Gemini.TunedModelSource? tunedModelSource = default, + float? topP = default, + string? description = default, + float? temperature = default, + string? displayName = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPermissionsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPermissionsCreate.g.cs index 6d247e33..2eced6f5 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 @@ -36,23 +36,23 @@ public partial interface IGeminiClient /// Create a permission to a specific resource. /// /// - /// - /// 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 type of the grantee. + /// /// 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, string? emailAddress = default, global::Google.Gemini.PermissionRole? role = default, + global::Google.Gemini.PermissionGranteeType? granteeType = 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 065efa6e..b9a1f31c 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 @@ -46,15 +46,15 @@ public partial interface IGeminiClient /// /// /// - /// - /// 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 type of the grantee. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// @@ -62,9 +62,9 @@ public partial interface IGeminiClient string tunedModelsId, string permissionsId, string? updateMask = default, - global::Google.Gemini.PermissionGranteeType? granteeType = default, string? emailAddress = default, global::Google.Gemini.PermissionRole? role = default, + global::Google.Gemini.PermissionGranteeType? granteeType = 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 c28f27c0..3a4a6dfc 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,17 +36,11 @@ 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 name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// /// Optional. The service tier of the request. @@ -57,30 +51,36 @@ public partial interface IGeminiClient /// /// 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. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// /// 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, - string? model = default, - string? cachedContent = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? contents = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, + global::System.Collections.Generic.IList? tools = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContentAsStream.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContentAsStream.g.cs index b8058997..c29f9678 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,17 +22,11 @@ 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 name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// /// Optional. The service tier of the request. @@ -43,30 +37,36 @@ public partial interface IGeminiClient /// /// 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. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// /// 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, - string? model = default, - string? cachedContent = default, global::Google.Gemini.ToolConfig? toolConfig = default, - global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? contents = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, + global::System.Collections.Generic.IList? tools = default, + string? cachedContent = default, bool? store = default, + string? model = default, + global::System.Collections.Generic.IList? safetySettings = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContext.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContext.g.cs index c2547271..3227c0ea 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.ImageResponseFormatMimeTypeJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatMimeTypeNullableJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatImageSizeJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatImageSizeNullableJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryJsonConverter), + typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatMimeTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatMimeTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatAspectRatioJsonConverter), + typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatDeliveryJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatAspectRatioNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatDeliveryNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierJsonConverter), + typeof(global::Google.Gemini.JsonConverters.TextResponseFormatMimeTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.TextResponseFormatMimeTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryJsonConverter), + typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DocumentStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DocumentStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SchemaTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SchemaTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatMimeTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageJsonConverter), - typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatMimeTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatDeliveryJsonConverter), + typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonJsonConverter), - typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatDeliveryNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.TunedModelStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.TunedModelStateNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.PermissionRoleJsonConverter), typeof(global::Google.Gemini.JsonConverters.PermissionRoleNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatMimeTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatMimeTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ComputerUseDisabledSafetyPolicieJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ComputerUseDisabledSafetyPolicieNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatImageSizeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatImageSizeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DocumentStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatAspectRatioJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DocumentStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatAspectRatioNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileStateNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.FileSourceJsonConverter), typeof(global::Google.Gemini.JsonConverters.FileSourceNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionJsonConverter), typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieNullableJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SchemaTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SchemaTypeNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeJsonConverter), typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ComputerUseDisabledSafetyPolicieJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ComputerUseDisabledSafetyPolicieNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.TunedModelStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryJsonConverter), - typeof(global::Google.Gemini.JsonConverters.TunedModelStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelJsonConverter), typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateJsonConverter), typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageJsonConverter), typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.TextResponseFormatMimeTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryJsonConverter), - typeof(global::Google.Gemini.JsonConverters.TextResponseFormatMimeTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierNullableJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonNullableJsonConverter), 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.Model))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(int))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievedContext))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(string))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(float))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(bool))] - [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.ImageResponseFormatImageSize), TypeInfoPropertyName = "ImageResponseFormatImageSize2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormatDelivery), TypeInfoPropertyName = "ImageResponseFormatDelivery2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormatAspectRatio), TypeInfoPropertyName = "ImageResponseFormatAspectRatio2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TranslationConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlContext))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport))] - [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::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::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkCustomMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(int))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SpeakerVoiceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VoiceConfig))] + [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.InlinedRequest))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(object))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.File))] - [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::Google.Gemini.Tool))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleMaps))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleSearch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSearch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionDeclaration))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleSearchRetrieval))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecution))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::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.SearchEntryPoint))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(byte[]))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CustomLongRunningOperation))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(bool))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Status))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UsageMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UsageMetadataServiceTier), TypeInfoPropertyName = "UsageMetadataServiceTier2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModalityTokenCount))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbeddingUsageMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LogprobsResultCandidate))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkCustomMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkStringList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCall))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.WhiteSpaceConfig))] - [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.CachedContentUsageMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipResponse))] - [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.TuningExample))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.StringList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CachedContent))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Content))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Corpus))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CountTokensRequest))] - [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.SemanticRetrieverChunk))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(double))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.Dictionary))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SchemaType), TypeInfoPropertyName = "SchemaType2")] - [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.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.Web))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchOutput))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentResponses))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Maps))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PlaceAnswerSources))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DynamicRetrievalConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingAttribution))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AttributionSourceId))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ChunkingConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievalConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LatLng))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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.EmbedContentRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentRequestTaskType), TypeInfoPropertyName = "EmbedContentRequestTaskType2")] - [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.ListPermissionsResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [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(float))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkStringList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchStats))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningSnapshot))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ResponseFormatConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormat))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TextResponseFormat))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchEmbedContentsRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TextResponseFormatMimeType), TypeInfoPropertyName = "TextResponseFormatMimeType2")] + [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.EmbedContentBatchOutput))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentResponses))] + [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.Blob))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(byte[]))] + [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.GenerateContentBatchState), TypeInfoPropertyName = "GenerateContentBatchState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatchOutput))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SearchEntryPoint))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AttributionSourceId))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingPassageId))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SemanticRetrieverChunk))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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.Part))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VideoMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCode))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCall))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileData))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCall))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResult))] + [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.FunctionCallingConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCallingConfigMode), TypeInfoPropertyName = "FunctionCallingConfigMode2")] + [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.ModelStatus))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatusModelStage), TypeInfoPropertyName = "ModelStatusModelStage2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.StringList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Candidate))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CandidateFinishReason), TypeInfoPropertyName = "CandidateFinishReason2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(double))] [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.TopCandidates))] - [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.EmbedContentBatch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchState), TypeInfoPropertyName = "EmbedContentBatchState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InputEmbedContentConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchStats))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedback))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedbackBlockReason), TypeInfoPropertyName = "PromptFeedbackBlockReason2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Content))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingAttribution))] + [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.SafetyRating))] - [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.ToolResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponseToolType), TypeInfoPropertyName = "ToolResponseToolType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Interval))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SearchTypes))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesResponse))] + [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.FunctionResponseBlob))] [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.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.ToolResponseToolType), TypeInfoPropertyName = "ToolResponseToolType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningExamples))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningExample))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Web))] + [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.Dataset))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Corpus))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListOperationsResponse))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Operation))] - [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.Hyperparameters))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Empty))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentRequests))] - [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.CreateFileRequest))] - [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::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.CitationSource))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingPassageId))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VideoMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Permission))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PermissionRole), TypeInfoPropertyName = "PermissionRole2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PermissionGranteeType), TypeInfoPropertyName = "PermissionGranteeType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LatLng))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListCachedContentsResponse))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CachedContent))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievalConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentRequestTaskType), TypeInfoPropertyName = "EmbedContentRequestTaskType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Model))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ContentEmbedding))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormatMimeType), TypeInfoPropertyName = "ImageResponseFormatMimeType2")] + [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.ImageResponseFormatAspectRatio), TypeInfoPropertyName = "ImageResponseFormatAspectRatio2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievalMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningTask))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningSnapshot))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Dataset))] - [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.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.ImageSearch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.WebSearch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningExamples))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModalityTokenCountModality), TypeInfoPropertyName = "ModalityTokenCountModality2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunk))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InputConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Image))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchStats))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SpeakerVoiceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VoiceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AsyncBatchEmbedContentRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Candidate))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CandidateFinishReason), TypeInfoPropertyName = "CandidateFinishReason2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlContextMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CitationMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCallingConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCallingConfigMode), TypeInfoPropertyName = "FunctionCallingConfigMode2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSource), TypeInfoPropertyName = "FileSource2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileState), TypeInfoPropertyName = "FileState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VideoFileMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Tool))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecution))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlContext))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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.GoogleSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleMaps))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchStats))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.StreamableHttpTransport))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.Dictionary))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchEmbedContentsResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCallToolType), TypeInfoPropertyName = "ToolCallToolType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Maps))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PlaceAnswerSources))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InputEmbedContentConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchState), TypeInfoPropertyName = "EmbedContentBatchState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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.VideoFileMetadata))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfigMediaResolution), TypeInfoPropertyName = "GenerationConfigMediaResolution2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ThinkingConfig))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SpeechConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ResponseFormatConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TranslationConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Schema))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageConfig))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfigResponseModalitie), TypeInfoPropertyName = "GenerationConfigResponseModalitie2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ThinkingConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CustomLongRunningOperation))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievedContext))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.MultiSpeakerVoiceConfig))] - [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::Google.Gemini.FunctionResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponseScheduling), TypeInfoPropertyName = "FunctionResponseScheduling2")] - [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.UrlMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlMetadataUrlRetrievalStatus), TypeInfoPropertyName = "UrlMetadataUrlRetrievalStatus2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModelSource))] - [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.ToolCall))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResult))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Blob))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileData))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResultOutcome), TypeInfoPropertyName = "CodeExecutionResultOutcome2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PrebuiltVoiceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCallToolType), TypeInfoPropertyName = "ToolCallToolType2")] - [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.ImportFileRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfigMediaResolution), TypeInfoPropertyName = "GenerationConfigMediaResolution2")] + [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.ListPermissionsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentRequestServiceTier), TypeInfoPropertyName = "GenerateContentRequestServiceTier2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::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.BatchGenerateContentRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatus))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModel))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModelState), TypeInfoPropertyName = "TunedModelState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatusModelStage), TypeInfoPropertyName = "ModelStatusModelStage2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UploadToFileSearchStoreRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ThinkingConfigThinkingLevel), TypeInfoPropertyName = "ThinkingConfigThinkingLevel2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TextResponseFormat))] - [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.SafetySetting))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesRequest))] - [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.UploadToFileSearchStoreRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ChunkingConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Hyperparameters))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageSearch))] + [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.ListModelsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.Dictionary))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::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.LogprobsResultCandidate))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedResponses))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSearchStore))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Image))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileRequest))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponseBlob))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GeneratedFileState), TypeInfoPropertyName = "GeneratedFileState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCodeLanguage), TypeInfoPropertyName = "ExecutableCodeLanguage2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatchState), TypeInfoPropertyName = "GenerateContentBatchState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatchOutput))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TextResponseFormatMimeType), TypeInfoPropertyName = "TextResponseFormatMimeType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TopCandidates))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CitationSource))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Interval))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.WhiteSpaceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PrebuiltVoiceConfig))] [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.EmbedContentResponse))] + [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.BatchGenerateContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResultOutcome), TypeInfoPropertyName = "CodeExecutionResultOutcome2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileResponse))] + [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::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchEmbedContentsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentConfigTaskType), TypeInfoPropertyName = "EmbedContentConfigTaskType2")] + [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.GroundingChunk))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CachedContentUsageMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Empty))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [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.AsyncBatchEmbedContentRequest))] + [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::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CountTokensRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModalityTokenCountModality), TypeInfoPropertyName = "ModalityTokenCountModality2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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::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.CountTokensResponse))] + [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.ListFileSearchStoresResponse))] + [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.ThinkingConfigThinkingLevel), TypeInfoPropertyName = "ThinkingConfigThinkingLevel2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DynamicRetrievalConfigMode), TypeInfoPropertyName = "DynamicRetrievalConfigMode2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GeneratedFileState), TypeInfoPropertyName = "GeneratedFileState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionDeclarationBehavior), TypeInfoPropertyName = "FunctionDeclarationBehavior2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCodeLanguage), TypeInfoPropertyName = "ExecutableCodeLanguage2")] + [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::Google.Gemini.SafetySettingThreshold), TypeInfoPropertyName = "SafetySettingThreshold2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetySettingCategory), TypeInfoPropertyName = "SafetySettingCategory2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListFilesResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedback))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UsageMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UsageMetadataServiceTier), TypeInfoPropertyName = "UsageMetadataServiceTier2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedbackBlockReason), TypeInfoPropertyName = "PromptFeedbackBlockReason2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] public sealed partial class SourceGenerationContext : global::System.Text.Json.Serialization.JsonSerializerContext { } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContextTypes.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContextTypes.g.cs index 71f8ba7d..7d459c9d 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContextTypes.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContextTypes.g.cs @@ -28,1096 +28,1096 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - public global::Google.Gemini.Model? Type0 { get; set; } + public global::Google.Gemini.RetrievedContext? Type0 { get; set; } /// /// /// - public int? Type1 { get; set; } + public string? Type1 { get; set; } /// /// /// - public string? Type2 { get; set; } + public global::System.Collections.Generic.IList? Type2 { get; set; } /// /// /// - public float? Type3 { get; set; } + public global::Google.Gemini.GroundingChunkCustomMetadata? Type3 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type4 { get; set; } + public int? Type4 { get; set; } /// /// /// - public bool? Type5 { get; set; } + public global::Google.Gemini.SpeakerVoiceConfig? Type5 { get; set; } /// /// /// - public global::Google.Gemini.ImageResponseFormat? Type6 { get; set; } + public global::Google.Gemini.VoiceConfig? Type6 { get; set; } /// /// /// - public global::Google.Gemini.ImageResponseFormatMimeType? Type7 { get; set; } + public global::Google.Gemini.InlinedEmbedContentRequest? Type7 { get; set; } /// /// /// - public global::Google.Gemini.ImageResponseFormatImageSize? Type8 { get; set; } + public global::Google.Gemini.EmbedContentRequest? Type8 { get; set; } /// /// /// - public global::Google.Gemini.ImageResponseFormatDelivery? Type9 { get; set; } + public object? Type9 { get; set; } /// /// /// - public global::Google.Gemini.ImageResponseFormatAspectRatio? Type10 { get; set; } + public global::Google.Gemini.InlinedRequest? Type10 { get; set; } /// /// /// - public global::Google.Gemini.TranslationConfig? Type11 { get; set; } + public global::Google.Gemini.GenerateContentRequest? Type11 { get; set; } /// /// /// - public global::Google.Gemini.UrlContext? Type12 { get; set; } + public global::Google.Gemini.CustomLongRunningOperation? Type12 { get; set; } /// /// /// - public global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport? Type13 { get; set; } + public bool? Type13 { get; set; } /// /// /// - public global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? Type14 { get; set; } + public global::Google.Gemini.Status? Type14 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type15 { get; set; } + public global::Google.Gemini.AudioResponseFormat? Type15 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type16 { get; set; } + public global::Google.Gemini.AudioResponseFormatMimeType? Type16 { get; set; } /// /// /// - public global::Google.Gemini.ListModelsResponse? Type17 { get; set; } + public global::Google.Gemini.AudioResponseFormatDelivery? Type17 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type18 { get; set; } + public global::Google.Gemini.FunctionResponse? Type18 { get; set; } /// /// /// - public global::Google.Gemini.InlinedRequest? Type19 { get; set; } + public global::System.Collections.Generic.IList? Type19 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentRequest? Type20 { get; set; } + public global::Google.Gemini.FunctionResponsePart? Type20 { get; set; } /// /// /// - public object? Type21 { get; set; } + public global::Google.Gemini.FunctionResponseScheduling? Type21 { get; set; } /// /// /// - public global::Google.Gemini.CreateFileResponse? Type22 { get; set; } + public float? Type22 { get; set; } /// /// /// - public global::Google.Gemini.File? Type23 { get; set; } + public global::Google.Gemini.GroundingChunkStringList? Type23 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentConfig? Type24 { get; set; } + public global::Google.Gemini.BatchStats? Type24 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentConfigTaskType? Type25 { get; set; } + public global::Google.Gemini.TuningSnapshot? Type25 { get; set; } /// /// /// - public global::Google.Gemini.Tool? Type26 { get; set; } + public global::Google.Gemini.ResponseFormatConfig? Type26 { get; set; } /// /// /// - public global::Google.Gemini.GoogleMaps? Type27 { get; set; } + public global::Google.Gemini.ImageResponseFormat? Type27 { get; set; } /// /// /// - public global::Google.Gemini.GoogleSearch? Type28 { get; set; } + public global::Google.Gemini.TextResponseFormat? Type28 { get; set; } /// /// /// - public global::Google.Gemini.FileSearch? Type29 { get; set; } + public global::System.Collections.Generic.IList? Type29 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type30 { get; set; } + public global::Google.Gemini.BatchEmbedContentsRequest? Type30 { get; set; } /// /// /// - public global::Google.Gemini.FunctionDeclaration? Type31 { get; set; } + public global::System.Collections.Generic.IList? Type31 { get; set; } /// /// /// - public global::Google.Gemini.ComputerUse? Type32 { get; set; } + public global::Google.Gemini.TextResponseFormatMimeType? Type32 { get; set; } /// /// /// - public global::Google.Gemini.GoogleSearchRetrieval? Type33 { get; set; } + public global::Google.Gemini.UrlMetadata? Type33 { get; set; } /// /// /// - public global::Google.Gemini.CodeExecution? Type34 { get; set; } + public global::Google.Gemini.UrlMetadataUrlRetrievalStatus? Type34 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type35 { get; set; } + public global::Google.Gemini.EmbedContentBatchOutput? Type35 { get; set; } /// /// /// - public global::Google.Gemini.McpServer? Type36 { get; set; } + public global::Google.Gemini.InlinedEmbedContentResponses? Type36 { get; set; } /// /// /// - public global::Google.Gemini.SearchEntryPoint? Type37 { get; set; } + public global::Google.Gemini.UrlContextMetadata? Type37 { get; set; } /// /// /// - public byte[]? Type38 { get; set; } + public global::System.Collections.Generic.IList? Type38 { get; set; } /// /// /// - public global::Google.Gemini.Status? Type39 { get; set; } + public global::Google.Gemini.Blob? Type39 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type40 { get; set; } + public byte[]? Type40 { get; set; } /// /// /// - public global::Google.Gemini.UsageMetadata? Type41 { get; set; } + public global::Google.Gemini.GenerateContentBatch? Type41 { get; set; } /// /// /// - public global::Google.Gemini.UsageMetadataServiceTier? Type42 { get; set; } + public global::Google.Gemini.InputConfig? Type42 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type43 { get; set; } + public global::Google.Gemini.GenerateContentBatchState? Type43 { get; set; } /// /// /// - public global::Google.Gemini.ModalityTokenCount? Type44 { get; set; } + public global::Google.Gemini.GenerateContentBatchOutput? Type44 { get; set; } /// /// /// - public global::Google.Gemini.EmbeddingUsageMetadata? Type45 { get; set; } + public global::Google.Gemini.SearchEntryPoint? Type45 { get; set; } /// /// /// - public global::Google.Gemini.LogprobsResultCandidate? Type46 { get; set; } + public global::Google.Gemini.AttributionSourceId? Type46 { get; set; } /// /// /// - public global::Google.Gemini.GroundingChunkCustomMetadata? Type47 { get; set; } + public global::Google.Gemini.GroundingPassageId? Type47 { get; set; } /// /// /// - public global::Google.Gemini.GroundingChunkStringList? Type48 { get; set; } + public global::Google.Gemini.SemanticRetrieverChunk? Type48 { get; set; } /// /// /// - public global::Google.Gemini.FunctionCall? Type49 { get; set; } + public global::Google.Gemini.Document? Type49 { get; set; } /// /// /// - public global::Google.Gemini.WhiteSpaceConfig? Type50 { get; set; } + public global::Google.Gemini.DocumentState? Type50 { get; set; } /// /// /// - public global::Google.Gemini.InlinedRequests? Type51 { get; set; } + public global::System.Collections.Generic.IList? Type51 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type52 { get; set; } + public global::Google.Gemini.CustomMetadata? Type52 { get; set; } /// /// /// - public global::Google.Gemini.CachedContentUsageMetadata? Type53 { get; set; } + public global::Google.Gemini.Part? Type53 { get; set; } /// /// /// - public global::Google.Gemini.TransferOwnershipResponse? Type54 { get; set; } + public global::Google.Gemini.VideoMetadata? Type54 { get; set; } /// /// /// - public global::Google.Gemini.SafetySetting? Type55 { get; set; } + public global::Google.Gemini.ExecutableCode? Type55 { get; set; } /// /// /// - public global::Google.Gemini.SafetySettingCategory? Type56 { get; set; } + public global::Google.Gemini.ToolResponse? Type56 { get; set; } /// /// /// - public global::Google.Gemini.SafetySettingThreshold? Type57 { get; set; } + public global::Google.Gemini.FunctionCall? Type57 { get; set; } /// /// /// - public global::Google.Gemini.TuningExample? Type58 { get; set; } + public global::Google.Gemini.FileData? Type58 { get; set; } /// /// /// - public global::Google.Gemini.StringList? Type59 { get; set; } + public global::Google.Gemini.ToolCall? Type59 { get; set; } /// /// /// - public global::Google.Gemini.TransferOwnershipRequest? Type60 { get; set; } + public global::Google.Gemini.CodeExecutionResult? Type60 { get; set; } /// /// /// - public global::Google.Gemini.CachedContent? Type61 { get; set; } + public global::Google.Gemini.EmbeddingUsageMetadata? Type61 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type62 { get; set; } + public global::System.Collections.Generic.IList? Type62 { get; set; } /// /// /// - public global::Google.Gemini.ToolConfig? Type63 { get; set; } + public global::Google.Gemini.ModalityTokenCount? Type63 { get; set; } /// /// /// - public global::Google.Gemini.Content? Type64 { get; set; } + public global::Google.Gemini.FunctionCallingConfig? Type64 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type65 { get; set; } + public global::Google.Gemini.FunctionCallingConfigMode? Type65 { get; set; } /// /// /// - public global::Google.Gemini.Corpus? Type66 { get; set; } + public global::Google.Gemini.GoogleSearchRetrieval? Type66 { get; set; } /// /// /// - public global::Google.Gemini.CountTokensRequest? Type67 { get; set; } + public global::Google.Gemini.DynamicRetrievalConfig? Type67 { get; set; } /// /// /// - public global::Google.Gemini.Schema? Type68 { get; set; } + public global::Google.Gemini.ModelStatus? Type68 { get; set; } /// /// /// - public global::Google.Gemini.FunctionDeclarationBehavior? Type69 { get; set; } + public global::Google.Gemini.ModelStatusModelStage? Type69 { get; set; } /// /// /// - public global::Google.Gemini.SemanticRetrieverChunk? Type70 { get; set; } + public global::Google.Gemini.StringList? Type70 { get; set; } /// /// /// - public double? Type71 { get; set; } + public global::Google.Gemini.Candidate? Type71 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type72 { get; set; } + public global::Google.Gemini.CandidateFinishReason? Type72 { get; set; } /// /// /// - public global::System.Collections.Generic.Dictionary? Type73 { get; set; } + public double? Type73 { get; set; } /// /// /// - public global::Google.Gemini.SchemaType? Type74 { get; set; } + public global::Google.Gemini.LogprobsResult? Type74 { get; set; } /// /// /// - public global::Google.Gemini.ListCorporaResponse? Type75 { get; set; } + public global::Google.Gemini.GroundingMetadata? Type75 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type76 { get; set; } + public global::Google.Gemini.Content? Type76 { get; set; } /// /// /// - public global::Google.Gemini.ListFileSearchStoresResponse? Type77 { get; set; } + public global::System.Collections.Generic.IList? Type77 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type78 { get; set; } + public global::Google.Gemini.GroundingAttribution? Type78 { get; set; } /// /// /// - public global::Google.Gemini.FileSearchStore? Type79 { get; set; } + public global::Google.Gemini.CitationMetadata? Type79 { get; set; } /// /// /// - public global::Google.Gemini.Web? Type80 { get; set; } + public global::System.Collections.Generic.IList? Type80 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatchOutput? Type81 { get; set; } + public global::Google.Gemini.SafetyRating? Type81 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentResponses? Type82 { get; set; } + public global::Google.Gemini.RegisterFilesResponse? Type82 { get; set; } /// /// /// - public global::Google.Gemini.Maps? Type83 { get; set; } + public global::System.Collections.Generic.IList? Type83 { get; set; } /// /// /// - public global::Google.Gemini.PlaceAnswerSources? Type84 { get; set; } + public global::Google.Gemini.File? Type84 { get; set; } /// /// /// - public global::Google.Gemini.DynamicRetrievalConfig? Type85 { get; set; } + public global::Google.Gemini.FunctionResponseBlob? Type85 { get; set; } /// /// /// - public global::Google.Gemini.GroundingAttribution? Type86 { get; set; } + public global::Google.Gemini.ReviewSnippet? Type86 { get; set; } /// /// /// - public global::Google.Gemini.AttributionSourceId? Type87 { get; set; } + public global::Google.Gemini.ToolResponseToolType? Type87 { get; set; } /// /// /// - public global::Google.Gemini.ChunkingConfig? Type88 { get; set; } + public global::Google.Gemini.TuningExamples? Type88 { get; set; } /// /// /// - public global::Google.Gemini.RetrievalConfig? Type89 { get; set; } + public global::System.Collections.Generic.IList? Type89 { get; set; } /// /// /// - public global::Google.Gemini.LatLng? Type90 { get; set; } + public global::Google.Gemini.TuningExample? Type90 { get; set; } /// /// /// - public global::Google.Gemini.AudioResponseFormat? Type91 { get; set; } + public global::Google.Gemini.Web? Type91 { get; set; } /// /// /// - public global::Google.Gemini.AudioResponseFormatMimeType? Type92 { get; set; } + public global::Google.Gemini.TunedModel? Type92 { get; set; } /// /// /// - public global::Google.Gemini.AudioResponseFormatDelivery? Type93 { get; set; } + public global::Google.Gemini.TunedModelState? Type93 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentRequest? Type94 { get; set; } + public global::Google.Gemini.TuningTask? Type94 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentRequestTaskType? Type95 { get; set; } + public global::Google.Gemini.TunedModelSource? Type95 { get; set; } /// /// /// - public global::Google.Gemini.Permission? Type96 { get; set; } + public global::Google.Gemini.Dataset? Type96 { get; set; } /// /// /// - public global::Google.Gemini.PermissionGranteeType? Type97 { get; set; } + public global::Google.Gemini.TransferOwnershipRequest? Type97 { get; set; } /// /// /// - public global::Google.Gemini.PermissionRole? Type98 { get; set; } + public global::Google.Gemini.Corpus? Type98 { get; set; } /// /// /// - public global::Google.Gemini.ListPermissionsResponse? Type99 { get; set; } + public global::Google.Gemini.ListOperationsResponse? Type99 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type100 { get; set; } + public global::System.Collections.Generic.IList? Type100 { get; set; } /// /// /// - public global::Google.Gemini.LogprobsResult? Type101 { get; set; } + public global::Google.Gemini.Operation? Type101 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type102 { get; set; } + public global::Google.Gemini.Permission? Type102 { get; set; } /// /// /// - public global::Google.Gemini.TopCandidates? Type103 { get; set; } + public global::Google.Gemini.PermissionRole? Type103 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type104 { get; set; } + public global::Google.Gemini.PermissionGranteeType? Type104 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentRequest? Type105 { get; set; } + public global::Google.Gemini.LatLng? Type105 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatch? Type106 { get; set; } + public global::Google.Gemini.ListCachedContentsResponse? Type106 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatchState? Type107 { get; set; } + public global::System.Collections.Generic.IList? Type107 { get; set; } /// /// /// - public global::Google.Gemini.InputEmbedContentConfig? Type108 { get; set; } + public global::Google.Gemini.CachedContent? Type108 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatchStats? Type109 { get; set; } + public global::Google.Gemini.ToolConfig? Type109 { get; set; } /// /// /// - public global::Google.Gemini.PromptFeedback? Type110 { get; set; } + public global::Google.Gemini.RetrievalConfig? Type110 { get; set; } /// /// /// - public global::Google.Gemini.PromptFeedbackBlockReason? Type111 { get; set; } + public global::Google.Gemini.EmbedContentConfig? Type111 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type112 { get; set; } + public global::Google.Gemini.EmbedContentRequestTaskType? Type112 { get; set; } /// /// /// - public global::Google.Gemini.SafetyRating? Type113 { get; set; } + public global::Google.Gemini.Model? Type113 { get; set; } /// /// /// - public global::Google.Gemini.ListDocumentsResponse? Type114 { get; set; } + public global::Google.Gemini.ContentEmbedding? Type114 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type115 { get; set; } + public global::System.Collections.Generic.IList? Type115 { get; set; } /// /// /// - public global::Google.Gemini.Document? Type116 { get; set; } + public global::System.Collections.Generic.IList? Type116 { get; set; } /// /// /// - public global::Google.Gemini.ToolResponse? Type117 { get; set; } + public global::Google.Gemini.ImageResponseFormatMimeType? Type117 { get; set; } /// /// /// - public global::Google.Gemini.ToolResponseToolType? Type118 { get; set; } + public global::Google.Gemini.ImageResponseFormatDelivery? Type118 { get; set; } /// /// /// - public global::Google.Gemini.Interval? Type119 { get; set; } + public global::Google.Gemini.ImageResponseFormatImageSize? Type119 { get; set; } /// /// /// - public global::Google.Gemini.SearchTypes? Type120 { get; set; } + public global::Google.Gemini.ImageResponseFormatAspectRatio? Type120 { get; set; } /// /// /// - public global::Google.Gemini.ReviewSnippet? Type121 { get; set; } + public global::Google.Gemini.RetrievalMetadata? Type121 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type122 { get; set; } + public global::Google.Gemini.Tool? Type122 { get; set; } /// /// /// - public global::Google.Gemini.ComputerUseDisabledSafetyPolicie? Type123 { get; set; } + public global::Google.Gemini.CodeExecution? Type123 { get; set; } /// /// /// - public global::Google.Gemini.ComputerUseEnvironment? Type124 { get; set; } + public global::Google.Gemini.UrlContext? Type124 { get; set; } /// /// /// - public global::Google.Gemini.ListOperationsResponse? Type125 { get; set; } + public global::Google.Gemini.FileSearch? Type125 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type126 { get; set; } + public global::System.Collections.Generic.IList? Type126 { get; set; } /// /// /// - public global::Google.Gemini.Operation? Type127 { get; set; } + public global::Google.Gemini.FunctionDeclaration? Type127 { get; set; } /// /// /// - public global::Google.Gemini.ListFilesResponse? Type128 { get; set; } + public global::System.Collections.Generic.IList? Type128 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type129 { get; set; } + public global::Google.Gemini.McpServer? Type129 { get; set; } /// /// /// - public global::Google.Gemini.Hyperparameters? Type130 { get; set; } + public global::Google.Gemini.GoogleSearch? Type130 { get; set; } /// /// /// - public global::Google.Gemini.Empty? Type131 { get; set; } + public global::Google.Gemini.GoogleMaps? Type131 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentRequests? Type132 { get; set; } + public global::Google.Gemini.ComputerUse? Type132 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentResponse? Type133 { get; set; } + public global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport? Type133 { get; set; } /// /// /// - public global::Google.Gemini.ContentEmbedding? Type134 { get; set; } + public global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? Type134 { get; set; } /// /// /// - public global::Google.Gemini.CreateFileRequest? Type135 { get; set; } + public global::Google.Gemini.EmbedContentBatchStats? Type135 { get; set; } /// /// /// - public global::Google.Gemini.ListGeneratedFilesResponse? Type136 { get; set; } + public global::Google.Gemini.StreamableHttpTransport? Type136 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type137 { get; set; } + public global::System.Collections.Generic.Dictionary? Type137 { get; set; } /// /// /// - public global::Google.Gemini.GeneratedFile? Type138 { get; set; } + public global::Google.Gemini.ToolCallToolType? Type138 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type139 { get; set; } + public global::Google.Gemini.Maps? Type139 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentResponse? Type140 { get; set; } + public global::Google.Gemini.PlaceAnswerSources? Type140 { get; set; } /// /// /// - public global::Google.Gemini.CitationSource? Type141 { get; set; } + public global::Google.Gemini.EmbedContentBatch? Type141 { get; set; } /// /// /// - public global::Google.Gemini.GroundingPassageId? Type142 { get; set; } + public global::Google.Gemini.InputEmbedContentConfig? Type142 { get; set; } /// /// /// - public global::Google.Gemini.VideoMetadata? Type143 { get; set; } + public global::Google.Gemini.EmbedContentBatchState? Type143 { get; set; } /// /// /// - public global::Google.Gemini.ListCachedContentsResponse? Type144 { get; set; } + public global::Google.Gemini.FileState? Type144 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type145 { get; set; } + public global::Google.Gemini.FileSource? Type145 { get; set; } /// /// /// - public global::Google.Gemini.RetrievalMetadata? Type146 { get; set; } + public global::Google.Gemini.VideoFileMetadata? Type146 { get; set; } /// /// /// - public global::Google.Gemini.TuningTask? Type147 { get; set; } + public global::Google.Gemini.GenerationConfig? Type147 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type148 { get; set; } + public global::Google.Gemini.ThinkingConfig? Type148 { get; set; } /// /// /// - public global::Google.Gemini.TuningSnapshot? Type149 { get; set; } + public global::Google.Gemini.SpeechConfig? Type149 { get; set; } /// /// /// - public global::Google.Gemini.Dataset? Type150 { get; set; } + public global::Google.Gemini.TranslationConfig? Type150 { get; set; } /// /// /// - public global::Google.Gemini.DocumentState? Type151 { get; set; } + public global::Google.Gemini.Schema? Type151 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type152 { get; set; } + public global::Google.Gemini.ImageConfig? Type152 { get; set; } /// /// /// - public global::Google.Gemini.CustomMetadata? Type153 { get; set; } + public global::System.Collections.Generic.IList? Type153 { get; set; } /// /// /// - public global::Google.Gemini.InlinedResponses? Type154 { get; set; } + public global::Google.Gemini.GenerationConfigResponseModalitie? Type154 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type155 { get; set; } + public global::Google.Gemini.GenerationConfigMediaResolution? Type155 { get; set; } /// /// /// - public global::Google.Gemini.InlinedResponse? Type156 { get; set; } + public global::Google.Gemini.InlinedEmbedContentRequests? Type156 { get; set; } /// /// /// - public global::Google.Gemini.ImageSearch? Type157 { get; set; } + public global::System.Collections.Generic.IList? Type157 { get; set; } /// /// /// - public global::Google.Gemini.WebSearch? Type158 { get; set; } + public global::Google.Gemini.ListPermissionsResponse? Type158 { get; set; } /// /// /// - public global::Google.Gemini.TuningExamples? Type159 { get; set; } + public global::System.Collections.Generic.IList? Type159 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type160 { get; set; } + public global::Google.Gemini.GenerateContentRequestServiceTier? Type160 { get; set; } /// /// /// - public global::Google.Gemini.ModalityTokenCountModality? Type161 { get; set; } + public global::System.Collections.Generic.IList? Type161 { get; set; } /// /// /// - public global::Google.Gemini.GroundingMetadata? Type162 { get; set; } + public global::System.Collections.Generic.IList? Type162 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type163 { get; set; } + public global::System.Collections.Generic.IList? Type163 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type164 { get; set; } + public global::Google.Gemini.SafetySetting? Type164 { get; set; } /// /// /// - public global::Google.Gemini.GroundingChunk? Type165 { get; set; } + public global::Google.Gemini.RegisterFilesRequest? Type165 { get; set; } /// /// /// - public global::Google.Gemini.InputConfig? Type166 { get; set; } + public global::Google.Gemini.UploadToFileSearchStoreRequest? Type166 { get; set; } /// /// /// - public global::Google.Gemini.Image? Type167 { get; set; } + public global::Google.Gemini.ChunkingConfig? Type167 { get; set; } /// /// /// - public global::Google.Gemini.BatchStats? Type168 { get; set; } + public global::Google.Gemini.Hyperparameters? Type168 { get; set; } /// /// /// - public global::Google.Gemini.SpeakerVoiceConfig? Type169 { get; set; } + public global::Google.Gemini.ImageSearch? Type169 { get; set; } /// /// /// - public global::Google.Gemini.VoiceConfig? Type170 { get; set; } + public global::System.Collections.Generic.IList? Type170 { get; set; } /// /// /// - public global::Google.Gemini.AsyncBatchEmbedContentRequest? Type171 { get; set; } + public global::Google.Gemini.InlinedEmbedContentResponse? Type171 { get; set; } /// /// /// - public global::Google.Gemini.Candidate? Type172 { get; set; } + public global::Google.Gemini.ListModelsResponse? Type172 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type173 { get; set; } + public global::System.Collections.Generic.IList? Type173 { get; set; } /// /// /// - public global::Google.Gemini.CandidateFinishReason? Type174 { get; set; } + public global::System.Collections.Generic.Dictionary? Type174 { get; set; } /// /// /// - public global::Google.Gemini.UrlContextMetadata? Type175 { get; set; } + public global::System.Collections.Generic.IList? Type175 { get; set; } /// /// /// - public global::Google.Gemini.CitationMetadata? Type176 { get; set; } + public global::Google.Gemini.SchemaType? Type176 { get; set; } /// /// /// - public global::Google.Gemini.FunctionCallingConfig? Type177 { get; set; } + public global::Google.Gemini.LogprobsResultCandidate? Type177 { get; set; } /// /// /// - public global::Google.Gemini.FunctionCallingConfigMode? Type178 { get; set; } + public global::Google.Gemini.InlinedResponses? Type178 { get; set; } /// /// /// - public global::Google.Gemini.FileSource? Type179 { get; set; } + public global::Google.Gemini.FileSearchStore? Type179 { get; set; } /// /// /// - public global::Google.Gemini.FileState? Type180 { get; set; } + public global::Google.Gemini.Image? Type180 { get; set; } /// /// /// - public global::Google.Gemini.VideoFileMetadata? Type181 { get; set; } + public global::Google.Gemini.CreateFileRequest? Type181 { get; set; } /// /// /// - public global::Google.Gemini.StreamableHttpTransport? Type182 { get; set; } + public global::System.Collections.Generic.IList? Type182 { get; set; } /// /// /// - public global::System.Collections.Generic.Dictionary? Type183 { get; set; } + public global::System.Collections.Generic.IList? Type183 { get; set; } /// /// /// - public global::Google.Gemini.BatchEmbedContentsResponse? Type184 { get; set; } + public global::Google.Gemini.TopCandidates? Type184 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type185 { get; set; } + public global::System.Collections.Generic.IList? Type185 { get; set; } /// /// /// - public global::Google.Gemini.GenerationConfig? Type186 { get; set; } + public global::Google.Gemini.CitationSource? Type186 { get; set; } /// /// /// - public global::Google.Gemini.GenerationConfigMediaResolution? Type187 { get; set; } + public global::Google.Gemini.InlinedResponse? Type187 { get; set; } /// /// /// - public global::Google.Gemini.SpeechConfig? Type188 { get; set; } + public global::Google.Gemini.GenerateContentResponse? Type188 { get; set; } /// /// /// - public global::Google.Gemini.ResponseFormatConfig? Type189 { get; set; } + public global::Google.Gemini.Interval? Type189 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type190 { get; set; } + public global::Google.Gemini.WhiteSpaceConfig? Type190 { get; set; } /// /// /// - public global::Google.Gemini.GenerationConfigResponseModalitie? Type191 { get; set; } + public global::Google.Gemini.PrebuiltVoiceConfig? Type191 { get; set; } /// /// /// - public global::Google.Gemini.ImageConfig? Type192 { get; set; } + public global::Google.Gemini.ListTunedModelsResponse? Type192 { get; set; } /// /// /// - public global::Google.Gemini.ThinkingConfig? Type193 { get; set; } + public global::System.Collections.Generic.IList? Type193 { get; set; } /// /// /// - public global::Google.Gemini.CustomLongRunningOperation? Type194 { get; set; } + public global::Google.Gemini.EmbedContentResponse? Type194 { get; set; } /// /// /// - public global::Google.Gemini.RetrievedContext? Type195 { get; set; } + public global::Google.Gemini.MultiSpeakerVoiceConfig? Type195 { get; set; } /// /// /// - public global::Google.Gemini.MultiSpeakerVoiceConfig? Type196 { get; set; } + public global::System.Collections.Generic.IList? Type196 { get; set; } /// /// /// - public global::Google.Gemini.CountTokensResponse? Type197 { get; set; } + public global::Google.Gemini.BatchGenerateContentRequest? Type197 { get; set; } /// /// /// - public global::Google.Gemini.RegisterFilesResponse? Type198 { get; set; } + public global::Google.Gemini.CodeExecutionResultOutcome? Type198 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponse? Type199 { get; set; } + public global::Google.Gemini.CreateFileResponse? Type199 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponseScheduling? Type200 { get; set; } + public global::Google.Gemini.SearchTypes? Type200 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type201 { get; set; } + public global::Google.Gemini.WebSearch? Type201 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponsePart? Type202 { get; set; } + public global::System.Collections.Generic.IList? Type202 { get; set; } /// /// /// - public global::Google.Gemini.UrlMetadata? Type203 { get; set; } + public global::Google.Gemini.BatchEmbedContentsResponse? Type203 { get; set; } /// /// /// - public global::Google.Gemini.UrlMetadataUrlRetrievalStatus? Type204 { get; set; } + public global::System.Collections.Generic.IList? Type204 { get; set; } /// /// /// - public global::Google.Gemini.TunedModelSource? Type205 { get; set; } + public global::Google.Gemini.EmbedContentConfigTaskType? Type205 { get; set; } /// /// /// - public global::Google.Gemini.Part? Type206 { get; set; } + public global::Google.Gemini.ListCorporaResponse? Type206 { get; set; } /// /// /// - public global::Google.Gemini.ExecutableCode? Type207 { get; set; } + public global::System.Collections.Generic.IList? Type207 { get; set; } /// /// /// - public global::Google.Gemini.ToolCall? Type208 { get; set; } + public global::System.Collections.Generic.IList? Type208 { get; set; } /// /// /// - public global::Google.Gemini.CodeExecutionResult? Type209 { get; set; } + public global::Google.Gemini.GroundingChunk? Type209 { get; set; } /// /// /// - public global::Google.Gemini.Blob? Type210 { get; set; } + public global::Google.Gemini.CachedContentUsageMetadata? Type210 { get; set; } /// /// /// - public global::Google.Gemini.FileData? Type211 { get; set; } + public global::Google.Gemini.Empty? Type211 { get; set; } /// /// /// - public global::Google.Gemini.CodeExecutionResultOutcome? Type212 { get; set; } + public global::System.Collections.Generic.IList? Type212 { get; set; } /// /// /// - public global::Google.Gemini.PrebuiltVoiceConfig? Type213 { get; set; } + public global::Google.Gemini.ListDocumentsResponse? Type213 { get; set; } /// /// /// - public global::Google.Gemini.ToolCallToolType? Type214 { get; set; } + public global::System.Collections.Generic.IList? Type214 { get; set; } /// /// /// - public global::Google.Gemini.SafetyRatingCategory? Type215 { get; set; } + public global::Google.Gemini.AsyncBatchEmbedContentRequest? Type215 { get; set; } /// /// /// - public global::Google.Gemini.SafetyRatingProbability? Type216 { get; set; } + public global::Google.Gemini.InlinedRequests? Type216 { get; set; } /// /// /// - public global::Google.Gemini.ImportFileRequest? Type217 { get; set; } + public global::System.Collections.Generic.IList? Type217 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type218 { get; set; } + public global::System.Collections.Generic.IList? Type218 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentRequestServiceTier? Type219 { get; set; } + public global::Google.Gemini.CountTokensRequest? Type219 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type220 { get; set; } + public global::Google.Gemini.ModalityTokenCountModality? Type220 { get; set; } /// /// /// - public global::Google.Gemini.BatchGenerateContentRequest? Type221 { get; set; } + public global::System.Collections.Generic.IList? Type221 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentBatch? Type222 { get; set; } + public global::Google.Gemini.ListGeneratedFilesResponse? Type222 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentResponse? Type223 { get; set; } + public global::System.Collections.Generic.IList? Type223 { get; set; } /// /// /// - public global::Google.Gemini.ModelStatus? Type224 { get; set; } + public global::Google.Gemini.GeneratedFile? Type224 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type225 { get; set; } + public global::System.Collections.Generic.IList? Type225 { get; set; } /// /// /// - public global::Google.Gemini.TunedModel? Type226 { get; set; } + public global::Google.Gemini.ComputerUseDisabledSafetyPolicie? Type226 { get; set; } /// /// /// - public global::Google.Gemini.TunedModelState? Type227 { get; set; } + public global::Google.Gemini.ComputerUseEnvironment? Type227 { get; set; } /// /// /// - public global::Google.Gemini.ModelStatusModelStage? Type228 { get; set; } + public global::Google.Gemini.CountTokensResponse? Type228 { get; set; } /// /// /// - public global::Google.Gemini.UploadToFileSearchStoreRequest? Type229 { get; set; } + public global::Google.Gemini.SafetyRatingCategory? Type229 { get; set; } /// /// /// - public global::Google.Gemini.ThinkingConfigThinkingLevel? Type230 { get; set; } + public global::Google.Gemini.SafetyRatingProbability? Type230 { get; set; } /// /// /// - public global::Google.Gemini.TextResponseFormat? Type231 { get; set; } + public global::Google.Gemini.ListFileSearchStoresResponse? Type231 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type232 { get; set; } + public global::System.Collections.Generic.IList? Type232 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type233 { get; set; } + public global::System.Collections.Generic.IList? Type233 { get; set; } /// /// /// - public global::Google.Gemini.RegisterFilesRequest? Type234 { get; set; } + public global::Google.Gemini.ThinkingConfigThinkingLevel? Type234 { get; set; } /// /// /// - public global::Google.Gemini.BatchEmbedContentsRequest? Type235 { get; set; } + public global::Google.Gemini.DynamicRetrievalConfigMode? Type235 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type236 { get; set; } + public global::Google.Gemini.GeneratedFileState? Type236 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type237 { get; set; } + public global::Google.Gemini.TransferOwnershipResponse? Type237 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponseBlob? Type238 { get; set; } + public global::Google.Gemini.FunctionDeclarationBehavior? Type238 { get; set; } /// /// /// - public global::Google.Gemini.GeneratedFileState? Type239 { get; set; } + public global::Google.Gemini.ExecutableCodeLanguage? Type239 { get; set; } /// /// /// - public global::Google.Gemini.ExecutableCodeLanguage? Type240 { get; set; } + public global::Google.Gemini.ImportFileRequest? Type240 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentBatchState? Type241 { get; set; } + public global::System.Collections.Generic.IList? Type241 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentBatchOutput? Type242 { get; set; } + public global::Google.Gemini.SafetySettingThreshold? Type242 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type243 { get; set; } + public global::Google.Gemini.SafetySettingCategory? Type243 { get; set; } /// /// /// - public global::Google.Gemini.TextResponseFormatMimeType? Type244 { get; set; } + public global::Google.Gemini.ListFilesResponse? Type244 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type245 { get; set; } + public global::System.Collections.Generic.IList? Type245 { get; set; } /// /// /// - public global::Google.Gemini.ListTunedModelsResponse? Type246 { get; set; } + public global::Google.Gemini.PromptFeedback? Type246 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type247 { get; set; } + public global::Google.Gemini.UsageMetadata? Type247 { get; set; } /// /// /// - public global::Google.Gemini.DynamicRetrievalConfigMode? Type248 { get; set; } + public global::Google.Gemini.UsageMetadataServiceTier? Type248 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type249 { get; set; } + public global::Google.Gemini.PromptFeedbackBlockReason? 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; } /// /// /// - public global::System.Collections.Generic.List? ListType17 { get; set; } + public global::System.Collections.Generic.List? ListType17 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType18 { get; set; } + public global::System.Collections.Generic.List? ListType18 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType19 { get; set; } + public global::System.Collections.Generic.List? ListType19 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType20 { get; set; } + public global::System.Collections.Generic.List? ListType20 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType21 { get; set; } + public global::System.Collections.Generic.List? ListType21 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType22 { get; set; } + public global::System.Collections.Generic.List? ListType22 { get; set; } /// /// /// @@ -1125,35 +1125,35 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - 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; } /// /// /// @@ -1161,54 +1161,54 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - 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 5f9a1bf9..31aabb54 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 `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; } + /// + /// 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; } + /// /// 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 `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`. - /// /// /// Identifier for a part within a `GroundingPassage`. /// + /// + /// Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public AttributionSourceId( - global::Google.Gemini.SemanticRetrieverChunk? semanticRetrieverChunk, - global::Google.Gemini.GroundingPassageId? groundingPassage) + global::Google.Gemini.GroundingPassageId? groundingPassage, + global::Google.Gemini.SemanticRetrieverChunk? semanticRetrieverChunk) { - this.SemanticRetrieverChunk = semanticRetrieverChunk; this.GroundingPassage = groundingPassage; + this.SemanticRetrieverChunk = semanticRetrieverChunk; } /// 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 fde13634..be8c7ada 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 @@ -14,6 +14,12 @@ public sealed partial class AudioResponseFormat [global::System.Text.Json.Serialization.JsonPropertyName("bitRate")] public int? BitRate { get; set; } + /// + /// Optional. Sample rate in Hz. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("sampleRate")] + public int? SampleRate { get; set; } + /// /// Optional. The MIME type of the audio output. /// @@ -21,12 +27,6 @@ public sealed partial class AudioResponseFormat [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatMimeTypeJsonConverter))] public global::Google.Gemini.AudioResponseFormatMimeType? MimeType { get; set; } - /// - /// Optional. Sample rate in Hz. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("sampleRate")] - public int? SampleRate { get; set; } - /// /// Optional. The delivery mode for the audio output. /// @@ -46,12 +46,12 @@ public sealed partial class AudioResponseFormat /// /// Optional. Bit rate in bits per second (bps). Only applicable for compressed formats (MP3, Opus). /// - /// - /// Optional. The MIME type of the audio output. - /// /// /// Optional. Sample rate in Hz. /// + /// + /// Optional. The MIME type of the audio output. + /// /// /// Optional. The delivery mode for the audio output. /// @@ -60,13 +60,13 @@ public sealed partial class AudioResponseFormat #endif public AudioResponseFormat( int? bitRate, - global::Google.Gemini.AudioResponseFormatMimeType? mimeType, int? sampleRate, + global::Google.Gemini.AudioResponseFormatMimeType? mimeType, global::Google.Gemini.AudioResponseFormatDelivery? delivery) { this.BitRate = bitRate; - this.MimeType = mimeType; this.SampleRate = sampleRate; + this.MimeType = mimeType; this.Delivery = delivery; } 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 25c98c30..40ebd66a 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 @@ -9,32 +9,32 @@ namespace Google.Gemini public sealed partial class BatchStats { /// - /// 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 in the batch.
+ /// Output only. The number of requests that were successfully processed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("requestCount")] - public string? RequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("successfulRequestCount")] + public string? SuccessfulRequestCount { get; set; } /// - /// Output only. The number of requests that were successfully processed.
+ /// Output only. The number of requests that are still pending processing.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("successfulRequestCount")] - public string? SuccessfulRequestCount { 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 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; } /// /// Additional properties that are not explicitly defined in the schema @@ -45,35 +45,35 @@ public sealed partial class BatchStats /// /// Initializes a new instance of the class. /// - /// - /// Output only. The number of requests that are still pending processing.
- /// Included only in responses - /// - /// - /// Output only. The number of requests in the batch.
+ /// + /// Output only. The number of requests that failed to be processed.
/// Included only in responses /// /// /// Output only. The number of requests that were successfully processed.
/// Included only in responses /// - /// - /// Output only. The number of requests that failed to be processed.
+ /// + /// Output only. The number of requests that are still pending processing.
+ /// Included only in responses + /// + /// + /// 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 BatchStats( - string? pendingRequestCount, - string? requestCount, + string? failedRequestCount, string? successfulRequestCount, - string? failedRequestCount) + string? pendingRequestCount, + string? requestCount) { + this.FailedRequestCount = failedRequestCount; + this.SuccessfulRequestCount = successfulRequestCount; this.PendingRequestCount = pendingRequestCount; this.RequestCount = requestCount; - this.SuccessfulRequestCount = successfulRequestCount; - this.FailedRequestCount = failedRequestCount; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Blob.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Blob.g.cs index 2f59c767..17a76eb9 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Blob.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Blob.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class Blob { - /// - /// Raw bytes for media formats. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("data")] - public byte[]? Data { get; set; } - /// /// The IANA standard MIME type of the source data. Examples 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). // /// [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] public string? MimeType { get; set; } + /// + /// Raw bytes for media formats. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("data")] + public byte[]? Data { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class Blob /// /// Initializes a new instance of the class. /// - /// - /// Raw bytes for media formats. - /// /// /// 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). // /// + /// + /// Raw bytes for media formats. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Blob( - byte[]? data, - string? mimeType) + string? mimeType, + byte[]? data) { - this.Data = data; this.MimeType = mimeType; + this.Data = data; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CachedContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CachedContent.g.cs index 879dad16..c0ceeab7 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 @@ -9,10 +9,22 @@ namespace Google.Gemini public sealed partial class CachedContent { /// - /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. + /// 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; } + + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + [global::System.Text.Json.Serialization.JsonPropertyName("tools")] + public global::System.Collections.Generic.IList? Tools { get; set; } + + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("systemInstruction")] + public global::Google.Gemini.Content? SystemInstruction { get; set; } /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` @@ -27,12 +39,6 @@ public sealed partial class CachedContent [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] public string? UpdateTime { get; set; } - /// - /// Input only. New TTL for this resource, input only. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("ttl")] - public string? Ttl { get; set; } - /// /// Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`
/// Included only in responses @@ -40,24 +46,6 @@ public sealed partial class CachedContent [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } - /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response - /// - [global::System.Text.Json.Serialization.JsonPropertyName("tools")] - public global::System.Collections.Generic.IList? Tools { 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; } - - /// - /// 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. Creation time of the cache entry.
/// Included only in responses @@ -65,6 +53,12 @@ public sealed partial class CachedContent [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] public string? CreateTime { get; set; } + /// + /// Input only. New TTL for this resource, input only. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("ttl")] + public string? Ttl { get; set; } + /// /// Metadata on the usage of the cached content. /// @@ -72,16 +66,22 @@ public sealed partial class CachedContent public global::Google.Gemini.CachedContentUsageMetadata? UsageMetadata { 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. + /// 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("systemInstruction")] - public global::Google.Gemini.Content? SystemInstruction { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("expireTime")] + public string? ExpireTime { get; set; } /// - /// Optional. Input only. Immutable. The content to cache. + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. /// - [global::System.Text.Json.Serialization.JsonPropertyName("contents")] - public global::System.Collections.Generic.IList? Contents { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { 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; } /// /// Additional properties that are not explicitly defined in the schema @@ -92,8 +92,14 @@ public sealed partial class CachedContent /// /// Initializes a new instance of the class. /// - /// - /// 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. + /// + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` @@ -102,64 +108,58 @@ public sealed partial class CachedContent /// Output only. When the cache entry was last updated in UTC time.
/// Included only in responses /// - /// - /// Input only. New TTL for this resource, input only. - /// /// /// Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`
/// Included only in responses /// - /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response - /// - /// - /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// /// Output only. Creation time of the cache entry.
/// Included only in responses /// + /// + /// Input only. New TTL for this resource, input only. + /// /// /// Metadata on the usage of the cached 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. + /// + /// 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. + /// + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CachedContent( - string? expireTime, + global::System.Collections.Generic.IList? contents, + global::System.Collections.Generic.IList? tools, + global::Google.Gemini.Content? systemInstruction, string? model, string? updateTime, - string? ttl, string? name, - global::System.Collections.Generic.IList? tools, - string? displayName, - global::Google.Gemini.ToolConfig? toolConfig, string? createTime, + string? ttl, global::Google.Gemini.CachedContentUsageMetadata? usageMetadata, - global::Google.Gemini.Content? systemInstruction, - global::System.Collections.Generic.IList? contents) + string? expireTime, + string? displayName, + global::Google.Gemini.ToolConfig? toolConfig) { - this.ExpireTime = expireTime; + this.Contents = contents; + this.Tools = tools; + this.SystemInstruction = systemInstruction; this.Model = model; this.UpdateTime = updateTime; - this.Ttl = ttl; this.Name = name; - this.Tools = tools; - this.DisplayName = displayName; - this.ToolConfig = toolConfig; this.CreateTime = createTime; + this.Ttl = ttl; this.UsageMetadata = usageMetadata; - this.SystemInstruction = systemInstruction; - this.Contents = contents; + this.ExpireTime = expireTime; + this.DisplayName = displayName; + this.ToolConfig = toolConfig; } /// 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 2276d102..73d35fa8 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Candidate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Candidate.g.cs @@ -9,23 +9,12 @@ namespace Google.Gemini public sealed partial class Candidate { /// - /// 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; } - - /// - /// Metadata returned to client when grounding is enabled. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("groundingMetadata")] - public global::Google.Gemini.GroundingMetadata? GroundingMetadata { get; set; } - - /// - /// Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.
+ /// 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("groundingAttributions")] - public global::System.Collections.Generic.IList? GroundingAttributions { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("finishReason")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonJsonConverter))] + public global::Google.Gemini.CandidateFinishReason? FinishReason { get; set; } /// /// Output only. Average log probability score of the candidate.
@@ -35,30 +24,30 @@ public sealed partial class Candidate public double? AvgLogprobs { get; set; } /// - /// Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.
- /// Included only in responses + /// Logprobs Result ///
- [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("logprobsResult")] + public global::Google.Gemini.LogprobsResult? LogprobsResult { get; set; } /// - /// Metadata related to url context retrieval tool. + /// Output only. Index of the candidate in the list of response candidates.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("urlContextMetadata")] - public global::Google.Gemini.UrlContextMetadata? UrlContextMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("index")] + public int? Index { get; set; } /// - /// A collection of source attributions for a piece of content. + /// Metadata returned to client when grounding is enabled. /// - [global::System.Text.Json.Serialization.JsonPropertyName("citationMetadata")] - public global::Google.Gemini.CitationMetadata? CitationMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("groundingMetadata")] + public global::Google.Gemini.GroundingMetadata? GroundingMetadata { get; set; } /// - /// List of ratings for the safety of a response candidate. There is at most one rating per category. + /// 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("safetyRatings")] - public global::System.Collections.Generic.IList? SafetyRatings { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("finishMessage")] + public string? FinishMessage { get; set; } /// /// Output only. Token count for this candidate.
@@ -68,24 +57,35 @@ public sealed partial class Candidate public int? TokenCount { get; set; } /// - /// Output only. Index of the candidate in the list of response candidates.
- /// Included only in responses + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("index")] - public int? Index { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("content")] + public global::Google.Gemini.Content? Content { get; set; } /// - /// Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.
+ /// Output only. 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("finishMessage")] - public string? FinishMessage { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("groundingAttributions")] + public global::System.Collections.Generic.IList? GroundingAttributions { get; set; } /// - /// Logprobs Result + /// A collection of source attributions for a piece of content. /// - [global::System.Text.Json.Serialization.JsonPropertyName("logprobsResult")] - public global::Google.Gemini.LogprobsResult? LogprobsResult { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("citationMetadata")] + public global::Google.Gemini.CitationMetadata? CitationMetadata { get; set; } + + /// + /// Metadata related to url context retrieval tool. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("urlContextMetadata")] + public global::Google.Gemini.UrlContextMetadata? UrlContextMetadata { get; set; } + + /// + /// List of ratings for the safety of a response candidate. There is at most one rating per category. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("safetyRatings")] + public global::System.Collections.Generic.IList? SafetyRatings { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -96,77 +96,77 @@ public sealed partial class Candidate /// /// Initializes a new instance of the class. /// - /// - /// 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. - /// - /// - /// Metadata returned to client when grounding is enabled. - /// - /// - /// Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.
+ /// + /// Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.
/// Included only in responses /// /// /// Output only. 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.
- /// Included only in responses + /// + /// Logprobs Result /// - /// - /// Metadata related to url context retrieval tool. + /// + /// Output only. Index of the candidate in the list of response candidates.
+ /// Included only in responses /// - /// - /// A collection of source attributions for a piece of content. + /// + /// Metadata returned to client when grounding is enabled. /// - /// - /// List of ratings for the safety of a response candidate. There is at most one rating per category. + /// + /// Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.
+ /// Included only in responses /// /// /// Output only. Token count for this candidate.
/// Included only in responses /// - /// - /// Output only. Index of the candidate in the list of response candidates.
- /// Included only in responses + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// - /// - /// Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.
+ /// + /// 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 + /// + /// A collection of source attributions for a piece of content. + /// + /// + /// Metadata related to url context retrieval tool. + /// + /// + /// List of ratings for the safety of a response candidate. There is at most one rating per category. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Candidate( - global::Google.Gemini.Content? content, - global::Google.Gemini.GroundingMetadata? groundingMetadata, - global::System.Collections.Generic.IList? groundingAttributions, - double? avgLogprobs, global::Google.Gemini.CandidateFinishReason? finishReason, - global::Google.Gemini.UrlContextMetadata? urlContextMetadata, - global::Google.Gemini.CitationMetadata? citationMetadata, - global::System.Collections.Generic.IList? safetyRatings, - int? tokenCount, + double? avgLogprobs, + global::Google.Gemini.LogprobsResult? logprobsResult, int? index, + global::Google.Gemini.GroundingMetadata? groundingMetadata, string? finishMessage, - global::Google.Gemini.LogprobsResult? logprobsResult) + int? tokenCount, + global::Google.Gemini.Content? content, + global::System.Collections.Generic.IList? groundingAttributions, + global::Google.Gemini.CitationMetadata? citationMetadata, + global::Google.Gemini.UrlContextMetadata? urlContextMetadata, + global::System.Collections.Generic.IList? safetyRatings) { - this.Content = content; + this.FinishReason = finishReason; + this.AvgLogprobs = avgLogprobs; + this.LogprobsResult = logprobsResult; + this.Index = index; this.GroundingMetadata = groundingMetadata; + this.FinishMessage = finishMessage; + this.TokenCount = tokenCount; + this.Content = content; this.GroundingAttributions = groundingAttributions; - this.AvgLogprobs = avgLogprobs; - this.FinishReason = finishReason; - this.UrlContextMetadata = urlContextMetadata; this.CitationMetadata = citationMetadata; + this.UrlContextMetadata = urlContextMetadata; this.SafetyRatings = safetyRatings; - this.TokenCount = tokenCount; - this.Index = index; - this.FinishMessage = finishMessage; - this.LogprobsResult = logprobsResult; } /// 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 9f49fa85..38c4e4b1 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CitationSource.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CitationSource.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class CitationSource { - /// - /// Optional. URI that is attributed as a source for a portion of the text. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("uri")] - public string? Uri { get; set; } - /// /// Optional. End of the attributed segment, exclusive. /// @@ -26,6 +20,12 @@ public sealed partial class CitationSource [global::System.Text.Json.Serialization.JsonPropertyName("startIndex")] public int? StartIndex { get; set; } + /// + /// Optional. URI that is attributed as a source for a portion of the text. + /// + [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. /// @@ -41,15 +41,15 @@ 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. End of the attributed segment, exclusive. /// /// /// 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. + /// /// /// Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations. /// @@ -57,14 +57,14 @@ public sealed partial class CitationSource [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CitationSource( - string? uri, int? endIndex, int? startIndex, + string? uri, string? license) { - this.Uri = uri; this.EndIndex = endIndex; this.StartIndex = startIndex; + 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 a1771d2d..11556e1a 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CodeExecutionResult.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CodeExecutionResult.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini ///
public sealed partial class CodeExecutionResult { - /// - /// Optional. Contains stdout when code execution is successful, stderr or other description otherwise. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("output")] - public string? Output { get; set; } - /// /// Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id. /// @@ -27,6 +21,12 @@ public sealed partial class CodeExecutionResult [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeJsonConverter))] public global::Google.Gemini.CodeExecutionResultOutcome? Outcome { get; set; } + /// + /// Optional. 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 /// @@ -36,26 +36,26 @@ public sealed partial class CodeExecutionResult /// /// Initializes a new instance of the class. /// - /// - /// Optional. Contains stdout when code execution is successful, stderr or other description otherwise. - /// /// /// 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. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CodeExecutionResult( - string? output, string? id, - global::Google.Gemini.CodeExecutionResultOutcome? outcome) + global::Google.Gemini.CodeExecutionResultOutcome? outcome, + string? output) { - this.Output = output; this.Id = id; this.Outcome = outcome; + this.Output = output; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ComputerUse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ComputerUse.g.cs index 29d270f1..07cc01bb 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ComputerUse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ComputerUse.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ComputerUse { - /// - /// Optional. Disabled safety policies for computer use. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("disabledSafetyPolicies")] - public global::System.Collections.Generic.IList? DisabledSafetyPolicies { get; set; } - /// /// Optional. Whether enable the prompt injection detection check on computer-use request. /// [global::System.Text.Json.Serialization.JsonPropertyName("enablePromptInjectionDetection")] public bool? EnablePromptInjectionDetection { get; set; } + /// + /// Optional. Disabled safety policies for computer use. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("disabledSafetyPolicies")] + public global::System.Collections.Generic.IList? DisabledSafetyPolicies { get; set; } + /// /// Optional. By default, predefined functions are included in the final model call. Some of them can be explicitly excluded from being automatically included. This can serve two purposes: 1. Using a more restricted / different action space. 2. Improving the definitions / instructions of predefined functions. /// @@ -42,12 +42,12 @@ public sealed partial class ComputerUse /// /// Initializes a new instance of the class. /// - /// - /// Optional. Disabled safety policies for computer use. - /// /// /// Optional. Whether enable the prompt injection detection check on computer-use request. /// + /// + /// Optional. Disabled safety policies for computer use. + /// /// /// 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. /// @@ -58,13 +58,13 @@ public sealed partial class ComputerUse [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ComputerUse( - global::System.Collections.Generic.IList? disabledSafetyPolicies, bool? enablePromptInjectionDetection, + global::System.Collections.Generic.IList? disabledSafetyPolicies, global::System.Collections.Generic.IList? excludedPredefinedFunctions, global::Google.Gemini.ComputerUseEnvironment? environment) { - this.DisabledSafetyPolicies = disabledSafetyPolicies; this.EnablePromptInjectionDetection = enablePromptInjectionDetection; + this.DisabledSafetyPolicies = disabledSafetyPolicies; this.ExcludedPredefinedFunctions = excludedPredefinedFunctions; this.Environment = environment; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Content.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Content.g.cs index c53213b9..db1b7f3e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Content.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Content.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini ///
public sealed partial class Content { - /// - /// Optional. The producer of the content. Must be either 'user' or 'model'. Useful to set for multi-turn conversations, otherwise can be left blank or unset. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("role")] - public string? Role { get; set; } - /// /// Ordered `Parts` that constitute a single message. Parts may have different MIME types. /// [global::System.Text.Json.Serialization.JsonPropertyName("parts")] public global::System.Collections.Generic.IList? Parts { get; set; } + /// + /// Optional. The producer of the content. Must be either 'user' or 'model'. Useful to set for multi-turn conversations, otherwise can be left blank or unset. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("role")] + public string? Role { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class Content /// /// Initializes a new instance of the class. /// - /// - /// Optional. The producer of the content. Must be either 'user' or 'model'. Useful to set for multi-turn conversations, otherwise can be left blank or unset. - /// /// /// Ordered `Parts` that constitute a single message. Parts may have different MIME types. /// + /// + /// 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. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Content( - string? role, - global::System.Collections.Generic.IList? parts) + global::System.Collections.Generic.IList? parts, + string? role) { - this.Role = role; this.Parts = parts; + this.Role = role; } /// 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 208805c4..cd6f9195 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 @@ -14,6 +14,13 @@ public sealed partial class Corpus [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 + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } + /// /// 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 @@ -28,13 +35,6 @@ public sealed partial class Corpus [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] public string? CreateTime { get; set; } - /// - /// Output only. The Timestamp of when the `Corpus` was last updated.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -47,6 +47,10 @@ 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" /// + /// + /// Output only. The Timestamp of when the `Corpus` was last updated.
+ /// Included only in responses + /// /// /// Output only. Immutable. Identifier. The `Corpus` resource name. The ID (name excluding the "corpora/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `corpora/my-awesome-corpora-123a456b789c`
/// Included only in responses @@ -55,23 +59,19 @@ public sealed partial class Corpus /// Output only. The Timestamp of when the `Corpus` was created.
/// Included only in responses /// - /// - /// Output only. The Timestamp of when the `Corpus` was last updated.
- /// Included only in responses - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Corpus( string? displayName, + string? updateTime, string? name, - string? createTime, - string? updateTime) + string? createTime) { this.DisplayName = displayName; + this.UpdateTime = updateTime; this.Name = name; this.CreateTime = createTime; - 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 b3630d1d..263ea346 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 { - /// - /// 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; } + /// + /// Request to generate a completion from the model. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("generateContentRequest")] + public global::Google.Gemini.GenerateContentRequest? GenerateContentRequest { 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. /// - /// - /// 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. /// + /// + /// Request to generate a completion from the model. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CountTokensRequest( - global::Google.Gemini.GenerateContentRequest? generateContentRequest, - global::System.Collections.Generic.IList? contents) + global::System.Collections.Generic.IList? contents, + global::Google.Gemini.GenerateContentRequest? generateContentRequest) { - this.GenerateContentRequest = generateContentRequest; this.Contents = contents; + this.GenerateContentRequest = generateContentRequest; } /// 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 b3cee467..f96a5986 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CountTokensResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CountTokensResponse.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class CountTokensResponse { + /// + /// The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("totalTokens")] + public int? TotalTokens { get; set; } + /// /// Output only. List of modalities that were processed in the request input.
/// Included only in responses @@ -22,12 +28,6 @@ public sealed partial class CountTokensResponse [global::System.Text.Json.Serialization.JsonPropertyName("cacheTokensDetails")] public global::System.Collections.Generic.IList? CacheTokensDetails { get; set; } - /// - /// The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("totalTokens")] - public int? TotalTokens { get; set; } - /// /// Number of tokens in the cached part of the prompt (the cached content). /// @@ -43,6 +43,9 @@ public sealed partial class CountTokensResponse /// /// Initializes a new instance of the class. /// + /// + /// The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative. + /// /// /// Output only. List of modalities that were processed in the request input.
/// Included only in responses @@ -51,9 +54,6 @@ public sealed partial class CountTokensResponse /// Output only. List of modalities that were processed in the cached content.
/// Included only in responses /// - /// - /// The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative. - /// /// /// Number of tokens in the cached part of the prompt (the cached content). /// @@ -61,14 +61,14 @@ public sealed partial class CountTokensResponse [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CountTokensResponse( + int? totalTokens, global::System.Collections.Generic.IList? promptTokensDetails, global::System.Collections.Generic.IList? cacheTokensDetails, - int? totalTokens, int? cachedContentTokenCount) { + this.TotalTokens = totalTokens; this.PromptTokensDetails = promptTokensDetails; this.CacheTokensDetails = cacheTokensDetails; - this.TotalTokens = totalTokens; this.CachedContentTokenCount = cachedContentTokenCount; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomLongRunningOperation.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomLongRunningOperation.g.cs index c4c7ed77..fcaac99b 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 @@ -20,12 +20,6 @@ public sealed partial class CustomLongRunningOperation [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("error")] - public global::Google.Gemini.Status? Error { get; set; } - /// /// 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. /// @@ -38,6 +32,12 @@ public sealed partial class CustomLongRunningOperation [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; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -53,30 +53,30 @@ public sealed partial class CustomLongRunningOperation /// /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. /// - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). - /// /// /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. /// /// /// If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available. /// + /// + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CustomLongRunningOperation( object? response, string? name, - global::Google.Gemini.Status? error, object? metadata, - bool? done) + bool? done, + global::Google.Gemini.Status? error) { this.Response = response; this.Name = name; - this.Error = error; this.Metadata = metadata; this.Done = done; + 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 45b6081b..d30ea6b0 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomMetadata.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomMetadata.g.cs @@ -15,10 +15,10 @@ public sealed partial class CustomMetadata public string? Key { get; set; } /// - /// The numeric value of the metadata to store. + /// User provided string values assigned to a single metadata key. /// - [global::System.Text.Json.Serialization.JsonPropertyName("numericValue")] - public float? NumericValue { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("stringListValue")] + public global::Google.Gemini.StringList? StringListValue { get; set; } /// /// The string value of the metadata to store. @@ -27,10 +27,10 @@ public sealed partial class CustomMetadata public string? StringValue { get; set; } /// - /// User provided string values assigned to a single metadata key. + /// The numeric value of the metadata to store. /// - [global::System.Text.Json.Serialization.JsonPropertyName("stringListValue")] - public global::Google.Gemini.StringList? StringListValue { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("numericValue")] + public float? NumericValue { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -44,28 +44,28 @@ public sealed partial class CustomMetadata /// /// Required. The key of the metadata to store. /// - /// - /// The numeric value of the metadata to store. + /// + /// User provided string values assigned to a single metadata key. /// /// /// The string value of the metadata to store. /// - /// - /// User provided string values assigned to a single metadata key. + /// + /// The numeric value of the metadata to store. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CustomMetadata( string? key, - float? numericValue, + global::Google.Gemini.StringList? stringListValue, string? stringValue, - global::Google.Gemini.StringList? stringListValue) + float? numericValue) { this.Key = key; - this.NumericValue = numericValue; - this.StringValue = stringValue; this.StringListValue = stringListValue; + this.StringValue = stringValue; + this.NumericValue = numericValue; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Document.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Document.g.cs index 9558bd60..825cba89 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Document.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Document.g.cs @@ -9,25 +9,11 @@ namespace Google.Gemini public sealed partial class Document { /// - /// Optional. The human-readable display name for the `Document`. The display name must be no more than 512 characters in length, including spaces. Example: "Semantic Retriever Documentation" - /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } - - /// - /// Output only. Current state of the `Document`.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("state")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.DocumentStateJsonConverter))] - public global::Google.Gemini.DocumentState? State { get; set; } - - /// - /// Output only. The mime type of the Document.
+ /// Output only. The size of raw bytes ingested into the Document.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] - public string? MimeType { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] + public string? SizeBytes { get; set; } /// /// Immutable. Identifier. The `Document` resource name. The ID (name excluding the "fileSearchStores/*/documents/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/{file_search_store_id}/documents/my-awesome-doc-123a456b789c` @@ -36,11 +22,19 @@ public sealed partial class Document public string? Name { get; set; } /// - /// Output only. The Timestamp of when the `Document` was last updated.
+ /// Output only. The Timestamp of when the `Document` was created.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } + + /// + /// Output only. Current state of the `Document`.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("state")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.DocumentStateJsonConverter))] + public global::Google.Gemini.DocumentState? State { get; set; } /// /// Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`. @@ -49,18 +43,24 @@ public sealed partial class Document public global::System.Collections.Generic.IList? CustomMetadata { 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 mime type of the Document.
/// 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 Timestamp of when the `Document` was created.
+ /// Output only. The Timestamp of when the `Document` 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; } /// /// Additional properties that are not explicitly defined in the schema @@ -71,56 +71,56 @@ public sealed partial class Document /// /// Initializes a new instance of the class. /// - /// - /// Optional. The human-readable display name for the `Document`. The display name must be no more than 512 characters in length, including spaces. Example: "Semantic Retriever Documentation" - /// - /// - /// Output only. Current state of the `Document`.
- /// Included only in responses - /// - /// - /// Output only. The mime type of the Document.
+ /// + /// Output only. The size of raw bytes ingested into the Document.
/// Included only in responses /// /// /// Immutable. Identifier. The `Document` resource name. The ID (name excluding the "fileSearchStores/*/documents/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/{file_search_store_id}/documents/my-awesome-doc-123a456b789c` /// - /// - /// Output only. The Timestamp of when the `Document` was last updated.
+ /// + /// 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 /// /// /// 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 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 mime type of the Document.
/// Included only in responses /// - /// - /// Output only. The Timestamp of when the `Document` was created.
+ /// + /// Output only. The Timestamp of when the `Document` was last updated.
/// Included only in responses /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Document( - string? displayName, - global::Google.Gemini.DocumentState? state, - string? mimeType, + string? sizeBytes, string? name, - string? updateTime, + string? createTime, + global::Google.Gemini.DocumentState? state, global::System.Collections.Generic.IList? customMetadata, - string? sizeBytes, - string? createTime) + string? displayName, + string? mimeType, + string? updateTime) { - this.DisplayName = displayName; + this.SizeBytes = sizeBytes; + this.Name = name; + this.CreateTime = createTime; this.State = state; + this.CustomMetadata = customMetadata; + this.DisplayName = displayName; this.MimeType = mimeType; - this.Name = name; this.UpdateTime = updateTime; - this.CustomMetadata = customMetadata; - this.SizeBytes = sizeBytes; - this.CreateTime = createTime; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.DynamicRetrievalConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.DynamicRetrievalConfig.g.cs index 18d7176e..c5176056 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.DynamicRetrievalConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.DynamicRetrievalConfig.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class DynamicRetrievalConfig { - /// - /// The threshold to be used in dynamic retrieval. If not set, a system default value is used. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("dynamicThreshold")] - public float? DynamicThreshold { get; set; } - /// /// The mode of the predictor to be used in dynamic retrieval. /// @@ -21,6 +15,12 @@ public sealed partial class DynamicRetrievalConfig [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeJsonConverter))] public global::Google.Gemini.DynamicRetrievalConfigMode? Mode { get; set; } + /// + /// The threshold to be used in dynamic retrieval. If not set, a system default value is used. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("dynamicThreshold")] + public float? DynamicThreshold { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,21 +30,21 @@ public sealed partial class DynamicRetrievalConfig /// /// Initializes a new instance of the class. /// - /// - /// The threshold to be used in dynamic retrieval. If not set, a system default value is used. - /// /// /// The mode of the predictor to be used in dynamic retrieval. /// + /// + /// The threshold to be used in dynamic retrieval. If not set, a system default value is used. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public DynamicRetrievalConfig( - float? dynamicThreshold, - global::Google.Gemini.DynamicRetrievalConfigMode? mode) + global::Google.Gemini.DynamicRetrievalConfigMode? mode, + float? dynamicThreshold) { - this.DynamicThreshold = dynamicThreshold; this.Mode = mode; + this.DynamicThreshold = dynamicThreshold; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatch.g.cs index bb7b800a..d24f558c 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 @@ -14,6 +14,12 @@ public sealed partial class EmbedContentBatch [global::System.Text.Json.Serialization.JsonPropertyName("model")] public string? Model { get; set; } + /// + /// Configures the input to the batch request. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("inputConfig")] + public global::Google.Gemini.InputEmbedContentConfig? InputConfig { get; set; } + /// /// Output only. The time at which the batch was last updated.
/// Included only in responses @@ -30,23 +36,23 @@ public sealed partial class EmbedContentBatch public global::Google.Gemini.EmbedContentBatchState? State { get; set; } /// - /// Configures the input to the batch request. + /// Output only. The time at which the batch processing completed.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("inputConfig")] - public global::Google.Gemini.InputEmbedContentConfig? InputConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] + public string? EndTime { get; set; } /// - /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. + /// Stats about the batch. /// - [global::System.Text.Json.Serialization.JsonPropertyName("priority")] - public string? Priority { 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 processing completed.
- /// Included only in responses + /// Required. The user-defined name of this batch. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] - public string? EndTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
@@ -56,10 +62,11 @@ public sealed partial class EmbedContentBatch public string? Name { get; set; } /// - /// Required. The user-defined name of this batch. + /// Output only. The time at which the batch 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; } /// /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. @@ -68,17 +75,10 @@ public sealed partial class EmbedContentBatch public global::Google.Gemini.EmbedContentBatchOutput? Output { get; set; } /// - /// Stats about the batch. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("batchStats")] - public global::Google.Gemini.EmbedContentBatchStats? BatchStats { get; set; } - - /// - /// Output only. The time at which the batch was created.
- /// 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. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("priority")] + public string? Priority { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -92,6 +92,9 @@ public sealed partial class EmbedContentBatch /// /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// + /// + /// Configures the input to the batch request. + /// /// /// Output only. The time at which the batch was last updated.
/// Included only in responses @@ -100,60 +103,57 @@ public sealed partial class EmbedContentBatch /// Output only. The state of the batch.
/// Included only in responses /// - /// - /// 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. - /// /// /// Output only. The time at which the batch processing completed.
/// Included only in responses /// - /// - /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
- /// Included only in responses + /// + /// Stats about the batch. /// /// /// 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. - /// - /// - /// Stats about the batch. + /// + /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
+ /// Included only in responses /// /// /// Output only. The time at which the batch was created.
/// Included only in responses /// + /// + /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. + /// + /// + /// 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. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentBatch( string? model, + global::Google.Gemini.InputEmbedContentConfig? inputConfig, string? updateTime, global::Google.Gemini.EmbedContentBatchState? state, - global::Google.Gemini.InputEmbedContentConfig? inputConfig, - string? priority, string? endTime, - string? name, + global::Google.Gemini.EmbedContentBatchStats? batchStats, string? displayName, + string? name, + string? createTime, global::Google.Gemini.EmbedContentBatchOutput? output, - global::Google.Gemini.EmbedContentBatchStats? batchStats, - string? createTime) + string? priority) { this.Model = model; + this.InputConfig = inputConfig; this.UpdateTime = updateTime; this.State = state; - this.InputConfig = inputConfig; - this.Priority = priority; this.EndTime = endTime; - this.Name = name; - this.DisplayName = displayName; - this.Output = output; this.BatchStats = batchStats; + this.DisplayName = displayName; + this.Name = name; this.CreateTime = createTime; + this.Output = output; + this.Priority = priority; } /// 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 9d780df3..811d2e62 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 were successfully processed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("requestCount")] - public string? RequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("successfulRequestCount")] + public string? SuccessfulRequestCount { get; set; } /// - /// Output only. The number of requests that were successfully processed.
+ /// Output only. The number of requests that are still pending processing.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("successfulRequestCount")] - public string? SuccessfulRequestCount { 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 in the batch.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("failedRequestCount")] - public string? FailedRequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("requestCount")] + public string? RequestCount { get; set; } /// - /// Output only. The number of requests that are still pending processing.
+ /// Output only. The number of requests that 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; } /// /// Additional properties that are not explicitly defined in the schema @@ -45,35 +45,35 @@ public sealed partial class EmbedContentBatchStats /// /// Initializes a new instance of the class. /// - /// - /// Output only. The number of requests in the batch.
- /// Included only in responses - /// /// /// Output only. The number of requests that were successfully processed.
/// Included only in responses /// - /// - /// Output only. The number of requests that failed to be processed.
- /// Included only in responses - /// /// /// Output only. The number of requests that are still pending processing.
/// Included only in responses /// + /// + /// Output only. The number of requests in the batch.
+ /// Included only in responses + /// + /// + /// Output only. The number of requests that failed to be processed.
+ /// Included only in responses + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentBatchStats( - string? requestCount, string? successfulRequestCount, - string? failedRequestCount, - string? pendingRequestCount) + string? pendingRequestCount, + string? requestCount, + string? failedRequestCount) { - this.RequestCount = requestCount; this.SuccessfulRequestCount = successfulRequestCount; - this.FailedRequestCount = failedRequestCount; this.PendingRequestCount = pendingRequestCount; + this.RequestCount = requestCount; + this.FailedRequestCount = failedRequestCount; } /// 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 b74705cb..9f35a7de 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 @@ -9,35 +9,35 @@ namespace Google.Gemini public sealed partial class EmbedContentConfig { /// - /// Optional. Reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. + /// Optional. The task type of the embedding. /// - [global::System.Text.Json.Serialization.JsonPropertyName("outputDimensionality")] - public int? OutputDimensionality { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("taskType")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeJsonConverter))] + public global::Google.Gemini.EmbedContentConfigTaskType? TaskType { get; set; } /// - /// Optional. Whether to extract audio from video content. + /// Optional. The title for the text. /// - [global::System.Text.Json.Serialization.JsonPropertyName("audioTrackExtraction")] - public bool? AudioTrackExtraction { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("title")] + public string? Title { get; set; } /// - /// Optional. Whether to enable OCR for document content. + /// Optional. Whether to extract audio from video content. /// - [global::System.Text.Json.Serialization.JsonPropertyName("documentOcr")] - public bool? DocumentOcr { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("audioTrackExtraction")] + public bool? AudioTrackExtraction { get; set; } /// - /// Optional. The title for the text. + /// Optional. Reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - public string? Title { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("outputDimensionality")] + public int? OutputDimensionality { get; set; } /// - /// Optional. The task type of the embedding. + /// Optional. Whether to enable OCR for document content. /// - [global::System.Text.Json.Serialization.JsonPropertyName("taskType")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeJsonConverter))] - public global::Google.Gemini.EmbedContentConfigTaskType? TaskType { get; set; } + [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. @@ -54,21 +54,21 @@ public sealed partial class EmbedContentConfig /// /// Initializes a new instance of the class. /// - /// - /// Optional. Reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. + /// + /// Optional. The task type of the embedding. + /// + /// + /// Optional. The title for the text. /// /// /// Optional. Whether to extract audio from video content. /// + /// + /// Optional. Reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. + /// /// /// Optional. Whether to enable OCR for document content. /// - /// - /// Optional. The title for the text. - /// - /// - /// Optional. The task type of the embedding. - /// /// /// Optional. Whether to silently truncate the input content if it's longer than the maximum sequence length. /// @@ -76,18 +76,18 @@ public sealed partial class EmbedContentConfig [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentConfig( - int? outputDimensionality, + global::Google.Gemini.EmbedContentConfigTaskType? taskType, + string? title, bool? audioTrackExtraction, + int? outputDimensionality, bool? documentOcr, - string? title, - global::Google.Gemini.EmbedContentConfigTaskType? taskType, bool? autoTruncate) { - this.OutputDimensionality = outputDimensionality; + this.TaskType = taskType; + this.Title = title; this.AudioTrackExtraction = audioTrackExtraction; + this.OutputDimensionality = outputDimensionality; this.DocumentOcr = documentOcr; - this.Title = title; - this.TaskType = taskType; this.AutoTruncate = autoTruncate; } 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 ce619e53..9b28e081 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 @@ -17,19 +17,10 @@ public sealed partial class EmbedContentRequest 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. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - [global::System.Obsolete("This property marked as deprecated.")] - public string? Title { 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`). + /// Configurations for the EmbedContent request. /// - [global::System.Text.Json.Serialization.JsonPropertyName("taskType")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeJsonConverter))] - [global::System.Obsolete("This property marked as deprecated.")] - public global::Google.Gemini.EmbedContentRequestTaskType? TaskType { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("embedContentConfig")] + public global::Google.Gemini.EmbedContentConfig? EmbedContentConfig { 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}` @@ -45,10 +36,19 @@ public sealed partial class EmbedContentRequest public int? OutputDimensionality { get; set; } /// - /// Configurations for the EmbedContent request. + /// Optional. Deprecated: Please use EmbedContentConfig.title instead. An optional title for the text. Only applicable when TaskType is `RETRIEVAL_DOCUMENT`. Note: Specifying a `title` for `RETRIEVAL_DOCUMENT` provides better quality embeddings for retrieval. /// - [global::System.Text.Json.Serialization.JsonPropertyName("embedContentConfig")] - public global::Google.Gemini.EmbedContentConfig? EmbedContentConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("title")] + [global::System.Obsolete("This property marked as deprecated.")] + public string? Title { 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`). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("taskType")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeJsonConverter))] + [global::System.Obsolete("This property marked as deprecated.")] + public global::Google.Gemini.EmbedContentRequestTaskType? TaskType { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -62,23 +62,23 @@ public sealed partial class EmbedContentRequest /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// - /// - /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` - /// /// /// Configurations for the EmbedContent request. /// + /// + /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentRequest( global::Google.Gemini.Content? content, - string? model, - global::Google.Gemini.EmbedContentConfig? embedContentConfig) + global::Google.Gemini.EmbedContentConfig? embedContentConfig, + string? model) { this.Content = content; - this.Model = model; this.EmbedContentConfig = embedContentConfig; + this.Model = model; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ExecutableCode.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ExecutableCode.g.cs index 9af6f777..358665ad 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,12 +14,6 @@ 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`. /// @@ -27,6 +21,12 @@ 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. The code to be executed. - /// /// /// Required. Programming language of the `code`. /// + /// + /// Required. The code to be executed. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ExecutableCode( string? id, - string? code, - global::Google.Gemini.ExecutableCodeLanguage? language) + global::Google.Gemini.ExecutableCodeLanguage? language, + string? code) { this.Id = id; - this.Code = code; this.Language = language; + this.Code = code; } /// 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 3d988c3a..6e97e648 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,45 +9,47 @@ namespace Google.Gemini public sealed partial class File { /// - /// Output only. The uri of the `File`.
+ /// Output only. SHA-256 hash of the uploaded bytes.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("uri")] - public string? Uri { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sha256Hash")] + public byte[]? Sha256Hash { get; set; } /// - /// Output only. The timestamp of when the `File` was created.
+ /// Output only. Processing state of the File.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { 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; } /// - /// 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` was last updated.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } /// - /// Output only. SHA-256 hash of the uploaded bytes.
+ /// Output only. The uri of the `File`.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("sha256Hash")] - public byte[]? Sha256Hash { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("uri")] + public string? Uri { get; set; } /// - /// Source of the File. + /// Output only. The download uri 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("downloadUri")] + public string? DownloadUri { get; set; } /// - /// Output only. MIME type of the file.
+ /// Output only. Size of the file in bytes.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] - public string? MimeType { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] + public string? SizeBytes { 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). @@ -56,33 +58,31 @@ public sealed partial class File public global::Google.Gemini.Status? Error { 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 timestamp of when the `File` was last updated.
- /// Included only in responses + /// Source of the File. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("source")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FileSourceJsonConverter))] + public global::Google.Gemini.FileSource? Source { get; set; } /// - /// Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.
- /// 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` ///
- [global::System.Text.Json.Serialization.JsonPropertyName("expirationTime")] - public string? ExpirationTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// - /// Output only. Processing state of the File.
+ /// Output only. The timestamp of when the `File` was created.
/// 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("createTime")] + public string? CreateTime { get; set; } /// /// Metadata for a video `File`. @@ -90,19 +90,19 @@ public sealed partial class File [global::System.Text.Json.Serialization.JsonPropertyName("videoMetadata")] public global::Google.Gemini.VideoFileMetadata? VideoMetadata { get; set; } - /// - /// Output only. The download uri of the `File`.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("downloadUri")] - public string? DownloadUri { get; set; } - /// /// Optional. The human-readable display name for the `File`. The display name must be no more than 512 characters in length, including spaces. Example: "Welcome Image" /// [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] public string? DisplayName { 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("expirationTime")] + public string? ExpirationTime { 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 uri of the `File`.
+ /// + /// Output only. SHA-256 hash of the uploaded bytes.
/// Included only in responses /// - /// - /// Output only. The timestamp of when the `File` was created.
+ /// + /// Output only. Processing state of the File.
/// Included only in responses /// - /// - /// Immutable. Identifier. The `File` resource name. The ID (name excluding the "files/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be generated. Example: `files/123-456` + /// + /// Output only. The timestamp of when the `File` was last updated.
+ /// Included only in responses /// - /// - /// Output only. SHA-256 hash of the uploaded bytes.
+ /// + /// Output only. The uri of the `File`.
/// Included only in responses /// - /// - /// Source of the File. + /// + /// Output only. The download uri of the `File`.
+ /// Included only in responses /// - /// - /// Output only. MIME type of the file.
+ /// + /// Output only. Size of the file in bytes.
/// Included only in responses /// /// /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// - /// - /// Output only. Size of the file in bytes.
+ /// + /// Output only. MIME type of the file.
/// Included only in responses /// - /// - /// Output only. The timestamp of when the `File` was last updated.
- /// Included only in responses + /// + /// 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 + /// + /// 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. Processing state of the File.
+ /// + /// Output only. The timestamp of when the `File` was created.
/// Included only in responses /// /// /// Metadata for a video `File`. /// - /// - /// Output only. The download uri of the `File`.
- /// Included only in responses - /// /// /// Optional. The human-readable display name for the `File`. The display name must be no more than 512 characters in length, including spaces. Example: "Welcome Image" /// + /// + /// Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.
+ /// Included only in responses + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public File( - string? uri, - string? createTime, - string? name, byte[]? sha256Hash, - global::Google.Gemini.FileSource? source, - string? mimeType, - global::Google.Gemini.Status? error, - string? sizeBytes, - string? updateTime, - string? expirationTime, global::Google.Gemini.FileState? state, - global::Google.Gemini.VideoFileMetadata? videoMetadata, + string? updateTime, + string? uri, string? downloadUri, - string? displayName) + string? sizeBytes, + global::Google.Gemini.Status? error, + string? mimeType, + global::Google.Gemini.FileSource? source, + string? name, + string? createTime, + global::Google.Gemini.VideoFileMetadata? videoMetadata, + string? displayName, + string? expirationTime) { - this.Uri = uri; - this.CreateTime = createTime; - this.Name = name; this.Sha256Hash = sha256Hash; - this.Source = source; - this.MimeType = mimeType; - this.Error = error; - this.SizeBytes = sizeBytes; - this.UpdateTime = updateTime; - this.ExpirationTime = expirationTime; this.State = state; - this.VideoMetadata = videoMetadata; + this.UpdateTime = updateTime; + this.Uri = uri; this.DownloadUri = downloadUri; + this.SizeBytes = sizeBytes; + this.Error = error; + this.MimeType = mimeType; + this.Source = source; + this.Name = name; + this.CreateTime = createTime; + this.VideoMetadata = videoMetadata; this.DisplayName = displayName; + this.ExpirationTime = expirationTime; } /// 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 47ddd26d..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,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class FileSearch { - /// - /// Optional. The number of semantic retrieval chunks to retrieve. - /// - [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` /// @@ -26,6 +20,12 @@ public sealed partial class FileSearch [global::System.Text.Json.Serialization.JsonPropertyName("metadataFilter")] public string? MetadataFilter { get; set; } + /// + /// Optional. The number of semantic retrieval chunks to retrieve. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("topK")] + public int? TopK { 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. /// - /// - /// 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` /// /// /// Optional. Metadata filter to apply to the semantic retrieval documents and chunks. /// + /// + /// Optional. The number of semantic retrieval chunks to retrieve. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FileSearch( - int? topK, global::System.Collections.Generic.IList? fileSearchStoreNames, - string? metadataFilter) + string? metadataFilter, + int? topK) { - this.TopK = topK; this.FileSearchStoreNames = fileSearchStoreNames; this.MetadataFilter = metadataFilter; + this.TopK = topK; } /// 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 412a2b6b..35e2d22d 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,11 +9,17 @@ namespace Google.Gemini public sealed partial class FileSearchStore { /// - /// Output only. The number of documents in the `FileSearchStore` that are being processed.
+ /// Output only. The Timestamp of when the `FileSearchStore` was last updated.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("pendingDocumentsCount")] - public string? PendingDocumentsCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } + + /// + /// Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("embeddingModel")] + public string? EmbeddingModel { get; set; } /// /// Output only. The size of raw bytes ingested into the `FileSearchStore`. This is the total size of all the documents in the `FileSearchStore`.
@@ -23,24 +29,24 @@ public sealed partial class FileSearchStore public string? SizeBytes { 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. + /// 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("embeddingModel")] - public string? EmbeddingModel { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// - /// Output only. The Timestamp of when the `FileSearchStore` was last updated.
+ /// 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("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("activeDocumentsCount")] + public string? ActiveDocumentsCount { get; set; } /// - /// Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.
+ /// Output only. Immutable. Identifier. The `FileSearchStore` resource name. It is an ID (name excluding the "fileSearchStores/" prefix) that can contain up to 40 characters that are lowercase alphanumeric or dashes (-). It is output only. The unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/my-awesome-file-search-store-123a456b789c` If `display_name` is not provided, the name will be randomly generated.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("activeDocumentsCount")] - public string? ActiveDocumentsCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// /// Output only. The Timestamp of when the `FileSearchStore` was created.
@@ -50,24 +56,18 @@ public sealed partial class FileSearchStore public string? CreateTime { get; set; } /// - /// Output only. The number of documents in the `FileSearchStore` that have failed processing.
+ /// Output only. The number of documents in the `FileSearchStore` that are being processed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("failedDocumentsCount")] - public string? FailedDocumentsCount { 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; } + [global::System.Text.Json.Serialization.JsonPropertyName("pendingDocumentsCount")] + public string? PendingDocumentsCount { get; set; } /// - /// Output only. Immutable. Identifier. The `FileSearchStore` resource name. It is an ID (name excluding the "fileSearchStores/" prefix) that can contain up to 40 characters that are lowercase alphanumeric or dashes (-). It is output only. The unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/my-awesome-file-search-store-123a456b789c` If `display_name` is not provided, the name will be randomly generated.
+ /// Output only. The number of documents in the `FileSearchStore` that have failed processing.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("failedDocumentsCount")] + public string? FailedDocumentsCount { get; set; } /// /// 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 size of raw bytes ingested into the `FileSearchStore`. This is the total size of all the documents in the `FileSearchStore`.
+ /// + /// Output only. The Timestamp of when the `FileSearchStore` was last updated.
/// 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.
+ /// + /// Output only. The size of raw bytes ingested into the `FileSearchStore`. This is the total size of all the documents in the `FileSearchStore`.
/// Included only in responses /// + /// + /// Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" + /// /// /// Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.
/// 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.
+ /// Included only in responses + /// /// /// Output only. The Timestamp of when the `FileSearchStore` was created.
/// Included only in responses /// - /// - /// Output only. The number of documents in the `FileSearchStore` that have failed processing.
+ /// + /// Output only. The number of documents in the `FileSearchStore` that are being processed.
/// Included only in responses /// - /// - /// Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" - /// - /// - /// Output only. Immutable. Identifier. The `FileSearchStore` resource name. It is an ID (name excluding the "fileSearchStores/" prefix) that can contain up to 40 characters that are lowercase alphanumeric or dashes (-). It is output only. The unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/my-awesome-file-search-store-123a456b789c` If `display_name` is not provided, the name will be randomly generated.
+ /// + /// Output only. The number of documents in the `FileSearchStore` that have failed processing.
/// Included only in responses /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FileSearchStore( - string? pendingDocumentsCount, - string? sizeBytes, - string? embeddingModel, string? updateTime, + string? embeddingModel, + string? sizeBytes, + string? displayName, string? activeDocumentsCount, + string? name, string? createTime, - string? failedDocumentsCount, - string? displayName, - string? name) + string? pendingDocumentsCount, + string? failedDocumentsCount) { - this.PendingDocumentsCount = pendingDocumentsCount; - this.SizeBytes = sizeBytes; - this.EmbeddingModel = embeddingModel; this.UpdateTime = updateTime; + this.EmbeddingModel = embeddingModel; + this.SizeBytes = sizeBytes; + this.DisplayName = displayName; this.ActiveDocumentsCount = activeDocumentsCount; + this.Name = name; this.CreateTime = createTime; + this.PendingDocumentsCount = pendingDocumentsCount; this.FailedDocumentsCount = failedDocumentsCount; - this.DisplayName = displayName; - this.Name = name; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionDeclaration.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionDeclaration.g.cs index d1595d99..dc3519de 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionDeclaration.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionDeclaration.g.cs @@ -9,47 +9,47 @@ namespace Google.Gemini public sealed partial class FunctionDeclaration { /// - /// Required. The name of the function. Must be a-z, A-Z, 0-9, or contain underscores, colons, dots, and dashes, with a maximum length of 128. + /// Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method. /// - [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("behavior")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorJsonConverter))] + public global::Google.Gemini.FunctionDeclarationBehavior? Behavior { get; set; } /// - /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). + /// 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("response")] - public global::Google.Gemini.Schema? Response { get; set; } + [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`. + /// 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("responseJsonSchema")] - public object? ResponseJsonSchema { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("parameters")] + public global::Google.Gemini.Schema? Parameters { get; set; } /// - /// Required. A brief description of the function. + /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). /// - [global::System.Text.Json.Serialization.JsonPropertyName("description")] - public string? Description { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("response")] + public global::Google.Gemini.Schema? Response { 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`. + /// Required. The name of the function. Must be a-z, A-Z, 0-9, or contain underscores, colons, dots, and dashes, with a maximum length of 128. /// - [global::System.Text.Json.Serialization.JsonPropertyName("parametersJsonSchema")] - public object? ParametersJsonSchema { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// - /// Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method. + /// Required. A brief description of the function. /// - [global::System.Text.Json.Serialization.JsonPropertyName("behavior")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorJsonConverter))] - public global::Google.Gemini.FunctionDeclarationBehavior? Behavior { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("description")] + public string? Description { get; set; } /// - /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). + /// 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("parameters")] - public global::Google.Gemini.Schema? Parameters { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseJsonSchema")] + public object? ResponseJsonSchema { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -60,46 +60,46 @@ public sealed partial class FunctionDeclaration /// /// Initializes a new instance of the class. /// - /// - /// Required. The name of the function. Must be a-z, A-Z, 0-9, or contain underscores, colons, dots, and dashes, with a maximum length of 128. + /// + /// Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method. + /// + /// + /// Optional. Describes the parameters to the function in JSON Schema format. The schema must describe an object where the properties are the parameters to the function. For example: ``` { "type": "object", "properties": { "name": { "type": "string" }, "age": { "type": "integer" } }, "additionalProperties": false, "required": ["name", "age"], "propertyOrdering": ["name", "age"] } ``` This field is mutually exclusive with `parameters`. + /// + /// + /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). /// /// /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). /// - /// - /// Optional. Describes the output from this function in JSON Schema format. The value specified by the schema is the response value of the function. This field is mutually exclusive with `response`. + /// + /// Required. The name of the function. Must be a-z, A-Z, 0-9, or contain underscores, colons, dots, and dashes, with a maximum length of 128. /// /// /// 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. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method. - /// - /// - /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). + /// + /// 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`. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionDeclaration( - string? name, + global::Google.Gemini.FunctionDeclarationBehavior? behavior, + object? parametersJsonSchema, + global::Google.Gemini.Schema? parameters, global::Google.Gemini.Schema? response, - object? responseJsonSchema, + string? name, string? description, - object? parametersJsonSchema, - global::Google.Gemini.FunctionDeclarationBehavior? behavior, - global::Google.Gemini.Schema? parameters) + object? responseJsonSchema) { - this.Name = name; - this.Response = response; - this.ResponseJsonSchema = responseJsonSchema; - this.Description = description; - this.ParametersJsonSchema = parametersJsonSchema; this.Behavior = behavior; + this.ParametersJsonSchema = parametersJsonSchema; this.Parameters = parameters; + this.Response = response; + this.Name = name; + this.Description = description; + this.ResponseJsonSchema = responseJsonSchema; } /// 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 3ac420b4..15c3ad8d 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponse.g.cs @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class FunctionResponse { /// - /// 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 identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("id")] + public string? Id { 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. @@ -21,10 +21,16 @@ public sealed partial class FunctionResponse public object? Response { get; set; } /// - /// Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`. + /// Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types. /// - [global::System.Text.Json.Serialization.JsonPropertyName("id")] - public string? Id { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("parts")] + public global::System.Collections.Generic.IList? Parts { get; set; } + + /// + /// Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// /// Optional. Signals that function call continues, and more responses will be returned, turning the function call into a generator. Is only applicable to NON_BLOCKING function calls, is ignored otherwise. If set to false, future responses will not be considered. It is allowed to return empty `response` with `will_continue=False` to signal that the function call is finished. This may still trigger the model generation. To avoid triggering the generation and finish the function call, additionally set `scheduling` to `SILENT`. @@ -39,12 +45,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; } - /// - /// 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; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -54,14 +54,17 @@ public sealed partial class FunctionResponse /// /// Initializes a new instance of the class. /// - /// - /// Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128. + /// + /// Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`. /// /// /// 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. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`. + /// + /// Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types. + /// + /// + /// Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128. /// /// /// Optional. Signals that function call continues, and more responses will be returned, turning the function call into a generator. Is only applicable to NON_BLOCKING function calls, is ignored otherwise. If set to false, future responses will not be considered. It is allowed to return empty `response` with `will_continue=False` to signal that the function call is finished. This may still trigger the model generation. To avoid triggering the generation and finish the function call, additionally set `scheduling` to `SILENT`. @@ -69,26 +72,23 @@ public sealed partial class FunctionResponse /// /// Optional. Specifies how the response should be scheduled in the conversation. Only applicable to NON_BLOCKING function calls, is ignored otherwise. Defaults to WHEN_IDLE. /// - /// - /// Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionResponse( - string? name, - object? response, string? id, + object? response, + global::System.Collections.Generic.IList? parts, + string? name, bool? willContinue, - global::Google.Gemini.FunctionResponseScheduling? scheduling, - global::System.Collections.Generic.IList? parts) + global::Google.Gemini.FunctionResponseScheduling? scheduling) { - this.Name = name; - this.Response = response; this.Id = id; + this.Response = response; + this.Parts = parts; + this.Name = name; this.WillContinue = willContinue; this.Scheduling = scheduling; - this.Parts = parts; } /// 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 a6800467..31b298b5 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatch.g.cs @@ -9,17 +9,10 @@ namespace Google.Gemini public sealed partial class GenerateContentBatch { /// - /// Output only. The time at which the batch processing completed.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] - public string? EndTime { get; set; } - - /// - /// 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}`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("priority")] - public string? Priority { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("model")] + public string? Model { get; set; } /// /// Configures the input to the batch request. @@ -27,6 +20,13 @@ public sealed partial class GenerateContentBatch [global::System.Text.Json.Serialization.JsonPropertyName("inputConfig")] public global::Google.Gemini.InputConfig? InputConfig { get; set; } + /// + /// Output only. The time at which the batch was last updated.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } + /// /// Output only. The state of the batch.
/// Included only in responses @@ -36,30 +36,37 @@ public sealed partial class GenerateContentBatch public global::Google.Gemini.GenerateContentBatchState? State { get; set; } /// - /// Output only. The time at which the batch was last updated.
+ /// Output only. The time at which the batch processing completed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] + public string? EndTime { get; set; } /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// Stats about the batch. /// - [global::System.Text.Json.Serialization.JsonPropertyName("model")] - public string? Model { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("batchStats")] + public global::Google.Gemini.BatchStats? BatchStats { get; set; } /// - /// Output only. The time at which the batch was created.
+ /// Required. The user-defined name of this batch. + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } + + /// + /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// - /// Required. The user-defined name of this batch. + /// Output only. The time at which the batch 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; } /// /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. @@ -68,17 +75,10 @@ public sealed partial class GenerateContentBatch public global::Google.Gemini.GenerateContentBatchOutput? Output { get; set; } /// - /// Stats about the batch. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("batchStats")] - public global::Google.Gemini.BatchStats? BatchStats { get; set; } - - /// - /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
- /// Included only in responses + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("priority")] + public string? Priority { 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 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}`. /// /// /// Configures the input to the batch request. /// + /// + /// Output only. The time at which the batch was last updated.
+ /// Included only in responses + /// /// /// Output only. The state of the batch.
/// Included only in responses /// - /// - /// Output only. The time at which the batch was last updated.
+ /// + /// 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}`. + /// + /// Stats about the batch. + /// + /// + /// Required. The user-defined name of this batch. + /// + /// + /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
+ /// Included only in responses /// /// /// Output only. The time at which the batch was created.
/// Included only in responses /// - /// - /// Required. The user-defined name of this batch. - /// /// /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. /// - /// - /// Stats about the batch. - /// - /// - /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
- /// Included only in responses + /// + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerateContentBatch( - string? endTime, - string? priority, + string? model, global::Google.Gemini.InputConfig? inputConfig, - global::Google.Gemini.GenerateContentBatchState? state, string? updateTime, - string? model, - string? createTime, + global::Google.Gemini.GenerateContentBatchState? state, + string? endTime, + global::Google.Gemini.BatchStats? batchStats, string? displayName, + string? name, + string? createTime, global::Google.Gemini.GenerateContentBatchOutput? output, - global::Google.Gemini.BatchStats? batchStats, - string? name) + string? priority) { - this.EndTime = endTime; - this.Priority = priority; + this.Model = model; this.InputConfig = inputConfig; - this.State = state; this.UpdateTime = updateTime; - this.Model = model; - this.CreateTime = createTime; - this.DisplayName = displayName; - this.Output = output; + this.State = state; + this.EndTime = endTime; this.BatchStats = batchStats; + this.DisplayName = displayName; this.Name = name; + this.CreateTime = createTime; + this.Output = output; + this.Priority = priority; } /// 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 c34eb311..bb020165 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,12 +8,6 @@ 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 @@ -21,6 +15,12 @@ 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( - global::Google.Gemini.InlinedResponses? inlinedResponses, - string? responsesFile) + string? responsesFile, + global::Google.Gemini.InlinedResponses? inlinedResponses) { - this.InlinedResponses = inlinedResponses; this.ResponsesFile = responsesFile; + this.InlinedResponses = inlinedResponses; } /// 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 3771cb21..85252d19 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentRequest.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentRequest.g.cs @@ -8,18 +8,6 @@ namespace Google.Gemini /// public sealed partial class GenerateContentRequest { - /// - /// 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 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("cachedContent")] - public string? CachedContent { get; set; } - /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// @@ -27,10 +15,10 @@ public sealed partial class GenerateContentRequest public global::Google.Gemini.ToolConfig? ToolConfig { get; set; } /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("tools")] - public global::System.Collections.Generic.IList? Tools { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("generationConfig")] + public global::Google.Gemini.GenerationConfig? GenerationConfig { get; set; } /// /// Optional. The service tier of the request. @@ -52,16 +40,16 @@ public sealed partial class GenerateContentRequest public global::System.Collections.Generic.IList? Contents { get; set; } /// - /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - [global::System.Text.Json.Serialization.JsonPropertyName("safetySettings")] - public global::System.Collections.Generic.IList? SafetySettings { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("tools")] + public global::System.Collections.Generic.IList? Tools { get; set; } /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// - [global::System.Text.Json.Serialization.JsonPropertyName("generationConfig")] - public global::Google.Gemini.GenerationConfig? GenerationConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("cachedContent")] + public string? CachedContent { get; set; } /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. @@ -69,6 +57,18 @@ public sealed partial class GenerateContentRequest [global::System.Text.Json.Serialization.JsonPropertyName("store")] public bool? Store { get; set; } + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("model")] + public string? Model { get; set; } + + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("safetySettings")] + public global::System.Collections.Generic.IList? SafetySettings { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -78,17 +78,11 @@ public sealed partial class GenerateContentRequest /// /// Initializes a new instance of the class. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// /// /// Optional. The service tier of the request. @@ -99,40 +93,46 @@ public sealed partial class 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. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerateContentRequest( - string? model, - string? cachedContent, global::Google.Gemini.ToolConfig? toolConfig, - global::System.Collections.Generic.IList? tools, + global::Google.Gemini.GenerationConfig? generationConfig, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier, global::Google.Gemini.Content? systemInstruction, global::System.Collections.Generic.IList? contents, - global::System.Collections.Generic.IList? safetySettings, - global::Google.Gemini.GenerationConfig? generationConfig, - bool? store) + global::System.Collections.Generic.IList? tools, + string? cachedContent, + bool? store, + string? model, + global::System.Collections.Generic.IList? safetySettings) { - this.Model = model; - this.CachedContent = cachedContent; this.ToolConfig = toolConfig; - this.Tools = tools; + this.GenerationConfig = generationConfig; this.ServiceTier = serviceTier; this.SystemInstruction = systemInstruction; this.Contents = contents; - this.SafetySettings = safetySettings; - this.GenerationConfig = generationConfig; + this.Tools = tools; + this.CachedContent = cachedContent; this.Store = store; + this.Model = model; + this.SafetySettings = safetySettings; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentResponse.g.cs index 5e1a92fc..d3d811e0 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 @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class GenerateContentResponse { - /// - /// The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("modelStatus")] - public global::Google.Gemini.ModelStatus? ModelStatus { get; set; } - /// /// Candidate responses from the model. /// @@ -21,17 +15,10 @@ public sealed partial class GenerateContentResponse public global::System.Collections.Generic.IList? Candidates { get; set; } /// - /// Metadata on the generation request's token usage. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] - public global::Google.Gemini.UsageMetadata? UsageMetadata { get; set; } - - /// - /// Output only. The model version used to generate the response.
- /// Included only in responses + /// A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("modelVersion")] - public string? ModelVersion { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("promptFeedback")] + public global::Google.Gemini.PromptFeedback? PromptFeedback { get; set; } /// /// Output only. response_id is used to identify each response.
@@ -41,10 +28,23 @@ public sealed partial class GenerateContentResponse public string? ResponseId { get; set; } /// - /// A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`. + /// Metadata on the generation request's token usage. /// - [global::System.Text.Json.Serialization.JsonPropertyName("promptFeedback")] - public global::Google.Gemini.PromptFeedback? PromptFeedback { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] + public global::Google.Gemini.UsageMetadata? UsageMetadata { get; set; } + + /// + /// The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("modelStatus")] + public global::Google.Gemini.ModelStatus? ModelStatus { get; set; } + + /// + /// Output only. The model version used to generate the response.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("modelVersion")] + public string? ModelVersion { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -55,43 +55,43 @@ public sealed partial class GenerateContentResponse /// /// Initializes a new instance of the class. /// - /// - /// 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. /// + /// + /// 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 + /// /// /// Metadata on the generation request's token usage. /// + /// + /// The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable. + /// /// /// Output only. The model version used to generate the response.
/// Included only in responses /// - /// - /// Output only. response_id is used to identify each response.
- /// Included only in responses - /// - /// - /// A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerateContentResponse( - global::Google.Gemini.ModelStatus? modelStatus, global::System.Collections.Generic.IList? candidates, - global::Google.Gemini.UsageMetadata? usageMetadata, - string? modelVersion, + global::Google.Gemini.PromptFeedback? promptFeedback, string? responseId, - global::Google.Gemini.PromptFeedback? promptFeedback) + global::Google.Gemini.UsageMetadata? usageMetadata, + global::Google.Gemini.ModelStatus? modelStatus, + string? modelVersion) { - this.ModelStatus = modelStatus; this.Candidates = candidates; + this.PromptFeedback = promptFeedback; + this.ResponseId = responseId; this.UsageMetadata = usageMetadata; + this.ModelStatus = modelStatus; this.ModelVersion = modelVersion; - this.ResponseId = responseId; - this.PromptFeedback = promptFeedback; } /// 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 2517cf54..c0eca73d 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 @@ -20,12 +20,6 @@ public sealed partial class GeneratedFile [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] public string? MimeType { get; set; } - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("error")] - public global::Google.Gemini.Status? Error { get; set; } - /// /// Output only. The state of the GeneratedFile.
/// Included only in responses @@ -34,6 +28,12 @@ public sealed partial class GeneratedFile [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateJsonConverter))] public global::Google.Gemini.GeneratedFileState? State { get; set; } + /// + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("error")] + public global::Google.Gemini.Status? Error { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -49,26 +49,26 @@ public sealed partial class GeneratedFile /// /// MIME type of the generatedFile. /// - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). - /// /// /// 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). + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GeneratedFile( string? name, string? mimeType, - global::Google.Gemini.Status? error, - global::Google.Gemini.GeneratedFileState? state) + global::Google.Gemini.GeneratedFileState? state, + global::Google.Gemini.Status? error) { this.Name = name; this.MimeType = mimeType; - this.Error = error; this.State = state; + this.Error = error; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerationConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerationConfig.g.cs index d74971a1..5705409e 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,41 +9,28 @@ namespace Google.Gemini public sealed partial class GenerationConfig { /// - /// Optional. If specified, the media resolution specified will be used. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("mediaResolution")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionJsonConverter))] - public global::Google.Gemini.GenerationConfigMediaResolution? MediaResolution { get; set; } - - /// - /// Optional. The maximum number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("topK")] - public int? TopK { get; set; } - - /// - /// Optional. Presence penalty applied to the next token's logprobs if the token has already been seen in the response. This penalty is binary on/off and not dependant on the number of times the token is used (after the first). Use frequency_penalty for a penalty that increases with each use. A positive penalty will discourage the use of tokens that have already been used in the response, increasing the vocabulary. A negative penalty will encourage the use of tokens that have already been used in the response, decreasing the vocabulary. + /// Optional. 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("presencePenalty")] - public float? PresencePenalty { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] + public float? Temperature { get; set; } /// - /// Optional. An internal detail. Use `responseJsonSchema` rather than this field. + /// Optional. MIME type of the generated candidate text. Supported MIME types are: `text/plain`: (default) Text output. `application/json`: JSON response in the response candidates. `text/x.enum`: ENUM as a string response in the response candidates. Refer to the [docs](https://ai.google.dev/gemini-api/docs/prompting_with_media#plain_text_formats) for a list of all supported text MIME types. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseJsonSchema")] - public object? ResponseJsonSchema { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseMimeType")] + public string? ResponseMimeType { get; set; } /// - /// Config for speech generation and transcription. + /// Optional. Seed used in decoding. If not set, the request uses a randomly generated seed. /// - [global::System.Text.Json.Serialization.JsonPropertyName("speechConfig")] - public global::Google.Gemini.SpeechConfig? SpeechConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("seed")] + 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. 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("stopSequences")] - public global::System.Collections.Generic.IList? StopSequences { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topP")] + public float? TopP { 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. @@ -52,70 +39,70 @@ public sealed partial class GenerationConfig 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. Enables enhanced civic answers. It may not be available for all models. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseFormat")] - public global::Google.Gemini.ResponseFormatConfig? ResponseFormat { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("enableEnhancedCivicAnswers")] + public bool? EnableEnhancedCivicAnswers { get; set; } /// - /// Optional. The maximum cumulative probability of tokens to consider when sampling. The model uses combined Top-k and Top-p (nucleus) sampling. Tokens are sorted based on their assigned probabilities so that only the most likely tokens are considered. Top-k sampling directly limits the maximum number of tokens to consider, while Nucleus sampling limits the number of tokens based on the cumulative probability. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests. + /// Optional. The 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("topP")] - public float? TopP { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("stopSequences")] + public global::System.Collections.Generic.IList? StopSequences { get; set; } /// - /// Optional. If true, export the logprobs results in response. + /// 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("responseLogprobs")] - public bool? ResponseLogprobs { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("candidateCount")] + public int? CandidateCount { get; set; } /// - /// Config for translation features. + /// 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("translationConfig")] - public global::Google.Gemini.TranslationConfig? TranslationConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxOutputTokens")] + public int? MaxOutputTokens { 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. + /// Optional. The maximum number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseModalities")] - public global::System.Collections.Generic.IList? ResponseModalities { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topK")] + public int? TopK { 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]. + /// Config for thinking features. /// - [global::System.Text.Json.Serialization.JsonPropertyName("logprobs")] - public int? Logprobs { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("thinkingConfig")] + public global::Google.Gemini.ThinkingConfig? ThinkingConfig { get; set; } /// - /// Optional. The maximum number of tokens to include in a response candidate. Note: The default value varies by model, see the `Model.output_token_limit` attribute of the `Model` returned from the `getModel` function. + /// 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("maxOutputTokens")] - public int? MaxOutputTokens { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseFormat")] + public global::Google.Gemini.ResponseFormatConfig? ResponseFormat { get; set; } /// - /// Config for image generation features. + /// 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("imageConfig")] - public global::Google.Gemini.ImageConfig? ImageConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("presencePenalty")] + public float? PresencePenalty { get; set; } /// - /// Optional. Seed used in decoding. If not set, the request uses a randomly generated seed. + /// Config for speech generation and transcription. /// - [global::System.Text.Json.Serialization.JsonPropertyName("seed")] - public int? Seed { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("speechConfig")] + public global::Google.Gemini.SpeechConfig? SpeechConfig { get; set; } /// - /// Config for thinking features. + /// Config for translation features. /// - [global::System.Text.Json.Serialization.JsonPropertyName("thinkingConfig")] - public global::Google.Gemini.ThinkingConfig? ThinkingConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("translationConfig")] + public global::Google.Gemini.TranslationConfig? TranslationConfig { 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. 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("responseMimeType")] - public string? ResponseMimeType { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("logprobs")] + public int? Logprobs { get; set; } /// /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). @@ -124,22 +111,35 @@ public sealed partial class GenerationConfig public global::Google.Gemini.Schema? ResponseSchema { 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. If true, export the logprobs results in response. /// - [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] - public float? Temperature { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseLogprobs")] + public bool? ResponseLogprobs { get; set; } /// - /// Optional. Enables enhanced civic answers. It may not be available for all models. + /// Config for image generation features. /// - [global::System.Text.Json.Serialization.JsonPropertyName("enableEnhancedCivicAnswers")] - public bool? EnableEnhancedCivicAnswers { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("imageConfig")] + public global::Google.Gemini.ImageConfig? ImageConfig { get; set; } /// - /// Optional. Number of generated responses to return. If unset, this will default to 1. Please note that this doesn't work for previous generation models (Gemini 1.0 family) + /// Optional. An internal detail. Use `responseJsonSchema` rather than this field. /// - [global::System.Text.Json.Serialization.JsonPropertyName("candidateCount")] - public int? CandidateCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseJsonSchema")] + public object? ResponseJsonSchema { 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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("responseModalities")] + public global::System.Collections.Generic.IList? ResponseModalities { get; set; } + + /// + /// Optional. If specified, the media resolution specified will be used. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("mediaResolution")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionJsonConverter))] + public global::Google.Gemini.GenerationConfigMediaResolution? MediaResolution { get; set; } /// /// 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. If specified, the media resolution specified will be used. + /// + /// Optional. Controls the randomness of the output. Note: The default value varies by model, see the `Model.temperature` attribute of the `Model` returned from the `getModel` function. Values can range from [0.0, 2.0]. /// - /// - /// Optional. The maximum number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests. + /// + /// Optional. MIME type of the generated candidate text. Supported MIME types are: `text/plain`: (default) Text output. `application/json`: JSON response in the response candidates. `text/x.enum`: ENUM as a string response in the response candidates. Refer to the [docs](https://ai.google.dev/gemini-api/docs/prompting_with_media#plain_text_formats) for a list of all supported text MIME types. /// - /// - /// Optional. Presence penalty applied to the next token's logprobs if the token has already been seen in the response. This penalty is binary on/off and not dependant on the number of times the token is used (after the first). Use frequency_penalty for a penalty that increases with each use. A positive penalty will discourage the use of tokens that have already been used in the response, increasing the vocabulary. A negative penalty will encourage the use of tokens that have already been used in the response, decreasing the vocabulary. + /// + /// Optional. Seed used in decoding. If not set, the request uses a randomly generated seed. /// - /// - /// Optional. An internal detail. Use `responseJsonSchema` rather than this field. + /// + /// Optional. 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. /// - /// - /// Config for speech generation and transcription. + /// + /// Optional. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit. + /// + /// + /// Optional. 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. /// - /// - /// 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. Number of generated responses to return. If unset, this will default to 1. Please note that this doesn't work for previous generation models (Gemini 1.0 family) + /// + /// + /// Optional. The maximum number of tokens to include in a response candidate. Note: The default value varies by model, see the `Model.output_token_limit` attribute of the `Model` returned from the `getModel` function. + /// + /// + /// Optional. The maximum number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests. + /// + /// + /// Config for thinking features. /// /// /// Configuration for the response output format. This is a flat object where each optional sub-field configures a specific output modality. /// - /// - /// 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. Presence penalty applied to the next token's logprobs if the token has already been seen in the response. This penalty is binary on/off and not dependant on the number of times the token is used (after the first). Use frequency_penalty for a penalty that increases with each use. A positive penalty will discourage the use of tokens that have already been used in the response, increasing the vocabulary. A negative penalty will encourage the use of tokens that have already been used in the response, decreasing the vocabulary. /// - /// - /// Optional. If true, export the logprobs results in response. + /// + /// Config for speech generation and transcription. /// /// /// Config for translation features. /// - /// - /// 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. Only valid if response_logprobs=True. This sets the number of top logprobs, including the chosen candidate, to return at each decoding step in the Candidate.logprobs_result. The number must be in the range of [0, 20]. /// - /// - /// Optional. The maximum number of tokens to 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. If true, export the logprobs results in response. /// /// /// Config for image generation features. /// - /// - /// Optional. Seed used in decoding. If not set, the request uses a randomly generated seed. - /// - /// - /// Config for thinking features. - /// - /// - /// Optional. MIME type of the generated candidate text. Supported MIME types are: `text/plain`: (default) Text output. `application/json`: JSON response in the response candidates. `text/x.enum`: ENUM as a string response in the response candidates. Refer to the [docs](https://ai.google.dev/gemini-api/docs/prompting_with_media#plain_text_formats) for a list of all supported text MIME types. - /// - /// - /// 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. 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. An internal detail. Use `responseJsonSchema` rather than this field. /// - /// - /// Optional. Enables enhanced civic answers. It may not be available for all models. + /// + /// 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. 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 specified, the media resolution specified will be used. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerationConfig( - global::Google.Gemini.GenerationConfigMediaResolution? mediaResolution, + float? temperature, + string? responseMimeType, + int? seed, + float? topP, + float? frequencyPenalty, + bool? enableEnhancedCivicAnswers, + global::System.Collections.Generic.IList? stopSequences, + int? candidateCount, + int? maxOutputTokens, int? topK, + global::Google.Gemini.ThinkingConfig? thinkingConfig, + global::Google.Gemini.ResponseFormatConfig? responseFormat, float? presencePenalty, - object? responseJsonSchema, global::Google.Gemini.SpeechConfig? speechConfig, - global::System.Collections.Generic.IList? stopSequences, - float? frequencyPenalty, - global::Google.Gemini.ResponseFormatConfig? responseFormat, - float? topP, - bool? responseLogprobs, global::Google.Gemini.TranslationConfig? translationConfig, - global::System.Collections.Generic.IList? responseModalities, int? logprobs, - int? maxOutputTokens, - global::Google.Gemini.ImageConfig? imageConfig, - int? seed, - global::Google.Gemini.ThinkingConfig? thinkingConfig, - string? responseMimeType, global::Google.Gemini.Schema? responseSchema, - float? temperature, - bool? enableEnhancedCivicAnswers, - int? candidateCount) + bool? responseLogprobs, + global::Google.Gemini.ImageConfig? imageConfig, + object? responseJsonSchema, + global::System.Collections.Generic.IList? responseModalities, + global::Google.Gemini.GenerationConfigMediaResolution? mediaResolution) { - this.MediaResolution = mediaResolution; + this.Temperature = temperature; + this.ResponseMimeType = responseMimeType; + this.Seed = seed; + this.TopP = topP; + this.FrequencyPenalty = frequencyPenalty; + this.EnableEnhancedCivicAnswers = enableEnhancedCivicAnswers; + this.StopSequences = stopSequences; + this.CandidateCount = candidateCount; + this.MaxOutputTokens = maxOutputTokens; this.TopK = topK; + this.ThinkingConfig = thinkingConfig; + this.ResponseFormat = responseFormat; this.PresencePenalty = presencePenalty; - this.ResponseJsonSchema = responseJsonSchema; this.SpeechConfig = speechConfig; - this.StopSequences = stopSequences; - this.FrequencyPenalty = frequencyPenalty; - this.ResponseFormat = responseFormat; - this.TopP = topP; - this.ResponseLogprobs = responseLogprobs; this.TranslationConfig = translationConfig; - this.ResponseModalities = responseModalities; this.Logprobs = logprobs; - this.MaxOutputTokens = maxOutputTokens; - this.ImageConfig = imageConfig; - this.Seed = seed; - this.ThinkingConfig = thinkingConfig; - this.ResponseMimeType = responseMimeType; this.ResponseSchema = responseSchema; - this.Temperature = temperature; - this.EnableEnhancedCivicAnswers = enableEnhancedCivicAnswers; - this.CandidateCount = candidateCount; + this.ResponseLogprobs = responseLogprobs; + this.ImageConfig = imageConfig; + this.ResponseJsonSchema = responseJsonSchema; + this.ResponseModalities = responseModalities; + this.MediaResolution = mediaResolution; } /// 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 9e3818e6..b34f6556 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 @@ -14,6 +14,12 @@ public sealed partial class GoogleAiGenerativelanguageV1betaGroundingSupport [global::System.Text.Json.Serialization.JsonPropertyName("segment")] public global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? Segment { 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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("confidenceScores")] + public global::System.Collections.Generic.IList? ConfidenceScores { 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 @@ -27,12 +33,6 @@ public sealed partial class GoogleAiGenerativelanguageV1betaGroundingSupport [global::System.Text.Json.Serialization.JsonPropertyName("groundingChunkIndices")] public global::System.Collections.Generic.IList? GroundingChunkIndices { 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. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("confidenceScores")] - public global::System.Collections.Generic.IList? ConfidenceScores { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -45,6 +45,9 @@ public sealed partial class GoogleAiGenerativelanguageV1betaGroundingSupport /// /// Segment of the content. /// + /// + /// 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. + /// /// /// 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 @@ -52,22 +55,19 @@ public sealed partial class GoogleAiGenerativelanguageV1betaGroundingSupport /// /// Optional. A list of indices (into 'grounding_chunk' in `response.candidate.grounding_metadata`) specifying the citations associated with the claim. For instance [1,3,4] means that grounding_chunk[1], grounding_chunk[3], grounding_chunk[4] are the retrieved content attributed to the claim. If the response is streaming, the grounding_chunk_indices refer to the indices across all responses. It is the client's responsibility to accumulate the grounding chunks from all responses (while maintaining the same order). /// - /// - /// Optional. Confidence score of the support references. Ranges from 0 to 1. 1 is the most confident. This list must have the same size as the grounding_chunk_indices. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GoogleAiGenerativelanguageV1betaGroundingSupport( global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? segment, + global::System.Collections.Generic.IList? confidenceScores, global::System.Collections.Generic.IList? renderedParts, - global::System.Collections.Generic.IList? groundingChunkIndices, - global::System.Collections.Generic.IList? confidenceScores) + global::System.Collections.Generic.IList? groundingChunkIndices) { this.Segment = segment; + this.ConfidenceScores = confidenceScores; this.RenderedParts = renderedParts; this.GroundingChunkIndices = groundingChunkIndices; - 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 cc2261d5..dec5fe8c 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 @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class GoogleAiGenerativelanguageV1betaSegment { + /// + /// The index of a Part object within its parent Content object. + /// + [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. /// @@ -26,12 +32,6 @@ public sealed partial class GoogleAiGenerativelanguageV1betaSegment [global::System.Text.Json.Serialization.JsonPropertyName("startIndex")] public int? StartIndex { get; set; } - /// - /// The index of a Part object within its parent Content object. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("partIndex")] - public int? PartIndex { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -41,6 +41,9 @@ public sealed partial class GoogleAiGenerativelanguageV1betaSegment /// /// Initializes a new instance of the class. /// + /// + /// 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. /// @@ -50,22 +53,19 @@ public sealed partial class GoogleAiGenerativelanguageV1betaSegment /// /// Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero. /// - /// - /// The index of a Part object within its parent Content object. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GoogleAiGenerativelanguageV1betaSegment( + int? partIndex, int? endIndex, string? text, - int? startIndex, - int? partIndex) + int? startIndex) { + this.PartIndex = partIndex; this.EndIndex = endIndex; this.Text = text; this.StartIndex = startIndex; - this.PartIndex = partIndex; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingAttribution.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingAttribution.g.cs index 87cb92d8..5f952188 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingAttribution.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingAttribution.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class GroundingAttribution { - /// - /// Identifier for the source contributing to this attribution. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("sourceId")] - public global::Google.Gemini.AttributionSourceId? SourceId { get; set; } - /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// [global::System.Text.Json.Serialization.JsonPropertyName("content")] public global::Google.Gemini.Content? Content { get; set; } + /// + /// Identifier for the source contributing to this attribution. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("sourceId")] + public global::Google.Gemini.AttributionSourceId? SourceId { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class GroundingAttribution /// /// Initializes a new instance of the class. /// - /// - /// Identifier for the source contributing to this attribution. - /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// + /// + /// Identifier for the source contributing to this attribution. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingAttribution( - global::Google.Gemini.AttributionSourceId? sourceId, - global::Google.Gemini.Content? content) + global::Google.Gemini.Content? content, + global::Google.Gemini.AttributionSourceId? sourceId) { - this.SourceId = sourceId; this.Content = content; + this.SourceId = sourceId; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunk.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunk.g.cs index 50f41a7b..a5794789 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,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class GroundingChunk { - /// - /// 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. /// @@ -32,6 +26,12 @@ public sealed partial class GroundingChunk [global::System.Text.Json.Serialization.JsonPropertyName("maps")] public global::Google.Gemini.Maps? Maps { get; set; } + /// + /// Chunk from image search. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("image")] + public global::Google.Gemini.Image? Image { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -41,9 +41,6 @@ public sealed partial class GroundingChunk /// /// Initializes a new instance of the class. /// - /// - /// Chunk from image search. - /// /// /// Chunk from context retrieved by the file search tool. /// @@ -53,19 +50,22 @@ public sealed partial class GroundingChunk /// /// A grounding chunk from Google Maps. A Maps chunk corresponds to a single place. /// + /// + /// Chunk from image search. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingChunk( - global::Google.Gemini.Image? image, global::Google.Gemini.RetrievedContext? retrievedContext, global::Google.Gemini.Web? web, - global::Google.Gemini.Maps? maps) + global::Google.Gemini.Maps? maps, + global::Google.Gemini.Image? image) { - this.Image = image; this.RetrievedContext = retrievedContext; this.Web = web; this.Maps = maps; + this.Image = image; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunkCustomMetadata.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunkCustomMetadata.g.cs index 833e31c1..406aef06 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; } + /// + /// Optional. The numeric value of the metadata. The expected range for this value depends on the specific `key` used. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("numericValue")] + public float? NumericValue { get; set; } + /// /// A list of string values. /// @@ -27,10 +27,10 @@ public sealed partial class GroundingChunkCustomMetadata public global::Google.Gemini.GroundingChunkStringList? StringListValue { get; set; } /// - /// Optional. The numeric value of the metadata. The expected range for this value depends on the specific `key` used. + /// The key of the metadata. /// - [global::System.Text.Json.Serialization.JsonPropertyName("numericValue")] - public float? NumericValue { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("key")] + public string? Key { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -41,31 +41,31 @@ public sealed partial class GroundingChunkCustomMetadata /// /// Initializes a new instance of the class. /// - /// - /// The key of the metadata. - /// /// /// Optional. The string value of the metadata. /// + /// + /// Optional. The numeric value of the metadata. The expected range for this value depends on the specific `key` used. + /// /// /// A list of string values. /// - /// - /// Optional. The numeric value of the metadata. The expected range for this value depends on the specific `key` used. + /// + /// The key of the metadata. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingChunkCustomMetadata( - string? key, string? stringValue, + float? numericValue, global::Google.Gemini.GroundingChunkStringList? stringListValue, - float? numericValue) + string? key) { - this.Key = key; this.StringValue = stringValue; - this.StringListValue = stringListValue; this.NumericValue = numericValue; + this.StringListValue = stringListValue; + this.Key = key; } /// 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 cac0cd2a..562bba31 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingMetadata.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingMetadata.g.cs @@ -8,36 +8,24 @@ namespace Google.Gemini /// public sealed partial class GroundingMetadata { - /// - /// List of grounding support. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("groundingSupports")] - public global::System.Collections.Generic.IList? GroundingSupports { get; set; } - - /// - /// Optional. Resource name of the Google Maps widget context token that can be used with the PlacesContextElement widget in order to render contextual data. Only populated in the case that grounding with Google Maps is enabled. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleMapsWidgetContextToken")] - public string? GoogleMapsWidgetContextToken { get; set; } - /// /// Google search entry point. /// [global::System.Text.Json.Serialization.JsonPropertyName("searchEntryPoint")] public global::Google.Gemini.SearchEntryPoint? SearchEntryPoint { get; set; } - /// - /// List of supporting references retrieved from specified grounding source. When streaming, this only contains the grounding chunks that have not been included in the grounding metadata of previous responses. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("groundingChunks")] - public global::System.Collections.Generic.IList? GroundingChunks { get; set; } - /// /// 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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("groundingSupports")] + public global::System.Collections.Generic.IList? GroundingSupports { get; set; } + /// /// Image search queries used for grounding. /// @@ -50,6 +38,18 @@ public sealed partial class GroundingMetadata [global::System.Text.Json.Serialization.JsonPropertyName("retrievalMetadata")] public global::Google.Gemini.RetrievalMetadata? RetrievalMetadata { get; set; } + /// + /// List of supporting references retrieved from specified grounding source. When streaming, this only contains the grounding chunks that have not been included in the grounding metadata of previous responses. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("groundingChunks")] + public global::System.Collections.Generic.IList? GroundingChunks { get; set; } + + /// + /// 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("googleMapsWidgetContextToken")] + public string? GoogleMapsWidgetContextToken { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -59,46 +59,46 @@ public sealed partial class GroundingMetadata /// /// Initializes a new instance of the class. /// - /// - /// 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. - /// /// /// Google search entry point. /// - /// - /// 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. - /// /// /// Web search queries for the following-up web search. /// + /// + /// List of grounding support. + /// /// /// Image search queries used for grounding. /// /// /// Metadata related to retrieval in the grounding flow. /// + /// + /// 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. + /// + /// + /// 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. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingMetadata( - global::System.Collections.Generic.IList? groundingSupports, - string? googleMapsWidgetContextToken, global::Google.Gemini.SearchEntryPoint? searchEntryPoint, - global::System.Collections.Generic.IList? groundingChunks, global::System.Collections.Generic.IList? webSearchQueries, + global::System.Collections.Generic.IList? groundingSupports, global::System.Collections.Generic.IList? imageSearchQueries, - global::Google.Gemini.RetrievalMetadata? retrievalMetadata) + global::Google.Gemini.RetrievalMetadata? retrievalMetadata, + global::System.Collections.Generic.IList? groundingChunks, + string? googleMapsWidgetContextToken) { - this.GroundingSupports = groundingSupports; - this.GoogleMapsWidgetContextToken = googleMapsWidgetContextToken; this.SearchEntryPoint = searchEntryPoint; - this.GroundingChunks = groundingChunks; this.WebSearchQueries = webSearchQueries; + this.GroundingSupports = groundingSupports; this.ImageSearchQueries = imageSearchQueries; this.RetrievalMetadata = retrievalMetadata; + this.GroundingChunks = groundingChunks; + this.GoogleMapsWidgetContextToken = googleMapsWidgetContextToken; } /// 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 02ec89a8..a49435d1 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,30 +8,30 @@ namespace Google.Gemini /// public sealed partial class Hyperparameters { - /// - /// Optional. Immutable. The learning rate multiplier is used to calculate a final learning_rate based on the default (recommended) value. Actual learning rate := learning_rate_multiplier * default learning rate Default learning rate is dependent on base model and dataset size. If not set, a default of 1.0 will be used. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("learningRateMultiplier")] - public float? LearningRateMultiplier { get; set; } - - /// - /// Immutable. The number of training epochs. An epoch is one pass through the training data. If not set, a default of 5 will be used. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("epochCount")] - public int? EpochCount { get; set; } - /// /// Optional. Immutable. The learning rate hyperparameter for tuning. If not set, a default of 0.001 or 0.0002 will be calculated based on the number of training examples. /// [global::System.Text.Json.Serialization.JsonPropertyName("learningRate")] public float? LearningRate { get; set; } + /// + /// Optional. Immutable. The learning rate multiplier is used to calculate a final learning_rate based on the default (recommended) value. Actual learning rate := learning_rate_multiplier * default learning rate Default learning rate is dependent on base model and dataset size. If not set, a default of 1.0 will be used. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("learningRateMultiplier")] + public float? LearningRateMultiplier { get; set; } + /// /// Immutable. The batch size hyperparameter for tuning. If not set, a default of 4 or 16 will be used based on the number of training examples. /// [global::System.Text.Json.Serialization.JsonPropertyName("batchSize")] public int? BatchSize { get; set; } + /// + /// Immutable. The number of training epochs. An epoch is one pass through the training data. If not set, a default of 5 will be used. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("epochCount")] + public int? EpochCount { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -41,31 +41,31 @@ public sealed partial class Hyperparameters /// /// Initializes a new instance of the class. /// - /// - /// Optional. Immutable. The learning rate multiplier is used to calculate a final learning_rate based on the default (recommended) value. Actual learning rate := learning_rate_multiplier * default learning rate Default learning rate is dependent on base model and dataset size. If not set, a default of 1.0 will be used. - /// - /// - /// Immutable. The number of training epochs. An epoch is one pass through the training data. If not set, a default of 5 will be used. - /// /// /// Optional. Immutable. The learning rate hyperparameter for tuning. If not set, a default of 0.001 or 0.0002 will be calculated based on the number of training examples. /// + /// + /// 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. /// + /// + /// 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. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Hyperparameters( - float? learningRateMultiplier, - int? epochCount, float? learningRate, - int? batchSize) + float? learningRateMultiplier, + int? batchSize, + int? epochCount) { - this.LearningRateMultiplier = learningRateMultiplier; - this.EpochCount = epochCount; this.LearningRate = learningRate; + this.LearningRateMultiplier = learningRateMultiplier; this.BatchSize = batchSize; + this.EpochCount = epochCount; } /// 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 c92b6eea..39c18fbf 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 @@ -15,10 +15,10 @@ public sealed partial class Image public string? SourceUri { get; set; } /// - /// The title of the web page that the image is from. + /// The root domain of the web page that the image is from, e.g. "example.com". /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - public string? Title { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("domain")] + public string? Domain { get; set; } /// /// The image asset URL. @@ -27,10 +27,10 @@ public sealed partial class Image public string? ImageUri { get; set; } /// - /// The root domain of the web page that the image is from, e.g. "example.com". + /// The title of the web page that the image is from. /// - [global::System.Text.Json.Serialization.JsonPropertyName("domain")] - public string? Domain { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("title")] + public string? Title { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -44,28 +44,28 @@ public sealed partial class Image /// /// The web page URI for attribution. /// - /// - /// The title of the web page that the image is from. + /// + /// The root domain of the web page that the image is from, e.g. "example.com". /// /// /// The image asset URL. /// - /// - /// The root domain of the web page that the image is from, e.g. "example.com". + /// + /// The title of the web page that the image is from. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Image( string? sourceUri, - string? title, + string? domain, string? imageUri, - string? domain) + string? title) { this.SourceUri = sourceUri; - this.Title = title; - this.ImageUri = imageUri; this.Domain = domain; + this.ImageUri = imageUri; + this.Title = title; } /// 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 b21e1c7b..e876f9ed 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 @@ -15,13 +15,6 @@ public sealed partial class ImageResponseFormat [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatMimeTypeJsonConverter))] public global::Google.Gemini.ImageResponseFormatMimeType? MimeType { get; set; } - /// - /// Optional. The size of the image output. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("imageSize")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatImageSizeJsonConverter))] - public global::Google.Gemini.ImageResponseFormatImageSize? ImageSize { get; set; } - /// /// Optional. The delivery mode for the image output. /// @@ -29,6 +22,13 @@ public sealed partial class ImageResponseFormat [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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("imageSize")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatImageSizeJsonConverter))] + public global::Google.Gemini.ImageResponseFormatImageSize? ImageSize { get; set; } + /// /// Optional. The aspect ratio for the image output. /// @@ -48,12 +48,12 @@ public sealed partial class ImageResponseFormat /// /// Optional. The MIME type of the image output. /// - /// - /// Optional. The size of the image output. - /// /// /// Optional. The delivery mode for the image output. /// + /// + /// Optional. The size of the image output. + /// /// /// Optional. The aspect ratio for the image output. /// @@ -62,13 +62,13 @@ public sealed partial class ImageResponseFormat #endif public ImageResponseFormat( global::Google.Gemini.ImageResponseFormatMimeType? mimeType, - global::Google.Gemini.ImageResponseFormatImageSize? imageSize, global::Google.Gemini.ImageResponseFormatDelivery? delivery, + global::Google.Gemini.ImageResponseFormatImageSize? imageSize, global::Google.Gemini.ImageResponseFormatAspectRatio? aspectRatio) { this.MimeType = mimeType; - this.ImageSize = imageSize; this.Delivery = delivery; + this.ImageSize = imageSize; this.AspectRatio = aspectRatio; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImportFileRequest.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImportFileRequest.g.cs index b8060008..5cc69875 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,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class ImportFileRequest { + /// + /// Required. The name of the `File` to import. Example: `files/abc-123` + /// + [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 /// @@ -20,12 +26,6 @@ public sealed partial class ImportFileRequest [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] public global::System.Collections.Generic.IList? CustomMetadata { get; set; } - /// - /// Required. The name of the `File` to import. Example: `files/abc-123` - /// - [global::System.Text.Json.Serialization.JsonPropertyName("fileName")] - public string? FileName { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class ImportFileRequest /// /// Initializes a new instance of the class. /// + /// + /// 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 /// /// /// Custom metadata to be associated with the file. /// - /// - /// Required. The name of the `File` to import. Example: `files/abc-123` - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ImportFileRequest( + string? fileName, global::Google.Gemini.ChunkingConfig? chunkingConfig, - global::System.Collections.Generic.IList? customMetadata, - string? fileName) + global::System.Collections.Generic.IList? customMetadata) { + this.FileName = fileName; this.ChunkingConfig = chunkingConfig; this.CustomMetadata = customMetadata; - this.FileName = fileName; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentResponse.g.cs index 21763257..c4006720 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentResponse.g.cs @@ -14,6 +14,12 @@ public sealed partial class InlinedEmbedContentResponse [global::System.Text.Json.Serialization.JsonPropertyName("error")] public global::Google.Gemini.Status? Error { get; set; } + /// + /// The response to an `EmbedContentRequest`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("response")] + public global::Google.Gemini.EmbedContentResponse? Response { get; set; } + /// /// Output only. The metadata associated with the request.
/// Included only in responses @@ -21,12 +27,6 @@ public sealed partial class InlinedEmbedContentResponse [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] public object? Metadata { get; set; } - /// - /// The response to an `EmbedContentRequest`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("response")] - public global::Google.Gemini.EmbedContentResponse? Response { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -39,24 +39,24 @@ public sealed partial class InlinedEmbedContentResponse /// /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// + /// + /// The response to an `EmbedContentRequest`. + /// /// /// Output only. The metadata associated with the request.
/// Included only in responses /// - /// - /// The response to an `EmbedContentRequest`. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public InlinedEmbedContentResponse( global::Google.Gemini.Status? error, - object? metadata, - global::Google.Gemini.EmbedContentResponse? response) + global::Google.Gemini.EmbedContentResponse? response, + object? metadata) { this.Error = error; - this.Metadata = metadata; this.Response = response; + this.Metadata = metadata; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InputConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InputConfig.g.cs index 3d0f91ff..736a29fe 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InputConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InputConfig.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class InputConfig { - /// - /// The name of the `File` containing the input requests. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("fileName")] - public string? FileName { get; set; } - /// /// The requests to be processed in the batch if provided as part of the batch creation request. /// [global::System.Text.Json.Serialization.JsonPropertyName("requests")] public global::Google.Gemini.InlinedRequests? Requests { get; set; } + /// + /// The name of the `File` containing the input requests. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("fileName")] + public string? FileName { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class InputConfig /// /// Initializes a new instance of the class. /// - /// - /// The name of the `File` containing the input requests. - /// /// /// The requests to be processed in the batch if provided as part of the batch creation request. /// + /// + /// The name of the `File` containing the input requests. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public InputConfig( - string? fileName, - global::Google.Gemini.InlinedRequests? requests) + global::Google.Gemini.InlinedRequests? requests, + string? fileName) { - this.FileName = fileName; this.Requests = requests; + this.FileName = fileName; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InputEmbedContentConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InputEmbedContentConfig.g.cs index 2ca5e4b2..05a50bda 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InputEmbedContentConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InputEmbedContentConfig.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class InputEmbedContentConfig { - /// - /// The name of the `File` containing the input requests. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("fileName")] - public string? FileName { get; set; } - /// /// The requests to be processed in the batch if provided as part of the batch creation request. /// [global::System.Text.Json.Serialization.JsonPropertyName("requests")] public global::Google.Gemini.InlinedEmbedContentRequests? Requests { get; set; } + /// + /// The name of the `File` containing the input requests. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("fileName")] + public string? FileName { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class InputEmbedContentConfig /// /// Initializes a new instance of the class. /// - /// - /// The name of the `File` containing the input requests. - /// /// /// The requests to be processed in the batch if provided as part of the batch creation request. /// + /// + /// The name of the `File` containing the input requests. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public InputEmbedContentConfig( - string? fileName, - global::Google.Gemini.InlinedEmbedContentRequests? requests) + global::Google.Gemini.InlinedEmbedContentRequests? requests, + string? fileName) { - this.FileName = fileName; this.Requests = requests; + this.FileName = fileName; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListDocumentsResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListDocumentsResponse.g.cs index ba11d1ec..305a1062 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 { - /// - /// 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; } + /// + /// The returned `Document`s. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("documents")] + public global::System.Collections.Generic.IList? Documents { 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. /// - /// - /// 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. /// + /// + /// The returned `Document`s. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListDocumentsResponse( - global::System.Collections.Generic.IList? documents, - string? nextPageToken) + string? nextPageToken, + global::System.Collections.Generic.IList? documents) { - this.Documents = documents; this.NextPageToken = nextPageToken; + this.Documents = documents; } /// 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 63edd676..1c44b2be 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListOperationsResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListOperationsResponse.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class ListOperationsResponse { - /// - /// The standard List next-page token. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] - public string? NextPageToken { get; set; } - /// /// 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. /// @@ -26,6 +20,12 @@ 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; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class ListOperationsResponse /// /// Initializes a new instance of the class. /// - /// - /// The standard List next-page token. - /// /// /// 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. /// /// /// A list of operations that matches the specified filter in the request. /// + /// + /// The standard List next-page token. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListOperationsResponse( - string? nextPageToken, global::System.Collections.Generic.IList? unreachable, - global::System.Collections.Generic.IList? operations) + global::System.Collections.Generic.IList? operations, + string? nextPageToken) { - this.NextPageToken = nextPageToken; this.Unreachable = unreachable; this.Operations = operations; + 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 800f4e39..fb6d6f43 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 { - /// - /// 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; } + /// + /// Returned permissions. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("permissions")] + public global::System.Collections.Generic.IList? Permissions { 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. /// - /// - /// 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. /// + /// + /// Returned permissions. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListPermissionsResponse( - global::System.Collections.Generic.IList? permissions, - string? nextPageToken) + string? nextPageToken, + global::System.Collections.Generic.IList? permissions) { - this.Permissions = permissions; this.NextPageToken = nextPageToken; + this.Permissions = permissions; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResult.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResult.g.cs index 8befbd8f..926abc0e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResult.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResult.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class LogprobsResult { + /// + /// Length = total number of decoding steps. The chosen candidates may or may not be in top_candidates. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("chosenCandidates")] + public global::System.Collections.Generic.IList? ChosenCandidates { get; set; } + /// /// Sum of log probabilities for all tokens. /// @@ -20,12 +26,6 @@ public sealed partial class LogprobsResult [global::System.Text.Json.Serialization.JsonPropertyName("topCandidates")] public global::System.Collections.Generic.IList? TopCandidates { get; set; } - /// - /// Length = total number of decoding steps. The chosen candidates may or may not be in top_candidates. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("chosenCandidates")] - public global::System.Collections.Generic.IList? ChosenCandidates { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class LogprobsResult /// /// Initializes a new instance of the class. /// + /// + /// Length = total number of decoding steps. The chosen candidates may or may not be in top_candidates. + /// /// /// Sum of log probabilities for all tokens. /// /// /// Length = total number of decoding steps. /// - /// - /// Length = total number of decoding steps. The chosen candidates may or may not be in top_candidates. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public LogprobsResult( + global::System.Collections.Generic.IList? chosenCandidates, float? logProbabilitySum, - global::System.Collections.Generic.IList? topCandidates, - global::System.Collections.Generic.IList? chosenCandidates) + global::System.Collections.Generic.IList? topCandidates) { + this.ChosenCandidates = chosenCandidates; this.LogProbabilitySum = logProbabilitySum; this.TopCandidates = topCandidates; - this.ChosenCandidates = chosenCandidates; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResultCandidate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResultCandidate.g.cs index c4f9fa4f..f52a493c 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 log probability. + /// The candidate’s token id value. /// - [global::System.Text.Json.Serialization.JsonPropertyName("logProbability")] - public float? LogProbability { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("tokenId")] + public int? TokenId { get; set; } /// /// The candidate’s token string value. @@ -21,10 +21,10 @@ public sealed partial class LogprobsResultCandidate public string? Token { get; set; } /// - /// The candidate’s token id value. + /// The candidate's log probability. /// - [global::System.Text.Json.Serialization.JsonPropertyName("tokenId")] - public int? TokenId { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("logProbability")] + public float? LogProbability { 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 log probability. + /// + /// The candidate’s token id value. /// /// /// The candidate’s token string value. /// - /// - /// The candidate’s token id value. + /// + /// The candidate's log probability. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public LogprobsResultCandidate( - float? logProbability, + int? tokenId, string? token, - int? tokenId) + float? logProbability) { - this.LogProbability = logProbability; - this.Token = token; this.TokenId = tokenId; + this.Token = token; + this.LogProbability = logProbability; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Maps.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Maps.g.cs index f67666c3..fb5f551c 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 @@ -8,24 +8,12 @@ namespace Google.Gemini /// public sealed partial class Maps { - /// - /// Text description of the place answer. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("text")] - public string? Text { get; set; } - /// /// The ID of the place, in `places/{place_id}` format. A user can use this ID to look up that place. /// [global::System.Text.Json.Serialization.JsonPropertyName("placeId")] public string? PlaceId { get; set; } - /// - /// Title of the place. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - public string? Title { get; set; } - /// /// Collection of sources that provide answers about the features of a given place in Google Maps. Each PlaceAnswerSources message corresponds to a specific place in Google Maps. The Google Maps tool used these sources in order to answer questions about features of the place (e.g: "does Bar Foo have Wifi" or "is Foo Bar wheelchair accessible?"). Currently we only support review snippets as sources. /// @@ -38,6 +26,18 @@ public sealed partial class Maps [global::System.Text.Json.Serialization.JsonPropertyName("uri")] public string? Uri { get; set; } + /// + /// Title of the place. + /// + [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; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -47,36 +47,36 @@ public sealed partial class Maps /// /// Initializes a new instance of the class. /// - /// - /// Text description of the place answer. - /// /// /// The ID of the place, in `places/{place_id}` format. A user can use this ID to look up that place. /// - /// - /// Title of the place. - /// /// /// 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. /// + /// + /// Title of the place. + /// + /// + /// Text description of the place answer. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Maps( - string? text, string? placeId, - string? title, global::Google.Gemini.PlaceAnswerSources? placeAnswerSources, - string? uri) + string? uri, + string? title, + string? text) { - this.Text = text; this.PlaceId = placeId; - this.Title = title; this.PlaceAnswerSources = placeAnswerSources; this.Uri = uri; + this.Title = title; + this.Text = text; } /// 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 6a90f2cd..d5bff801 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,12 +8,6 @@ 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. /// @@ -21,6 +15,12 @@ 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. /// - /// - /// Number of tokens. - /// /// /// The modality associated with this token count. /// + /// + /// Number of tokens. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ModalityTokenCount( - int? tokenCount, - global::Google.Gemini.ModalityTokenCountModality? modality) + global::Google.Gemini.ModalityTokenCountModality? modality, + int? tokenCount) { - this.TokenCount = tokenCount; this.Modality = modality; + this.TokenCount = tokenCount; } /// 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 6f8b6b2d..5a72279b 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,58 +9,58 @@ namespace Google.Gemini public sealed partial class 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` /// - [global::System.Text.Json.Serialization.JsonPropertyName("topK")] - public int? TopK { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// - /// Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` + /// Maximum number of input tokens allowed for this model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("baseModelId")] - public string? BaseModelId { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("inputTokenLimit")] + public int? InputTokenLimit { get; set; } /// - /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) + /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("version")] - public string? Version { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { 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. + /// Whether the model supports thinking. /// - [global::System.Text.Json.Serialization.JsonPropertyName("topP")] - public float? TopP { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("thinking")] + public bool? Thinking { 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` + /// The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("supportedGenerationMethods")] + public global::System.Collections.Generic.IList? SupportedGenerationMethods { 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 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; } /// - /// The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`. + /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) /// - [global::System.Text.Json.Serialization.JsonPropertyName("supportedGenerationMethods")] - public global::System.Collections.Generic.IList? SupportedGenerationMethods { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("version")] + public string? Version { get; set; } /// - /// A short description of the model. + /// The maximum temperature this model can use. /// - [global::System.Text.Json.Serialization.JsonPropertyName("description")] - public string? Description { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxTemperature")] + public float? MaxTemperature { 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. @@ -69,22 +69,22 @@ public sealed partial class Model public float? Temperature { get; set; } /// - /// Whether the model supports thinking. + /// 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("thinking")] - public bool? Thinking { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topK")] + public int? TopK { get; set; } /// - /// Maximum number of input tokens allowed for this model. + /// Maximum number of output tokens available for this model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("inputTokenLimit")] - public int? InputTokenLimit { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("outputTokenLimit")] + public int? OutputTokenLimit { 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. + /// Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("baseModelId")] + public string? BaseModelId { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -95,26 +95,17 @@ public sealed partial class Model /// /// Initializes a new instance of the class. /// - /// - /// For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. If empty, indicates the model doesn't use top-k sampling, and `top_k` isn't allowed as a generation parameter. - /// - /// - /// Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` - /// - /// - /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) - /// - /// - /// For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model. - /// /// /// 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 output tokens available for this model. + /// + /// Maximum number of input tokens allowed for this model. /// - /// - /// The maximum temperature this model can use. + /// + /// 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. /// /// /// The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`. @@ -122,49 +113,58 @@ public sealed partial class Model /// /// A short description of the model. /// + /// + /// For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model. + /// + /// + /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) + /// + /// + /// The maximum temperature this model can use. + /// /// /// 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. /// - /// - /// Whether the model supports thinking. + /// + /// For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. If empty, indicates the model doesn't use top-k sampling, and `top_k` isn't allowed as a generation parameter. /// - /// - /// Maximum number of input tokens allowed for this model. + /// + /// Maximum number of output tokens available for this 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. + /// + /// Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Model( - int? topK, - string? baseModelId, - string? version, - float? topP, string? name, - int? outputTokenLimit, - float? maxTemperature, + int? inputTokenLimit, + string? displayName, + bool? thinking, global::System.Collections.Generic.IList? supportedGenerationMethods, string? description, + float? topP, + string? version, + float? maxTemperature, float? temperature, - bool? thinking, - int? inputTokenLimit, - string? displayName) + int? topK, + int? outputTokenLimit, + string? baseModelId) { - this.TopK = topK; - this.BaseModelId = baseModelId; - this.Version = version; - this.TopP = topP; this.Name = name; - this.OutputTokenLimit = outputTokenLimit; - this.MaxTemperature = maxTemperature; + this.InputTokenLimit = inputTokenLimit; + this.DisplayName = displayName; + this.Thinking = thinking; this.SupportedGenerationMethods = supportedGenerationMethods; this.Description = description; + this.TopP = topP; + this.Version = version; + this.MaxTemperature = maxTemperature; this.Temperature = temperature; - this.Thinking = thinking; - this.InputTokenLimit = inputTokenLimit; - this.DisplayName = displayName; + this.TopK = topK; + this.OutputTokenLimit = outputTokenLimit; + this.BaseModelId = baseModelId; } /// 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 8706c1ac..5e2194d6 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,16 +9,10 @@ namespace Google.Gemini public sealed partial class Operation { /// - /// If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available. - /// - [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. + /// The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] - public object? Metadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("response")] + public object? Response { get; set; } /// /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. @@ -27,10 +21,16 @@ public sealed partial class Operation public string? Name { get; set; } /// - /// The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. + /// 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("response")] - public object? Response { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] + public object? Metadata { 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). @@ -47,17 +47,17 @@ public sealed partial class Operation /// /// Initializes a new instance of the class. /// - /// - /// If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available. - /// - /// - /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. + /// + /// The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. /// /// /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. /// - /// - /// The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. + /// + /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. + /// + /// + /// 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). @@ -66,16 +66,16 @@ public sealed partial class Operation [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Operation( - bool? done, - object? metadata, - string? name, object? response, + string? name, + object? metadata, + bool? done, global::Google.Gemini.Status? error) { - this.Done = done; - this.Metadata = metadata; - this.Name = name; this.Response = response; + this.Name = name; + this.Metadata = metadata; + this.Done = done; 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 f0bf84ca..df03455e 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 @@ -10,6 +10,13 @@ namespace Google.Gemini /// public sealed partial class Part { + /// + /// Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("videoMetadata")] + [global::System.Obsolete("This property marked as deprecated.")] + public global::Google.Gemini.VideoMetadata? VideoMetadata { get; set; } + /// /// The result output from a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model. This should contain the result of a`FunctionCall` made based on model prediction. /// @@ -23,10 +30,10 @@ public sealed partial class Part public global::Google.Gemini.ExecutableCode? ExecutableCode { get; set; } /// - /// Inline text. + /// Optional. Indicates if the part is thought from the model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("text")] - public string? Text { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("thought")] + public bool? Thought { 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`. @@ -35,28 +42,10 @@ public sealed partial class Part public global::Google.Gemini.ToolResponse? ToolResponse { get; set; } /// - /// A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("toolCall")] - public global::Google.Gemini.ToolCall? ToolCall { get; set; } - - /// - /// Custom metadata associated with the Part. Agents using genai.Part as content representation may need to keep track of the additional information. For example it can be name of a file/source from which the Part originates or a way to multiplex multiple Part streams. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("partMetadata")] - public object? PartMetadata { get; set; } - - /// - /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("codeExecutionResult")] - public global::Google.Gemini.CodeExecutionResult? CodeExecutionResult { get; set; } - - /// - /// Optional. Indicates if the part is thought from the model. + /// Raw media bytes. Text should not be sent as raw bytes, use the 'text' field. /// - [global::System.Text.Json.Serialization.JsonPropertyName("thought")] - public bool? Thought { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("inlineData")] + public global::Google.Gemini.Blob? InlineData { get; set; } /// /// Optional. An opaque signature for the thought so it can be reused in subsequent requests. @@ -64,12 +53,6 @@ public sealed partial class Part [global::System.Text.Json.Serialization.JsonPropertyName("thoughtSignature")] public byte[]? ThoughtSignature { 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; } - /// /// A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values. /// @@ -77,11 +60,10 @@ public sealed partial class Part public global::Google.Gemini.FunctionCall? FunctionCall { get; set; } /// - /// Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content. + /// Inline text. /// - [global::System.Text.Json.Serialization.JsonPropertyName("videoMetadata")] - [global::System.Obsolete("This property marked as deprecated.")] - public global::Google.Gemini.VideoMetadata? VideoMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("text")] + public string? Text { get; set; } /// /// URI based data. @@ -89,6 +71,24 @@ public sealed partial class Part [global::System.Text.Json.Serialization.JsonPropertyName("fileData")] public global::Google.Gemini.FileData? FileData { get; set; } + /// + /// Custom metadata associated with the Part. Agents using genai.Part as content representation may need to keep track of the additional information. For example it can be name of a file/source from which the Part originates or a way to multiplex multiple Part streams. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("partMetadata")] + public object? PartMetadata { get; set; } + + /// + /// A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("toolCall")] + public global::Google.Gemini.ToolCall? ToolCall { get; set; } + + /// + /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("codeExecutionResult")] + public global::Google.Gemini.CodeExecutionResult? CodeExecutionResult { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -104,65 +104,65 @@ public sealed partial class Part /// /// Code generated by the model that is meant to be executed, and the result returned to the model. Only generated when using the `CodeExecution` tool, in which the code will be automatically executed, and a corresponding `CodeExecutionResult` will also be generated. /// - /// - /// Inline text. + /// + /// Optional. Indicates if the part is thought from the model. /// /// /// The output from a server-side `ToolCall` execution. This message contains the results of a tool invocation that was initiated by a `ToolCall` from the model. The client should pass this `ToolResponse` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolCall`. /// - /// - /// 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`. - /// - /// - /// Custom metadata associated with the Part. Agents using genai.Part as content representation may need to keep track of the additional information. For example it can be name of a file/source from which the Part originates or a way to multiplex multiple Part streams. - /// - /// - /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. - /// - /// - /// Optional. Indicates if the part is thought from the model. + /// + /// Raw media bytes. Text should not be sent as raw bytes, use the 'text' field. /// /// /// Optional. An opaque signature for the thought so it can be reused in subsequent requests. /// - /// - /// Raw media bytes. Text should not be sent as raw bytes, use the 'text' field. - /// /// /// A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values. /// + /// + /// Inline text. + /// /// /// URI based data. /// + /// + /// Custom metadata associated with the Part. Agents using genai.Part as content representation may need to keep track of the additional information. For example it can be name of a file/source from which the Part originates or a way to multiplex multiple Part streams. + /// + /// + /// 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`. + /// + /// + /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Part( global::Google.Gemini.FunctionResponse? functionResponse, global::Google.Gemini.ExecutableCode? executableCode, - string? text, - global::Google.Gemini.ToolResponse? toolResponse, - global::Google.Gemini.ToolCall? toolCall, - object? partMetadata, - global::Google.Gemini.CodeExecutionResult? codeExecutionResult, bool? thought, - byte[]? thoughtSignature, + global::Google.Gemini.ToolResponse? toolResponse, global::Google.Gemini.Blob? inlineData, + byte[]? thoughtSignature, global::Google.Gemini.FunctionCall? functionCall, - global::Google.Gemini.FileData? fileData) + string? text, + global::Google.Gemini.FileData? fileData, + object? partMetadata, + global::Google.Gemini.ToolCall? toolCall, + global::Google.Gemini.CodeExecutionResult? codeExecutionResult) { this.FunctionResponse = functionResponse; this.ExecutableCode = executableCode; - this.Text = text; - this.ToolResponse = toolResponse; - this.ToolCall = toolCall; - this.PartMetadata = partMetadata; - this.CodeExecutionResult = codeExecutionResult; this.Thought = thought; - this.ThoughtSignature = thoughtSignature; + this.ToolResponse = toolResponse; this.InlineData = inlineData; + this.ThoughtSignature = thoughtSignature; this.FunctionCall = functionCall; + this.Text = text; this.FileData = fileData; + this.PartMetadata = partMetadata; + this.ToolCall = toolCall; + this.CodeExecutionResult = codeExecutionResult; } /// 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 7f87adba..6749cc78 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,19 @@ namespace Google.Gemini /// public sealed partial class Permission { + /// + /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("emailAddress")] + public string? EmailAddress { get; set; } + + /// + /// Required. The role granted by this permission. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("role")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.PermissionRoleJsonConverter))] + public global::Google.Gemini.PermissionRole? Role { get; set; } + /// /// Optional. Immutable. The type of the grantee. /// @@ -22,19 +35,6 @@ public sealed partial class Permission [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } - /// - /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("emailAddress")] - public string? EmailAddress { get; set; } - - /// - /// Required. The role granted by this permission. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("role")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.PermissionRoleJsonConverter))] - public global::Google.Gemini.PermissionRole? Role { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -44,6 +44,12 @@ public sealed partial class Permission /// /// Initializes a new instance of the class. /// + /// + /// 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 type of the grantee. /// @@ -51,25 +57,19 @@ public sealed partial class Permission /// Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.
/// Included only in responses /// - /// - /// 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. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Permission( - global::Google.Gemini.PermissionGranteeType? granteeType, - string? name, string? emailAddress, - global::Google.Gemini.PermissionRole? role) + global::Google.Gemini.PermissionRole? role, + global::Google.Gemini.PermissionGranteeType? granteeType, + string? name) { - this.GranteeType = granteeType; - this.Name = name; this.EmailAddress = emailAddress; this.Role = role; + this.GranteeType = granteeType; + this.Name = name; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.PromptFeedback.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.PromptFeedback.g.cs index 08e93e4a..fccaca72 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.PromptFeedback.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.PromptFeedback.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class PromptFeedback { + /// + /// Ratings for safety of the prompt. There is at most one rating per category. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("safetyRatings")] + public global::System.Collections.Generic.IList? SafetyRatings { get; set; } + /// /// Optional. If set, the prompt was blocked and no candidates are returned. Rephrase the prompt. /// @@ -15,12 +21,6 @@ public sealed partial class PromptFeedback [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonJsonConverter))] public global::Google.Gemini.PromptFeedbackBlockReason? BlockReason { get; set; } - /// - /// Ratings for safety of the prompt. There is at most one rating per category. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("safetyRatings")] - public global::System.Collections.Generic.IList? SafetyRatings { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,21 +30,21 @@ public sealed partial class PromptFeedback /// /// Initializes a new instance of the class. /// - /// - /// Optional. If set, the prompt was blocked and no candidates are returned. Rephrase the prompt. - /// /// /// Ratings for safety of the prompt. There is at most one rating per category. /// + /// + /// Optional. If set, the prompt was blocked and no candidates are returned. Rephrase the prompt. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public PromptFeedback( - global::Google.Gemini.PromptFeedbackBlockReason? blockReason, - global::System.Collections.Generic.IList? safetyRatings) + global::System.Collections.Generic.IList? safetyRatings, + global::Google.Gemini.PromptFeedbackBlockReason? blockReason) { - this.BlockReason = blockReason; this.SafetyRatings = safetyRatings; + this.BlockReason = blockReason; } /// 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 cb73b58e..fafacf58 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,12 +8,6 @@ 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. /// @@ -26,6 +20,12 @@ 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.ImageResponseFormat? image, + global::Google.Gemini.TextResponseFormat? text) { - 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 10e07f1c..587cc51b 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 { - /// - /// 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; } + /// + /// 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; } + /// /// 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. /// - /// - /// 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). /// + /// + /// 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. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public RetrievalConfig( - global::Google.Gemini.LatLng? latLng, - string? languageCode) + string? languageCode, + global::Google.Gemini.LatLng? latLng) { - this.LatLng = latLng; this.LanguageCode = languageCode; + this.LatLng = latLng; } /// 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 0ac70093..987acdfc 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 @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class RetrievedContext { + /// + /// Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123` + /// + [global::System.Text.Json.Serialization.JsonPropertyName("fileSearchStore")] + public string? FileSearchStore { get; set; } + /// /// Optional. User-provided metadata about the retrieved context. /// @@ -26,18 +32,6 @@ public sealed partial class RetrievedContext [global::System.Text.Json.Serialization.JsonPropertyName("text")] public string? Text { get; set; } - /// - /// Optional. Page number of the retrieved context, if applicable. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("pageNumber")] - public int? PageNumber { get; set; } - - /// - /// Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123` - /// - [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} /// @@ -50,6 +44,12 @@ public sealed partial class RetrievedContext [global::System.Text.Json.Serialization.JsonPropertyName("uri")] public string? Uri { get; set; } + /// + /// Optional. Page number of the retrieved context, if applicable. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("pageNumber")] + public int? PageNumber { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -59,6 +59,9 @@ public sealed partial class RetrievedContext /// /// Initializes a new instance of the class. /// + /// + /// Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123` + /// /// /// Optional. User-provided metadata about the retrieved context. /// @@ -68,37 +71,34 @@ public sealed partial class RetrievedContext /// /// Optional. Text of the chunk. /// - /// - /// Optional. Page number of the retrieved context, if applicable. - /// - /// - /// 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. URI reference of the semantic retrieval document. /// + /// + /// Optional. Page number of the retrieved context, if applicable. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public RetrievedContext( + string? fileSearchStore, global::System.Collections.Generic.IList? customMetadata, string? title, string? text, - int? pageNumber, - string? fileSearchStore, string? mediaId, - string? uri) + string? uri, + int? pageNumber) { + this.FileSearchStore = fileSearchStore; this.CustomMetadata = customMetadata; this.Title = title; this.Text = text; - this.PageNumber = pageNumber; - this.FileSearchStore = fileSearchStore; this.MediaId = mediaId; this.Uri = uri; + this.PageNumber = pageNumber; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ReviewSnippet.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ReviewSnippet.g.cs index f4ea2ba7..19c4fb32 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ReviewSnippet.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ReviewSnippet.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class ReviewSnippet { - /// - /// Title of the review. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - public string? Title { get; set; } - /// /// The ID of the review snippet. /// @@ -26,6 +20,12 @@ public sealed partial class ReviewSnippet [global::System.Text.Json.Serialization.JsonPropertyName("googleMapsUri")] public string? GoogleMapsUri { get; set; } + /// + /// Title of the review. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("title")] + public string? Title { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class ReviewSnippet /// /// Initializes a new instance of the class. /// - /// - /// Title of the review. - /// /// /// The ID of the review snippet. /// /// /// A link that corresponds to the user review on Google Maps. /// + /// + /// Title of the review. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ReviewSnippet( - string? title, string? reviewId, - string? googleMapsUri) + string? googleMapsUri, + string? title) { - this.Title = title; this.ReviewId = reviewId; this.GoogleMapsUri = googleMapsUri; + this.Title = title; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SafetySetting.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SafetySetting.g.cs index 1c981d0c..8a3dac69 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SafetySetting.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SafetySetting.g.cs @@ -8,13 +8,6 @@ namespace Google.Gemini /// public sealed partial class SafetySetting { - /// - /// Required. The category for this setting. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("category")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryJsonConverter))] - public global::Google.Gemini.SafetySettingCategory? Category { get; set; } - /// /// Required. Controls the probability threshold at which harm is blocked. /// @@ -22,6 +15,13 @@ public sealed partial class SafetySetting [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdJsonConverter))] public global::Google.Gemini.SafetySettingThreshold? Threshold { get; set; } + /// + /// Required. The category for this setting. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("category")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryJsonConverter))] + public global::Google.Gemini.SafetySettingCategory? Category { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -31,21 +31,21 @@ public sealed partial class SafetySetting /// /// Initializes a new instance of the class. /// - /// - /// Required. The category for this setting. - /// /// /// Required. Controls the probability threshold at which harm is blocked. /// + /// + /// Required. The category for this setting. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public SafetySetting( - global::Google.Gemini.SafetySettingCategory? category, - global::Google.Gemini.SafetySettingThreshold? threshold) + global::Google.Gemini.SafetySettingThreshold? threshold, + global::Google.Gemini.SafetySettingCategory? category) { - this.Category = category; this.Threshold = threshold; + this.Category = category; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Schema.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Schema.g.cs index aa945dc5..b1c611b3 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,70 +9,64 @@ namespace Google.Gemini public sealed partial class Schema { /// - /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING - /// - [global::System.Text.Json.Serialization.JsonPropertyName("minLength")] - public string? MinLength { get; set; } - - /// - /// Optional. Minimum number of the properties for 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). /// - [global::System.Text.Json.Serialization.JsonPropertyName("minProperties")] - public string? MinProperties { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("items")] + public global::Google.Gemini.Schema? Items { get; set; } /// - /// Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown. + /// Optional. Maximum length of the Type.STRING /// - [global::System.Text.Json.Serialization.JsonPropertyName("description")] - public string? Description { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxLength")] + public string? MaxLength { get; set; } /// - /// Optional. Indicates if the value may be null. + /// Optional. Maximum number of the properties for Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("nullable")] - public bool? Nullable { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxProperties")] + public string? MaxProperties { get; set; } /// - /// Optional. Pattern of the Type.STRING to restrict a string to a regular expression. + /// Optional. The title of the schema. /// - [global::System.Text.Json.Serialization.JsonPropertyName("pattern")] - public string? Pattern { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("title")] + public string? Title { get; set; } /// - /// Optional. Required properties of Type.OBJECT. + /// Optional. Maximum number of the elements for Type.ARRAY. /// - [global::System.Text.Json.Serialization.JsonPropertyName("required")] - public global::System.Collections.Generic.IList? Required { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxItems")] + public string? MaxItems { get; set; } /// - /// Optional. Minimum number of the elements for Type.ARRAY. + /// Optional. Maximum value of the Type.INTEGER and Type.NUMBER /// - [global::System.Text.Json.Serialization.JsonPropertyName("minItems")] - public string? MinItems { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maximum")] + public double? Maximum { 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. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING /// - [global::System.Text.Json.Serialization.JsonPropertyName("default")] - public object? Default { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minLength")] + public string? MinLength { 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. Properties of Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("enum")] - public global::System.Collections.Generic.IList? Enum { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("properties")] + public global::System.Collections.Generic.Dictionary? Properties { get; set; } /// - /// Optional. Maximum value of the Type.INTEGER and Type.NUMBER + /// Optional. Minimum number of the properties for Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maximum")] - public double? Maximum { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minProperties")] + public string? MinProperties { get; set; } /// - /// Optional. The title of the schema. + /// Optional. Pattern of the Type.STRING to restrict a string to a regular expression. /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - public string? Title { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("pattern")] + public string? Pattern { get; set; } /// /// Optional. The value should be validated against any (one or more) of the subschemas in the list. @@ -81,22 +75,23 @@ public sealed partial class Schema public global::System.Collections.Generic.IList? AnyOf { get; set; } /// - /// Optional. Maximum length of the Type.STRING + /// Optional. Default value of the field. Per JSON Schema, this field is intended for documentation generators and doesn't affect validation. Thus it's included here and ignored so that developers who send schemas with a `default` field don't get unknown-field errors. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxLength")] - public string? MaxLength { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("default")] + public object? Default { get; set; } /// - /// Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality. + /// Optional. Required properties of Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("format")] - public string? Format { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("required")] + public global::System.Collections.Generic.IList? Required { get; set; } /// - /// Optional. Maximum number of the properties for Type.OBJECT. + /// Required. Data type. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxProperties")] - public string? MaxProperties { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("type")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.SchemaTypeJsonConverter))] + public global::Google.Gemini.SchemaType? Type { get; set; } /// /// Optional. Example of the object. Will only populated when the object is the root. @@ -117,29 +112,34 @@ public sealed partial class Schema public double? Minimum { 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 format of the data. Any value is allowed, but most do not trigger any special functionality. /// - [global::System.Text.Json.Serialization.JsonPropertyName("items")] - public global::Google.Gemini.Schema? Items { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("format")] + public string? Format { get; set; } /// - /// Optional. Maximum number of the elements for Type.ARRAY. + /// Optional. Indicates if the value may be null. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxItems")] - public string? MaxItems { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("nullable")] + public bool? Nullable { get; set; } /// - /// Optional. Properties of Type.OBJECT. + /// Optional. Minimum number of the elements for Type.ARRAY. /// - [global::System.Text.Json.Serialization.JsonPropertyName("properties")] - public global::System.Collections.Generic.Dictionary? Properties { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minItems")] + public string? MinItems { get; set; } /// - /// Required. Data type. + /// 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("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("description")] + public string? Description { 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"]} + /// + [global::System.Text.Json.Serialization.JsonPropertyName("enum")] + public global::System.Collections.Generic.IList? Enum { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -150,50 +150,47 @@ public sealed partial class Schema /// /// Initializes a new instance of the class. /// - /// - /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING - /// - /// - /// Optional. Minimum number of the properties for 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. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown. + /// + /// Optional. Maximum length of the Type.STRING /// - /// - /// Optional. Indicates if the value may be null. + /// + /// Optional. Maximum number of the properties for Type.OBJECT. /// - /// - /// Optional. Pattern of the Type.STRING to restrict a string to a regular expression. + /// + /// Optional. The title of the schema. /// - /// - /// Optional. Required properties of Type.OBJECT. + /// + /// Optional. Maximum number of the elements for Type.ARRAY. /// - /// - /// Optional. Minimum number of the elements for Type.ARRAY. + /// + /// Optional. Maximum value of the Type.INTEGER and Type.NUMBER /// - /// - /// 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. 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. Properties of Type.OBJECT. /// - /// - /// Optional. Maximum value of the Type.INTEGER and Type.NUMBER + /// + /// Optional. Minimum number of the properties for Type.OBJECT. /// - /// - /// Optional. The title of the schema. + /// + /// Optional. Pattern of the Type.STRING to restrict a string to a regular expression. /// /// /// Optional. The value should be validated against any (one or more) of the subschemas in the list. /// - /// - /// Optional. Maximum length of the Type.STRING + /// + /// Optional. Default value of the field. Per JSON Schema, this field is intended for documentation generators and doesn't affect validation. Thus it's included here and ignored so that developers who send schemas with a `default` field don't get unknown-field errors. /// - /// - /// Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality. + /// + /// Optional. Required properties of Type.OBJECT. /// - /// - /// Optional. Maximum number of the properties for Type.OBJECT. + /// + /// Required. Data type. /// /// /// Optional. Example of the object. Will only populated when the object is the root. @@ -204,67 +201,70 @@ public sealed partial class Schema /// /// Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER /// - /// - /// 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 format of the data. Any value is allowed, but most do not trigger any special functionality. /// - /// - /// Optional. Maximum number of the elements for Type.ARRAY. + /// + /// Optional. Indicates if the value may be null. /// - /// - /// Optional. Properties of Type.OBJECT. + /// + /// Optional. Minimum number of the elements for Type.ARRAY. /// - /// - /// Required. Data type. + /// + /// Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown. + /// + /// + /// Optional. Possible values of the element of Type.STRING with enum format. For example we can define an Enum Direction as : {type:STRING, format:enum, enum:["EAST", NORTH", "SOUTH", "WEST"]} /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Schema( + global::Google.Gemini.Schema? items, + string? maxLength, + string? maxProperties, + string? title, + string? maxItems, + double? maximum, string? minLength, + global::System.Collections.Generic.Dictionary? properties, string? minProperties, - string? description, - bool? nullable, string? pattern, - global::System.Collections.Generic.IList? required, - string? minItems, - object? @default, - global::System.Collections.Generic.IList? @enum, - double? maximum, - string? title, global::System.Collections.Generic.IList? anyOf, - string? maxLength, - string? format, - string? maxProperties, + object? @default, + global::System.Collections.Generic.IList? required, + global::Google.Gemini.SchemaType? type, object? example, global::System.Collections.Generic.IList? propertyOrdering, double? minimum, - global::Google.Gemini.Schema? items, - string? maxItems, - global::System.Collections.Generic.Dictionary? properties, - global::Google.Gemini.SchemaType? type) + string? format, + bool? nullable, + string? minItems, + string? description, + global::System.Collections.Generic.IList? @enum) { + this.Items = items; + this.MaxLength = maxLength; + this.MaxProperties = maxProperties; + this.Title = title; + this.MaxItems = maxItems; + this.Maximum = maximum; this.MinLength = minLength; + this.Properties = properties; this.MinProperties = minProperties; - this.Description = description; - this.Nullable = nullable; this.Pattern = pattern; - this.Required = required; - this.MinItems = minItems; - this.Default = @default; - this.Enum = @enum; - this.Maximum = maximum; - this.Title = title; this.AnyOf = anyOf; - this.MaxLength = maxLength; - this.Format = format; - this.MaxProperties = maxProperties; + this.Default = @default; + this.Required = required; + this.Type = type; this.Example = example; this.PropertyOrdering = propertyOrdering; this.Minimum = minimum; - this.Items = items; - this.MaxItems = maxItems; - this.Properties = properties; - this.Type = type; + this.Format = format; + this.Nullable = nullable; + this.MinItems = minItems; + this.Description = description; + this.Enum = @enum; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeakerVoiceConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeakerVoiceConfig.g.cs index f9754c22..0a6833b4 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeakerVoiceConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeakerVoiceConfig.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class SpeakerVoiceConfig { - /// - /// The configuration for the voice to use. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("voiceConfig")] - public global::Google.Gemini.VoiceConfig? VoiceConfig { get; set; } - /// /// Required. The name of the speaker to use. Should be the same as in the prompt. /// [global::System.Text.Json.Serialization.JsonPropertyName("speaker")] public string? Speaker { get; set; } + /// + /// The configuration for the voice to use. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("voiceConfig")] + public global::Google.Gemini.VoiceConfig? VoiceConfig { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class SpeakerVoiceConfig /// /// Initializes a new instance of the class. /// - /// - /// The configuration for the voice to use. - /// /// /// Required. The name of the speaker to use. Should be the same as in the prompt. /// + /// + /// The configuration for the voice to use. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public SpeakerVoiceConfig( - global::Google.Gemini.VoiceConfig? voiceConfig, - string? speaker) + string? speaker, + global::Google.Gemini.VoiceConfig? voiceConfig) { - this.VoiceConfig = voiceConfig; this.Speaker = speaker; + this.VoiceConfig = voiceConfig; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Status.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Status.g.cs index 7db73b4f..d1de5ffc 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 @@ -14,18 +14,18 @@ public sealed partial class Status [global::System.Text.Json.Serialization.JsonPropertyName("message")] public string? Message { get; set; } - /// - /// The status code, which should be an enum value of google.rpc.Code. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("code")] - public int? Code { get; set; } - /// /// A 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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("code")] + public int? Code { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -38,23 +38,23 @@ public sealed partial class Status /// /// A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client. /// - /// - /// The status code, which should be an enum value of google.rpc.Code. - /// /// /// 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. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Status( string? message, - int? code, - global::System.Collections.Generic.IList? details) + global::System.Collections.Generic.IList? details, + int? code) { this.Message = message; - this.Code = code; this.Details = details; + this.Code = code; } /// 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 8a096b80..c519c72e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.StreamableHttpTransport.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.StreamableHttpTransport.g.cs @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class StreamableHttpTransport { /// - /// The full URL for the MCPServer endpoint. Example: "https://api.example.com/mcp" + /// HTTP timeout for regular operations. /// - [global::System.Text.Json.Serialization.JsonPropertyName("url")] - public string? Url { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("timeout")] + public string? Timeout { get; set; } /// /// Whether to close the client session when the transport closes. @@ -21,22 +21,22 @@ public sealed partial class StreamableHttpTransport public bool? TerminateOnClose { get; set; } /// - /// Optional: Fields for authentication headers, timeouts, etc., if needed. + /// Timeout for SSE read operations. /// - [global::System.Text.Json.Serialization.JsonPropertyName("headers")] - public global::System.Collections.Generic.Dictionary? Headers { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sseReadTimeout")] + public string? SseReadTimeout { get; set; } /// - /// HTTP timeout for regular operations. + /// Optional: Fields for authentication headers, timeouts, etc., if needed. /// - [global::System.Text.Json.Serialization.JsonPropertyName("timeout")] - public string? Timeout { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("headers")] + public global::System.Collections.Generic.Dictionary? Headers { get; set; } /// - /// Timeout for SSE read operations. + /// The full URL for the MCPServer endpoint. Example: "https://api.example.com/mcp" /// - [global::System.Text.Json.Serialization.JsonPropertyName("sseReadTimeout")] - public string? SseReadTimeout { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("url")] + public string? Url { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -47,36 +47,36 @@ public sealed partial class StreamableHttpTransport /// /// Initializes a new instance of the class. /// - /// - /// The full URL for the MCPServer endpoint. Example: "https://api.example.com/mcp" + /// + /// HTTP timeout for regular operations. /// /// /// Whether to close the client session when the transport closes. /// + /// + /// Timeout for SSE read operations. + /// /// /// Optional: Fields for authentication headers, timeouts, etc., if needed. /// - /// - /// HTTP timeout for regular operations. - /// - /// - /// Timeout for SSE read operations. + /// + /// The full URL for the MCPServer endpoint. Example: "https://api.example.com/mcp" /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public StreamableHttpTransport( - string? url, + string? timeout, bool? terminateOnClose, + string? sseReadTimeout, global::System.Collections.Generic.Dictionary? headers, - string? timeout, - string? sseReadTimeout) + string? url) { - this.Url = url; - this.TerminateOnClose = terminateOnClose; - this.Headers = headers; this.Timeout = timeout; + this.TerminateOnClose = terminateOnClose; this.SseReadTimeout = sseReadTimeout; + this.Headers = headers; + this.Url = url; } /// 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 096015d5..595773de 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,16 +9,22 @@ namespace Google.Gemini public sealed partial class Tool { /// - /// The GoogleMaps Tool that provides geospatial context for the user's query. + /// Tool to retrieve public web data for grounding, powered by Google. /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleMaps")] - public global::Google.Gemini.GoogleMaps? GoogleMaps { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("googleSearchRetrieval")] + public global::Google.Gemini.GoogleSearchRetrieval? GoogleSearchRetrieval { get; set; } /// - /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. + /// Tool that executes code generated by the model, and automatically returns the result to the model. See also `ExecutableCode` and `CodeExecutionResult` which are only generated when using this tool. /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleSearch")] - public global::Google.Gemini.GoogleSearch? GoogleSearch { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("codeExecution")] + public global::Google.Gemini.CodeExecution? CodeExecution { get; set; } + + /// + /// Tool to support URL context retrieval. + /// + [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. @@ -33,34 +39,28 @@ public sealed partial class Tool public global::System.Collections.Generic.IList? FunctionDeclarations { get; set; } /// - /// Computer Use tool type. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("computerUse")] - public global::Google.Gemini.ComputerUse? ComputerUse { get; set; } - - /// - /// Tool to retrieve public web data for grounding, powered by Google. + /// Optional. MCP Servers to connect to. /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleSearchRetrieval")] - public global::Google.Gemini.GoogleSearchRetrieval? GoogleSearchRetrieval { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("mcpServers")] + public global::System.Collections.Generic.IList? McpServers { 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. + /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. /// - [global::System.Text.Json.Serialization.JsonPropertyName("codeExecution")] - public global::Google.Gemini.CodeExecution? CodeExecution { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("googleSearch")] + public global::Google.Gemini.GoogleSearch? GoogleSearch { get; set; } /// - /// Tool to support URL context retrieval. + /// The GoogleMaps Tool that provides geospatial context for the user's query. /// - [global::System.Text.Json.Serialization.JsonPropertyName("urlContext")] - public global::Google.Gemini.UrlContext? UrlContext { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("googleMaps")] + public global::Google.Gemini.GoogleMaps? GoogleMaps { get; set; } /// - /// Optional. MCP Servers to connect to. + /// Computer Use tool type. /// - [global::System.Text.Json.Serialization.JsonPropertyName("mcpServers")] - public global::System.Collections.Generic.IList? McpServers { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("computerUse")] + public global::Google.Gemini.ComputerUse? ComputerUse { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -71,21 +71,6 @@ public sealed partial class Tool /// /// Initializes a new instance of the class. /// - /// - /// The GoogleMaps Tool that provides geospatial context for the user's query. - /// - /// - /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. - /// - /// - /// 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. - /// - /// - /// Computer Use tool type. - /// /// /// Tool to retrieve public web data for grounding, powered by Google. /// @@ -95,32 +80,47 @@ public sealed partial class Tool /// /// Tool to support URL context retrieval. /// + /// + /// The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API. + /// + /// + /// Optional. 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. + /// /// /// Optional. MCP Servers to connect to. /// + /// + /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. + /// + /// + /// The GoogleMaps Tool that provides geospatial context for the user's query. + /// + /// + /// Computer Use tool type. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Tool( - global::Google.Gemini.GoogleMaps? googleMaps, - global::Google.Gemini.GoogleSearch? googleSearch, - global::Google.Gemini.FileSearch? fileSearch, - global::System.Collections.Generic.IList? functionDeclarations, - global::Google.Gemini.ComputerUse? computerUse, global::Google.Gemini.GoogleSearchRetrieval? googleSearchRetrieval, global::Google.Gemini.CodeExecution? codeExecution, global::Google.Gemini.UrlContext? urlContext, - global::System.Collections.Generic.IList? mcpServers) + global::Google.Gemini.FileSearch? fileSearch, + global::System.Collections.Generic.IList? functionDeclarations, + global::System.Collections.Generic.IList? mcpServers, + global::Google.Gemini.GoogleSearch? googleSearch, + global::Google.Gemini.GoogleMaps? googleMaps, + global::Google.Gemini.ComputerUse? computerUse) { - this.GoogleMaps = googleMaps; - this.GoogleSearch = googleSearch; - this.FileSearch = fileSearch; - this.FunctionDeclarations = functionDeclarations; - this.ComputerUse = computerUse; this.GoogleSearchRetrieval = googleSearchRetrieval; this.CodeExecution = codeExecution; this.UrlContext = urlContext; + this.FileSearch = fileSearch; + this.FunctionDeclarations = functionDeclarations; this.McpServers = mcpServers; + this.GoogleSearch = googleSearch; + this.GoogleMaps = googleMaps; + this.ComputerUse = computerUse; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolCall.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolCall.g.cs index b0e4cb95..5cbd66dc 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolCall.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolCall.g.cs @@ -14,12 +14,6 @@ public sealed partial class ToolCall [global::System.Text.Json.Serialization.JsonPropertyName("id")] public string? Id { get; set; } - /// - /// Optional. The tool call arguments. Example: {"arg1" : "value1", "arg2" : "value2" , ...} - /// - [global::System.Text.Json.Serialization.JsonPropertyName("args")] - public object? Args { get; set; } - /// /// Required. The type of tool that was called. /// @@ -27,6 +21,12 @@ public sealed partial class ToolCall [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeJsonConverter))] public global::Google.Gemini.ToolCallToolType? ToolType { get; set; } + /// + /// Optional. The tool call arguments. Example: {"arg1" : "value1", "arg2" : "value2" , ...} + /// + [global::System.Text.Json.Serialization.JsonPropertyName("args")] + public object? Args { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -39,23 +39,23 @@ public sealed partial class ToolCall /// /// Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`. /// - /// - /// Optional. The tool call arguments. Example: {"arg1" : "value1", "arg2" : "value2" , ...} - /// /// /// Required. The type of tool that was called. /// + /// + /// Optional. The tool call arguments. Example: {"arg1" : "value1", "arg2" : "value2" , ...} + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ToolCall( string? id, - object? args, - global::Google.Gemini.ToolCallToolType? toolType) + global::Google.Gemini.ToolCallToolType? toolType, + object? args) { this.Id = id; - this.Args = args; this.ToolType = toolType; + this.Args = args; } /// 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 e9a35041..1abb4355 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolConfig.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class ToolConfig { - /// - /// 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. /// @@ -26,6 +20,12 @@ public sealed partial class ToolConfig [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; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class ToolConfig /// /// Initializes a new instance of the class. /// - /// - /// 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. /// /// /// Configuration for specifying function calling behavior. /// + /// + /// Retrieval config. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ToolConfig( - global::Google.Gemini.RetrievalConfig? retrievalConfig, bool? includeServerSideToolInvocations, - global::Google.Gemini.FunctionCallingConfig? functionCallingConfig) + global::Google.Gemini.FunctionCallingConfig? functionCallingConfig, + global::Google.Gemini.RetrievalConfig? retrievalConfig) { - this.RetrievalConfig = retrievalConfig; this.IncludeServerSideToolInvocations = includeServerSideToolInvocations; this.FunctionCallingConfig = functionCallingConfig; + this.RetrievalConfig = retrievalConfig; } /// 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 b8dd8e3f..706bb21c 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,87 +9,87 @@ namespace Google.Gemini public sealed partial class TunedModel { /// - /// 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 state of the tuned model.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] - public float? Temperature { 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; } /// - /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("tuningTask")] + public global::Google.Gemini.TuningTask? TuningTask { get; set; } /// - /// Output only. The timestamp when this model was updated.
- /// Included only in responses + /// 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("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topK")] + public int? TopK { get; set; } /// - /// Optional. A short description of this model. + /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` /// - [global::System.Text.Json.Serialization.JsonPropertyName("description")] - public string? Description { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("baseModel")] + public string? BaseModel { get; set; } /// - /// Output only. The state of the tuned model.
+ /// Output only. The timestamp when this model was updated.
/// 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("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`
- /// Included only in responses + /// Optional. List of project numbers that have read access to the tuned model. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("readerProjectNumbers")] + public global::System.Collections.Generic.IList? ReaderProjectNumbers { get; set; } /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// Tuned model as a source for training a new model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("baseModel")] - public string? BaseModel { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("tunedModelSource")] + public global::Google.Gemini.TunedModelSource? TunedModelSource { get; set; } /// - /// 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. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topP")] + public float? TopP { get; set; } /// - /// Tuning tasks that create tuned models. + /// Optional. A short description of this model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("tuningTask")] - public global::Google.Gemini.TuningTask? TuningTask { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("description")] + public string? Description { get; set; } /// - /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. + /// Optional. 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("topP")] - public float? TopP { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] + public float? Temperature { get; set; } /// - /// Tuned model as a source for training a new 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("tunedModelSource")] - public global::Google.Gemini.TunedModelSource? TunedModelSource { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { 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. + /// Output only. The timestamp when this model was created.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("topK")] - public int? TopK { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } /// - /// Optional. List of project numbers that have read access to the tuned model. + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// - [global::System.Text.Json.Serialization.JsonPropertyName("readerProjectNumbers")] - public global::System.Collections.Generic.IList? ReaderProjectNumbers { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -100,80 +100,80 @@ public sealed partial class TunedModel /// /// Initializes a new instance of the class. /// - /// - /// Optional. 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 state of the tuned model.
+ /// Included only in responses /// - /// - /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. + /// + /// 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. + /// + /// + /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` /// /// /// Output only. The timestamp when this model was updated.
/// Included only in responses /// + /// + /// Optional. List of project numbers that have read access to the tuned model. + /// + /// + /// Tuned model as a source for training a new model. + /// + /// + /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. + /// /// /// Optional. A short description of this model. /// - /// - /// Output only. The state of the tuned model.
- /// Included only in responses + /// + /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// /// /// Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`
/// Included only in responses /// - /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` - /// /// /// Output only. The timestamp when this model was created.
/// Included only in responses /// - /// - /// Tuning tasks that create tuned models. - /// - /// - /// 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. - /// - /// - /// Tuned model as a source for training a new model. - /// - /// - /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. - /// - /// - /// Optional. List of project numbers that have read access to the tuned model. + /// + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public TunedModel( - float? temperature, - string? displayName, + global::Google.Gemini.TunedModelState? state, + global::Google.Gemini.TuningTask? tuningTask, + int? topK, + string? baseModel, string? updateTime, + global::System.Collections.Generic.IList? readerProjectNumbers, + global::Google.Gemini.TunedModelSource? tunedModelSource, + float? topP, string? description, - global::Google.Gemini.TunedModelState? state, + float? temperature, string? name, - string? baseModel, string? createTime, - global::Google.Gemini.TuningTask? tuningTask, - float? topP, - global::Google.Gemini.TunedModelSource? tunedModelSource, - int? topK, - global::System.Collections.Generic.IList? readerProjectNumbers) + string? displayName) { - this.Temperature = temperature; - this.DisplayName = displayName; - this.UpdateTime = updateTime; - this.Description = description; this.State = state; - this.Name = name; - this.BaseModel = baseModel; - this.CreateTime = createTime; this.TuningTask = tuningTask; - this.TopP = topP; - this.TunedModelSource = tunedModelSource; this.TopK = topK; + this.BaseModel = baseModel; + this.UpdateTime = updateTime; this.ReaderProjectNumbers = readerProjectNumbers; + this.TunedModelSource = tunedModelSource; + this.TopP = topP; + this.Description = description; + this.Temperature = temperature; + this.Name = name; + this.CreateTime = createTime; + this.DisplayName = displayName; } /// 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 ebe79083..5c5e2375 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,32 +9,32 @@ namespace Google.Gemini public sealed partial class TuningSnapshot { /// - /// 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 timestamp when this metric was computed.
+ /// Output only. The tuning step.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("computeTime")] - public string? ComputeTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("step")] + public int? Step { get; set; } /// - /// Output only. The tuning step.
+ /// Output only. The epoch this step was part of.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("step")] - public int? Step { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("epoch")] + public int? Epoch { 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 epoch this step was part of.
- /// Included only in responses - /// - /// - /// Output only. The timestamp when this metric was computed.
+ /// + /// 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 epoch this step was part of.
+ /// Included only in responses + /// + /// + /// 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( - int? epoch, - string? computeTime, + float? meanLoss, int? step, - float? meanLoss) + int? epoch, + string? computeTime) { + this.MeanLoss = meanLoss; + this.Step = step; this.Epoch = epoch; this.ComputeTime = computeTime; - this.Step = step; - this.MeanLoss = meanLoss; } /// 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 54053061..b5b0bd37 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 @@ -8,20 +8,6 @@ namespace Google.Gemini /// public sealed partial class TuningTask { - /// - /// Output only. Metrics collected during tuning.
- /// Included only in responses - ///
- [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.
- /// Included only in responses - ///
- [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 @@ -41,6 +27,20 @@ public sealed partial class TuningTask [global::System.Text.Json.Serialization.JsonPropertyName("hyperparameters")] public global::Google.Gemini.Hyperparameters? Hyperparameters { get; set; } + /// + /// Output only. The timestamp when tuning this model completed.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("completeTime")] + public string? CompleteTime { get; set; } + + /// + /// Output only. Metrics collected during tuning.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("snapshots")] + public global::System.Collections.Generic.IList? Snapshots { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -50,14 +50,6 @@ public sealed partial class TuningTask /// /// Initializes a new instance of the class. /// - /// - /// 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 @@ -68,21 +60,29 @@ public sealed partial class TuningTask /// /// Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance /// + /// + /// Output only. The timestamp when tuning this model completed.
+ /// Included only in responses + /// + /// + /// Output only. Metrics collected during tuning.
+ /// Included only in responses + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public TuningTask( - global::System.Collections.Generic.IList? snapshots, - string? completeTime, string? startTime, global::Google.Gemini.Dataset? trainingData, - global::Google.Gemini.Hyperparameters? hyperparameters) + global::Google.Gemini.Hyperparameters? hyperparameters, + string? completeTime, + global::System.Collections.Generic.IList? snapshots) { - this.Snapshots = snapshots; - this.CompleteTime = completeTime; this.StartTime = startTime; this.TrainingData = trainingData; this.Hyperparameters = hyperparameters; + this.CompleteTime = completeTime; + this.Snapshots = snapshots; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UploadToFileSearchStoreRequest.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UploadToFileSearchStoreRequest.g.cs index d597ca58..2e77d4e4 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UploadToFileSearchStoreRequest.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UploadToFileSearchStoreRequest.g.cs @@ -14,18 +14,18 @@ public sealed partial class UploadToFileSearchStoreRequest [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] public string? DisplayName { get; set; } - /// - /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto - /// - [global::System.Text.Json.Serialization.JsonPropertyName("chunkingConfig")] - public global::Google.Gemini.ChunkingConfig? ChunkingConfig { get; set; } - /// /// Custom metadata to be associated with the data. /// [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] public global::System.Collections.Generic.IList? CustomMetadata { get; set; } + /// + /// 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; } + /// /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. /// @@ -44,12 +44,12 @@ public sealed partial class UploadToFileSearchStoreRequest /// /// Optional. Display name of the created document. /// - /// - /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto - /// /// /// Custom metadata to be associated with the data. /// + /// + /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto + /// /// /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. /// @@ -58,13 +58,13 @@ public sealed partial class UploadToFileSearchStoreRequest #endif public UploadToFileSearchStoreRequest( string? displayName, - global::Google.Gemini.ChunkingConfig? chunkingConfig, global::System.Collections.Generic.IList? customMetadata, + global::Google.Gemini.ChunkingConfig? chunkingConfig, string? mimeType) { this.DisplayName = displayName; - this.ChunkingConfig = chunkingConfig; this.CustomMetadata = customMetadata; + this.ChunkingConfig = chunkingConfig; this.MimeType = mimeType; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UrlMetadata.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UrlMetadata.g.cs index 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 01b10262..b1868692 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,45 +9,37 @@ 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; } - - /// - /// Output only. Number of tokens present in tool-use prompt(s).
+ /// Output only. List of modalities that were processed 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("promptTokensDetails")] + public global::System.Collections.Generic.IList? PromptTokensDetails { 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 of the cached content in the request input.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("promptTokenCount")] - public int? PromptTokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("cacheTokensDetails")] + public global::System.Collections.Generic.IList? CacheTokensDetails { get; set; } /// - /// Output only. Service tier of the request.
- /// Included only in responses + /// Total token count for the generation request (prompt + thoughts + response candidates). ///
- [global::System.Text.Json.Serialization.JsonPropertyName("serviceTier")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierJsonConverter))] - public global::Google.Gemini.UsageMetadataServiceTier? ServiceTier { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("totalTokenCount")] + public int? TotalTokenCount { get; set; } /// - /// Output only. Number of tokens of thoughts for thinking models.
+ /// Output only. List of modalities that were processed for tool-use request inputs.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("thoughtsTokenCount")] - public int? ThoughtsTokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("toolUsePromptTokensDetails")] + public global::System.Collections.Generic.IList? ToolUsePromptTokensDetails { get; set; } /// - /// 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. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("cacheTokensDetails")] - public global::System.Collections.Generic.IList? CacheTokensDetails { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokenCount")] + public int? CandidatesTokenCount { get; set; } /// /// Number of tokens in the cached part of the prompt (the cached content) @@ -56,31 +48,39 @@ public sealed partial class UsageMetadata public int? CachedContentTokenCount { get; set; } /// - /// 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 ///
- [global::System.Text.Json.Serialization.JsonPropertyName("totalTokenCount")] - public int? TotalTokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokensDetails")] + public global::System.Collections.Generic.IList? CandidatesTokensDetails { get; set; } /// - /// Output only. List of modalities that were processed in the request input.
+ /// Number of tokens in the prompt. When `cached_content` is set, this is still the total effective prompt size meaning this includes the number of tokens in the cached content. + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("promptTokenCount")] + public int? PromptTokenCount { get; set; } + + /// + /// Output only. Number of tokens present in tool-use prompt(s).
/// 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("toolUsePromptTokenCount")] + public int? ToolUsePromptTokenCount { get; set; } /// - /// Output only. List of modalities that were processed for tool-use request inputs.
+ /// Output only. Service tier of the request.
/// 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("serviceTier")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierJsonConverter))] + public global::Google.Gemini.UsageMetadataServiceTier? ServiceTier { get; set; } /// - /// Output only. List of modalities that were returned in the response.
+ /// Output only. Number of tokens of thoughts for thinking models.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokensDetails")] - public global::System.Collections.Generic.IList? CandidatesTokensDetails { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("thoughtsTokenCount")] + public int? ThoughtsTokenCount { 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. - /// - /// - /// Output only. Number of tokens present in tool-use prompt(s).
- /// 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. Service tier of the request.
- /// Included only in responses - /// - /// - /// Output only. Number of tokens of thoughts for thinking models.
+ /// + /// Output only. List of modalities that were processed in the request input.
/// Included only in responses /// /// /// Output only. List of modalities of the cached content in the request input.
/// Included only in responses /// - /// - /// Number of tokens in the cached part of the prompt (the cached content) - /// /// /// Total token count for the generation request (prompt + thoughts + response candidates). /// - /// - /// Output only. List of modalities that were processed in the request input.
- /// Included only in responses - /// /// /// Output only. List of modalities that were processed for tool-use request inputs.
/// Included only in responses /// + /// + /// Total number of tokens across all the generated response candidates. + /// + /// + /// Number of tokens in the cached part of the prompt (the cached content) + /// /// /// 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. Number of tokens present in tool-use prompt(s).
+ /// Included only in responses + /// + /// + /// 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 + /// /// /// 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? toolUsePromptTokenCount, - int? promptTokenCount, - global::Google.Gemini.UsageMetadataServiceTier? serviceTier, - int? thoughtsTokenCount, + global::System.Collections.Generic.IList? promptTokensDetails, global::System.Collections.Generic.IList? cacheTokensDetails, - int? cachedContentTokenCount, int? totalTokenCount, - global::System.Collections.Generic.IList? promptTokensDetails, global::System.Collections.Generic.IList? toolUsePromptTokensDetails, + int? candidatesTokenCount, + int? cachedContentTokenCount, global::System.Collections.Generic.IList? candidatesTokensDetails, + int? promptTokenCount, + int? toolUsePromptTokenCount, + global::Google.Gemini.UsageMetadataServiceTier? serviceTier, + int? thoughtsTokenCount, int? responseTokenCount, global::System.Collections.Generic.IList? responseTokensDetails) { - this.CandidatesTokenCount = candidatesTokenCount; - this.ToolUsePromptTokenCount = toolUsePromptTokenCount; - this.PromptTokenCount = promptTokenCount; - this.ServiceTier = serviceTier; - this.ThoughtsTokenCount = thoughtsTokenCount; + this.PromptTokensDetails = promptTokensDetails; this.CacheTokensDetails = cacheTokensDetails; - this.CachedContentTokenCount = cachedContentTokenCount; this.TotalTokenCount = totalTokenCount; - this.PromptTokensDetails = promptTokensDetails; this.ToolUsePromptTokensDetails = toolUsePromptTokensDetails; + this.CandidatesTokenCount = candidatesTokenCount; + this.CachedContentTokenCount = cachedContentTokenCount; this.CandidatesTokensDetails = candidatesTokensDetails; + this.PromptTokenCount = promptTokenCount; + this.ToolUsePromptTokenCount = toolUsePromptTokenCount; + this.ServiceTier = serviceTier; + this.ThoughtsTokenCount = thoughtsTokenCount; 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..6f022e26 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.VideoMetadata.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.VideoMetadata.g.cs @@ -10,11 +10,11 @@ namespace Google.Gemini public sealed partial class VideoMetadata { /// - /// Optional. The end offset of the video. + /// Optional. The start offset of the video. /// - [global::System.Text.Json.Serialization.JsonPropertyName("endOffset")] + [global::System.Text.Json.Serialization.JsonPropertyName("startOffset")] [global::System.Obsolete("This property marked as deprecated.")] - public string? EndOffset { get; set; } + public string? StartOffset { get; set; } /// /// Optional. The frame rate of the video sent to the model. If not specified, the default value will be 1.0. The fps range is (0.0, 24.0]. @@ -24,11 +24,11 @@ public sealed partial class VideoMetadata public double? Fps { get; set; } /// - /// Optional. The start offset of the video. + /// Optional. The end offset of the video. /// - [global::System.Text.Json.Serialization.JsonPropertyName("startOffset")] + [global::System.Text.Json.Serialization.JsonPropertyName("endOffset")] [global::System.Obsolete("This property marked as deprecated.")] - public string? StartOffset { get; set; } + public string? EndOffset { get; set; } /// /// 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 end offset of the video. + /// + /// Optional. The start offset of the video. /// /// /// Optional. The frame rate of the video sent to the model. If not specified, the default value will be 1.0. The fps range is (0.0, 24.0]. /// - /// - /// Optional. The start offset of the video. + /// + /// Optional. The end offset of the video. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public VideoMetadata( - string? endOffset, + string? startOffset, double? fps, - string? startOffset) + string? endOffset) { - this.EndOffset = endOffset; - this.Fps = fps; this.StartOffset = startOffset; + this.Fps = fps; + this.EndOffset = endOffset; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Web.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Web.g.cs index 10b0d5ec..057e2a36 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Web.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Web.g.cs @@ -9,18 +9,18 @@ namespace Google.Gemini public sealed partial class Web { /// - /// Output only. Title of the chunk.
+ /// Output only. URI reference of the chunk.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("title")] - public string? Title { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("uri")] + public string? Uri { get; set; } /// - /// Output only. URI reference of the chunk.
+ /// Output only. Title of the chunk.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("uri")] - public string? Uri { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("title")] + public string? Title { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -31,23 +31,23 @@ public sealed partial class Web /// /// Initializes a new instance of the class. /// - /// - /// Output only. Title of the chunk.
- /// Included only in responses - /// /// /// Output only. URI reference of the chunk.
/// Included only in responses /// + /// + /// Output only. Title of the chunk.
+ /// Included only in responses + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Web( - string? title, - string? uri) + string? uri, + string? title) { - this.Title = title; this.Uri = uri; + this.Title = title; } /// diff --git a/src/libs/Google.Gemini/openapi.json b/src/libs/Google.Gemini/openapi.json index c65b8140..f55aa53f 100644 --- a/src/libs/Google.Gemini/openapi.json +++ b/src/libs/Google.Gemini/openapi.json @@ -11,43 +11,52 @@ } ], "paths": { - "/models/{modelsId}:streamGenerateContent": { - "post": { - "description": "Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`.", - "operationId": "models.streamGenerateContent", + "/batches": { + "get": { + "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.", + "operationId": "batches.list", "parameters": [ { - "name": "modelsId", - "in": "path", - "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "name": "filter", + "in": "query", + "description": "The standard list filter.", "schema": { - "type": "string", - "pattern": "^models/[^/]+$" + "type": "string" } - } - ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" - } + }, + { + "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" } } - }, + ], "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" - } - }, - "text/event-stream": { - "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/ListOperationsResponse" } } } @@ -55,19 +64,28 @@ } } }, - "/models/{modelsId}:countTokens": { - "post": { - "description": "Runs a model's tokenizer on input `Content` and returns the token count. Refer to the [tokens guide](https://ai.google.dev/gemini-api/docs/tokens) to learn more about tokens.", - "operationId": "models.countTokens", + "/batches/{batchesId}:updateEmbedContentBatch": { + "patch": { + "description": "Updates a batch of EmbedContent requests for batch processing.", + "operationId": "batches.updateEmbedContentBatch", "parameters": [ { - "name": "modelsId", + "name": "batchesId", "in": "path", "required": true, - "description": "Required. The 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": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^batches/[^/]+$" + } + }, + { + "name": "updateMask", + "in": "query", + "description": "Optional. The list of fields to update.", + "schema": { + "type": "string", + "format": "google-fieldmask" } } ], @@ -75,7 +93,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CountTokensRequest" + "$ref": "#/components/schemas/EmbedContentBatch" } } } @@ -86,7 +104,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CountTokensResponse" + "$ref": "#/components/schemas/EmbedContentBatch" } } } @@ -94,38 +112,29 @@ } } }, - "/models/{modelsId}:batchGenerateContent": { + "/batches/{batchesId}:cancel": { "post": { - "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", - "operationId": "models.batchGenerateContent", + "description": "Starts asynchronous cancellation on a long-running operation. The server makes a best effort to cancel the operation, but success is not guaranteed. If the server doesn't support this method, it returns `google.rpc.Code.UNIMPLEMENTED`. Clients can use Operations.GetOperation or other methods to check whether the cancellation succeeded or whether the operation completed despite cancellation. On successful cancellation, the operation is not deleted; instead, it becomes an operation with an Operation.error value with a google.rpc.Status.code of `1`, corresponding to `Code.CANCELLED`.", + "operationId": "batches.cancel", "parameters": [ { - "name": "modelsId", + "name": "batchesId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "The name of the operation resource to be cancelled.", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^batches/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/BatchGenerateContentRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Empty" } } } @@ -133,58 +142,47 @@ } } }, - "/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", + "/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": "modelsId", + "name": "batchesId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "The name of the operation resource to be deleted.", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^batches/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/Empty" } } } } } - } - }, - "/models/{modelsId}": { + }, "get": { - "description": "Gets information about a specific `Model` such as its version number, token limits, [parameters](https://ai.google.dev/gemini-api/docs/models/generative-models#model-parameters) and other metadata. Refer to the [Gemini models guide](https://ai.google.dev/gemini-api/docs/models/gemini) for detailed model information.", - "operationId": "models.get", + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "batches.get", "parameters": [ { - "name": "modelsId", + "name": "batchesId", "in": "path", "required": true, - "description": "Required. The resource name of the model. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^batches/[^/]+$" } } ], @@ -194,7 +192,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Model" + "$ref": "#/components/schemas/Operation" } } } @@ -202,19 +200,28 @@ } } }, - "/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", + "/batches/{batchesId}:updateGenerateContentBatch": { + "patch": { + "description": "Updates a batch of GenerateContent requests for batch processing.", + "operationId": "batches.updateGenerateContentBatch", "parameters": [ { - "name": "modelsId", + "name": "batchesId", "in": "path", "required": true, - "description": "Required. The 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": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^batches/[^/]+$" + } + }, + { + "name": "updateMask", + "in": "query", + "description": "Optional. The list of fields to update.", + "schema": { + "type": "string", + "format": "google-fieldmask" } } ], @@ -222,7 +229,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/BatchEmbedContentsRequest" + "$ref": "#/components/schemas/GenerateContentBatch" } } } @@ -233,7 +240,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/BatchEmbedContentsResponse" + "$ref": "#/components/schemas/GenerateContentBatch" } } } @@ -241,58 +248,56 @@ } } }, - "/models/{modelsId}:asyncBatchEmbedContent": { - "post": { - "description": "Enqueues a batch of `EmbedContent` requests for batch processing. We have a `BatchEmbedContents` handler in `GenerativeService`, but it was synchronized. So we name this one to be `Async` to avoid confusion.", - "operationId": "models.asyncBatchEmbedContent", + "/tunedModels/{tunedModelsId}": { + "delete": { + "description": "Deletes a tuned model.", + "operationId": "tunedModels.delete", "parameters": [ { - "name": "modelsId", + "name": "tunedModelsId", "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 of the model. Format: `tunedModels/my-model-id`", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Empty" } } } } } - } - }, - "/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", + }, + "patch": { + "description": "Updates a tuned model.", + "operationId": "tunedModels.patch", "parameters": [ { - "name": "modelsId", + "name": "tunedModelsId", "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": "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": "^models/[^/]+$" + "pattern": "^tunedModels/[^/]+$" + } + }, + { + "name": "updateMask", + "in": "query", + "description": "Optional. The list of fields to update.", + "schema": { + "type": "string", + "format": "google-fieldmask" } } ], @@ -300,7 +305,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/EmbedContentRequest" + "$ref": "#/components/schemas/TunedModel" } } } @@ -311,34 +316,25 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/EmbedContentResponse" + "$ref": "#/components/schemas/TunedModel" } } } } } - } - }, - "/models": { + }, "get": { - "description": "Lists the [`Model`s](https://ai.google.dev/gemini-api/docs/models/gemini) available through the Gemini API.", - "operationId": "models.list", + "description": "Gets information about a specific TunedModel.", + "operationId": "tunedModels.get", "parameters": [ { - "name": "pageSize", - "in": "query", - "description": "The maximum number of `Models` to return (per page). If unspecified, 50 models will be returned per page. This method returns at most 1000 models per page, even if you pass a larger page_size.", + "name": "tunedModelsId", + "in": "path", + "required": true, + "description": "Required. The resource name of the model. Format: `tunedModels/my-model-id`", "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "A page token, received from a previous `ListModels` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListModels` must match the call that provided the page token.", - "schema": { - "type": "string" + "type": "string", + "pattern": "^tunedModels/[^/]+$" } } ], @@ -348,7 +344,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListModelsResponse" + "$ref": "#/components/schemas/TunedModel" } } } @@ -356,90 +352,69 @@ } } }, - "/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", + "/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", "parameters": [ { - "name": "filter", - "in": "query", - "description": "The standard list filter.", - "schema": { - "type": "string" - } - }, - { - "name": "modelsId", - "in": "path", - "required": true, - "description": "The name of the operation's parent resource.", - "schema": { - "type": "string", - "pattern": "^models/[^/]+$" - } - }, - { - "name": "pageSize", - "in": "query", - "description": "The standard list page size.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", + "name": "tunedModelId", "in": "query", - "description": "The standard list page token.", + "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" } - }, - { - "name": "returnPartialSuccess", - "in": "query", - "description": "When set to `true`, operations that are reachable are returned as normal, and those that are unreachable are returned in the ListOperationsResponse.unreachable field. This can only be `true` when reading across collections. For example, when `parent` is set to `\"projects/example/locations/-\"`. This field is not supported by default and will result in an `UNIMPLEMENTED` error if set unless explicitly documented otherwise in service or product specific documentation.", - "schema": { - "type": "boolean" - } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/TunedModel" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListOperationsResponse" + "$ref": "#/components/schemas/Operation" } } } } } - } - }, - "/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", + "description": "Lists created tuned models.", + "operationId": "tunedModels.list", "parameters": [ { - "name": "operationsId", - "in": "path", - "required": true, + "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": "modelsId", - "in": "path", - "required": true, - "description": "The name of the operation resource.", + "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": "string", - "pattern": "^models/[^/]+/operations/[^/]+$" + "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.", + "schema": { + "type": "string" } } ], @@ -449,7 +424,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/ListTunedModelsResponse" } } } @@ -457,19 +432,19 @@ } } }, - "/dynamic/{dynamicId}:streamGenerateContent": { + "/tunedModels/{tunedModelsId}:batchGenerateContent": { "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": "Enqueues a batch of `GenerateContent` requests for batch processing.", + "operationId": "tunedModels.batchGenerateContent", "parameters": [ { - "name": "dynamicId", + "name": "tunedModelsId", "in": "path", "required": true, "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^dynamic/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], @@ -477,7 +452,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "$ref": "#/components/schemas/BatchGenerateContentRequest" } } } @@ -488,12 +463,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" - } - }, - "text/event-stream": { - "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/Operation" } } } @@ -501,19 +471,19 @@ } } }, - "/dynamic/{dynamicId}:generateContent": { + "/tunedModels/{tunedModelsId}:asyncBatchEmbedContent": { "post": { - "description": "Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details.", - "operationId": "dynamic.generateContent", + "description": "Enqueues a batch of `EmbedContent` requests for batch processing. We have a `BatchEmbedContents` handler in `GenerativeService`, but it was synchronized. So we name this one to be `Async` to avoid confusion.", + "operationId": "tunedModels.asyncBatchEmbedContent", "parameters": [ { - "name": "dynamicId", + "name": "tunedModelsId", "in": "path", "required": true, "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^dynamic/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], @@ -521,7 +491,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" } } } @@ -532,7 +502,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/Operation" } } } @@ -540,50 +510,27 @@ } } }, - "/files": { - "get": { - "description": "Lists the metadata for `File`s owned by the requesting project.", - "operationId": "files.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 `File`s to return per page. If unspecified, defaults to 10. Maximum `page_size` is 100.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "Optional. A page token from a previous `ListFiles` call.", + "name": "tunedModelsId", + "in": "path", + "required": true, + "description": "Required. The resource name of the tuned model to transfer ownership. Format: `tunedModels/my-model-id`", "schema": { - "type": "string" + "type": "string", + "pattern": "^tunedModels/[^/]+$" } } ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/ListFilesResponse" - } - } - } - } - } - }, - "post": { - "description": "Creates a `File`.", - "operationId": "media.upload", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CreateFileRequest" + "$ref": "#/components/schemas/TransferOwnershipRequest" } } } @@ -594,7 +541,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CreateFileResponse" + "$ref": "#/components/schemas/TransferOwnershipResponse" } } } @@ -602,73 +549,66 @@ } } }, - "/files/{filesId}": { - "get": { - "description": "Gets the metadata for the given `File`.", - "operationId": "files.get", + "/tunedModels/{tunedModelsId}:generateContent": { + "post": { + "description": "Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details.", + "operationId": "tunedModels.generateContent", "parameters": [ { - "name": "filesId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The name of the `File` to get. Example: `files/abc-123`", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^files/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/GenerateContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/File" + "$ref": "#/components/schemas/GenerateContentResponse" } } } } } - }, - "delete": { - "description": "Deletes the `File`.", - "operationId": "files.delete", + } + }, + "/tunedModels/{tunedModelsId}:streamGenerateContent": { + "post": { + "description": "Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`.", + "operationId": "tunedModels.streamGenerateContent", "parameters": [ { - "name": "filesId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The name of the `File` to delete. Example: `files/abc-123`", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^files/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Empty" - } - } - } - } - } - } - }, - "/files:register": { - "post": { - "description": "Registers a Google Cloud Storage files with FileService. The user is expected to provide Google Cloud Storage URIs and will receive a File resource for each URI in return. Note that the files are not copied, just registered with File API. If one file fails to register, the whole request fails.", - "operationId": "files.register", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/RegisterFilesRequest" + "$ref": "#/components/schemas/GenerateContentRequest" } } } @@ -679,7 +619,12 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/RegisterFilesResponse" + "$ref": "#/components/schemas/GenerateContentResponse" + } + }, + "text/event-stream": { + "schema": { + "$ref": "#/components/schemas/GenerateContentResponse" } } } @@ -687,27 +632,53 @@ } } }, - "/generatedFiles": { + "/tunedModels/{tunedModelsId}/operations": { "get": { - "description": "Lists the generated files owned by the requesting project.", - "operationId": "generatedFiles.list", + "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.", + "operationId": "tunedModels.operations.list", "parameters": [ { - "name": "pageSize", + "name": "filter", "in": "query", - "description": "Optional. Maximum number of `GeneratedFile`s to return per page. If unspecified, defaults to 10. Maximum `page_size` is 50.", + "description": "The standard list filter.", "schema": { - "type": "integer", + "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.", + "schema": { + "type": "integer", "format": "int32" } }, { "name": "pageToken", "in": "query", - "description": "Optional. A page token from a previous `ListGeneratedFiles` call.", + "description": "The standard list page token.", "schema": { "type": "string" } + }, + { + "name": "returnPartialSuccess", + "in": "query", + "description": "When set to `true`, operations that are reachable are returned as normal, and those that are unreachable are returned in the ListOperationsResponse.unreachable field. This can only be `true` when reading across collections. For example, when `parent` is set to `\"projects/example/locations/-\"`. This field is not supported by default and will result in an `UNIMPLEMENTED` error if set unless explicitly documented otherwise in service or product specific documentation.", + "schema": { + "type": "boolean" + } } ], "responses": { @@ -716,7 +687,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListGeneratedFilesResponse" + "$ref": "#/components/schemas/ListOperationsResponse" } } } @@ -724,13 +695,13 @@ } } }, - "/generatedFiles/{generatedFilesId}/operations/{operationsId}": { + "/tunedModels/{tunedModelsId}/operations/{operationsId}": { "get": { "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "generatedFiles.operations.get", + "operationId": "tunedModels.operations.get", "parameters": [ { - "name": "operationsId", + "name": "tunedModelsId", "in": "path", "required": true, "schema": { @@ -738,13 +709,13 @@ } }, { - "name": "generatedFilesId", + "name": "operationsId", "in": "path", "required": true, "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^generatedFiles/[^/]+/operations/[^/]+$" + "pattern": "^tunedModels/[^/]+/operations/[^/]+$" } } ], @@ -762,15 +733,52 @@ } } }, - "/cachedContents": { + "/tunedModels/{tunedModelsId}/permissions": { + "post": { + "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" + } + } + } + }, + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Permission" + } + } + } + } + } + }, "get": { - "description": "Lists CachedContents.", - "operationId": "cachedContents.list", + "description": "Lists permissions for the specific resource.", + "operationId": "tunedModels.permissions.list", "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.", + "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" @@ -779,10 +787,20 @@ { "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.", + "description": "Optional. A page token, received from a previous `ListPermissions` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListPermissions` must match the call that provided the page token.", "schema": { "type": "string" } + }, + { + "name": "tunedModelsId", + "in": "path", + "required": true, + "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", + "schema": { + "type": "string", + "pattern": "^tunedModels/[^/]+$" + } } ], "responses": { @@ -791,21 +809,124 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListCachedContentsResponse" + "$ref": "#/components/schemas/ListPermissionsResponse" + } + } + } + } + } + } + }, + "/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" } } } } } }, - "post": { - "description": "Creates CachedContent resource.", - "operationId": "cachedContents.create", + "delete": { + "description": "Deletes the permission.", + "operationId": "tunedModels.permissions.delete", + "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/Empty" + } + } + } + } + } + }, + "patch": { + "description": "Updates the permission.", + "operationId": "tunedModels.permissions.patch", + "parameters": [ + { + "name": "tunedModelsId", + "in": "path", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "permissionsId", + "in": "path", + "required": true, + "description": "Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.", + "schema": { + "type": "string", + "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" + } + }, + { + "name": "updateMask", + "in": "query", + "description": "Required. The list of fields to update. Accepted ones: - role (`Permission.role` field)", + "schema": { + "type": "string", + "format": "google-fieldmask" + } + } + ], "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/Permission" } } } @@ -816,7 +937,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/Permission" } } } @@ -928,15 +1049,15 @@ } } }, - "/fileSearchStores": { + "/cachedContents": { "post": { - "description": "Creates an empty `FileSearchStore`.", - "operationId": "fileSearchStores.create", + "description": "Creates CachedContent resource.", + "operationId": "cachedContents.create", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/FileSearchStore" + "$ref": "#/components/schemas/CachedContent" } } } @@ -947,7 +1068,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/FileSearchStore" + "$ref": "#/components/schemas/CachedContent" } } } @@ -955,13 +1076,13 @@ } }, "get": { - "description": "Lists all `FileSearchStores` owned by the user.", - "operationId": "fileSearchStores.list", + "description": "Lists CachedContents.", + "operationId": "cachedContents.list", "parameters": [ { "name": "pageSize", "in": "query", - "description": "Optional. The maximum number of `FileSearchStores` to return (per page). The service may return fewer `FileSearchStores`. If unspecified, at most 10 `FileSearchStores` will be returned. The maximum size limit is 20 `FileSearchStores` per page.", + "description": "Optional. The maximum number of 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" @@ -970,7 +1091,7 @@ { "name": "pageToken", "in": "query", - "description": "Optional. A page token, received from a previous `ListFileSearchStores` call. Provide the `next_page_token` returned in the response as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListFileSearchStores` must match the call that provided the page token.", + "description": "Optional. A page token, received from a previous `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" } @@ -982,7 +1103,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListFileSearchStoresResponse" + "$ref": "#/components/schemas/ListCachedContentsResponse" } } } @@ -990,27 +1111,26 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}": { - "delete": { - "description": "Deletes a `FileSearchStore`.", - "operationId": "fileSearchStores.delete", + "/generatedFiles": { + "get": { + "description": "Lists the generated files owned by the requesting project.", + "operationId": "generatedFiles.list", "parameters": [ { - "name": "force", + "name": "pageSize", "in": "query", - "description": "Optional. If set to true, any `Document`s and objects related to this `FileSearchStore` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `FileSearchStore` contains any `Document`s.", + "description": "Optional. Maximum number of `GeneratedFile`s to return per page. If unspecified, defaults to 10. Maximum `page_size` is 50.", "schema": { - "type": "boolean" + "type": "integer", + "format": "int32" } }, { - "name": "fileSearchStoresId", - "in": "path", - "required": true, - "description": "Required. The resource name of the `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", + "name": "pageToken", + "in": "query", + "description": "Optional. A page token from a previous `ListGeneratedFiles` call.", "schema": { - "type": "string", - "pattern": "^fileSearchStores/[^/]+$" + "type": "string" } } ], @@ -1020,25 +1140,35 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/ListGeneratedFilesResponse" } } } } } - }, + } + }, + "/generatedFiles/{generatedFilesId}/operations/{operationsId}": { "get": { - "description": "Gets information about a specific `FileSearchStore`.", - "operationId": "fileSearchStores.get", + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "generatedFiles.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": "generatedFilesId", + "in": "path", + "required": true, + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+$" + "pattern": "^generatedFiles/[^/]+/operations/[^/]+$" } } ], @@ -1048,7 +1178,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/FileSearchStore" + "$ref": "#/components/schemas/Operation" } } } @@ -1056,19 +1186,19 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}:importFile": { + "/models/{modelsId}:streamGenerateContent": { "post": { - "description": "Imports a `File` from File Service to a `FileSearchStore`.", - "operationId": "fileSearchStores.importFile", + "description": "Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`.", + "operationId": "models.streamGenerateContent", "parameters": [ { - "name": "fileSearchStoresId", + "name": "modelsId", "in": "path", "required": true, - "description": "Required. Immutable. The name of the `FileSearchStore` to import the file into. Example: `fileSearchStores/my-file-search-store-123`", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+$" + "pattern": "^models/[^/]+$" } } ], @@ -1076,7 +1206,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ImportFileRequest" + "$ref": "#/components/schemas/GenerateContentRequest" } } } @@ -1087,7 +1217,12 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/GenerateContentResponse" + } + }, + "text/event-stream": { + "schema": { + "$ref": "#/components/schemas/GenerateContentResponse" } } } @@ -1095,37 +1230,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", + "/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": "operationsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "fileSearchStoresId", + "name": "modelsId", "in": "path", "required": true, - "description": "The name of the operation resource.", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/upload/operations/[^/]+$" + "pattern": "^models/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/GenerateContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/GenerateContentResponse" } } } @@ -1133,81 +1269,107 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}/documents/{documentsId}": { - "delete": { - "description": "Deletes a `Document`.", - "operationId": "fileSearchStores.documents.delete", + "/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", "parameters": [ { - "name": "fileSearchStoresId", + "name": "modelsId", "in": "path", "required": true, + "description": "Required. The resource name of the model. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", "schema": { - "type": "string" + "type": "string", + "pattern": "^models/[^/]+$" } - }, - { - "name": "force", - "in": "query", - "description": "Optional. If set to true, any `Chunk`s and objects related to this `Document` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `Document` contains any `Chunk`s.", - "schema": { - "type": "boolean" + } + ], + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Model" + } + } } - }, + } + } + } + }, + "/models/{modelsId}:asyncBatchEmbedContent": { + "post": { + "description": "Enqueues a batch of `EmbedContent` requests for batch processing. We have a `BatchEmbedContents` handler in `GenerativeService`, but it was synchronized. So we name this one to be `Async` to avoid confusion.", + "operationId": "models.asyncBatchEmbedContent", + "parameters": [ { - "name": "documentsId", + "name": "modelsId", "in": "path", "required": true, - "description": "Required. The resource name of the `Document` to delete. Example: `fileSearchStores/my-file-search-store-123/documents/the-doc-abc`", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" + "pattern": "^models/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/Operation" } } } } } - }, - "get": { - "description": "Gets information about a specific `Document`.", - "operationId": "fileSearchStores.documents.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": "fileSearchStoresId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "documentsId", + "name": "modelsId", "in": "path", "required": true, - "description": "Required. The name of the `Document` to retrieve. Example: `fileSearchStores/my-file-search-store-123/documents/the-doc-abc`", + "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" + "pattern": "^models/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/EmbedContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Document" + "$ref": "#/components/schemas/EmbedContentResponse" } } } @@ -1215,15 +1377,15 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}/documents": { + "/models": { "get": { - "description": "Lists all `Document`s in a `Corpus`.", - "operationId": "fileSearchStores.documents.list", + "description": "Lists the [`Model`s](https://ai.google.dev/gemini-api/docs/models/gemini) available through the Gemini API.", + "operationId": "models.list", "parameters": [ { "name": "pageSize", "in": "query", - "description": "Optional. The maximum number of `Document`s to return (per page). The service may return fewer `Document`s. If unspecified, at most 10 `Document`s will be returned. The maximum size limit is 20 `Document`s per page.", + "description": "The maximum number of `Models` to return (per page). If unspecified, 50 models will be returned per page. This method returns at most 1000 models per page, even if you pass a larger page_size.", "schema": { "type": "integer", "format": "int32" @@ -1232,20 +1394,10 @@ { "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": "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" } - }, - { - "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": { @@ -1254,7 +1406,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListDocumentsResponse" + "$ref": "#/components/schemas/ListModelsResponse" } } } @@ -1262,37 +1414,38 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}/operations/{operationsId}": { - "get": { - "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "fileSearchStores.operations.get", + "/models/{modelsId}:countTokens": { + "post": { + "description": "Runs a model's tokenizer on input `Content` and returns the token count. Refer to the [tokens guide](https://ai.google.dev/gemini-api/docs/tokens) to learn more about tokens.", + "operationId": "models.countTokens", "parameters": [ { - "name": "operationsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "fileSearchStoresId", + "name": "modelsId", "in": "path", "required": true, - "description": "The name of the operation resource.", + "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/operations/[^/]+$" + "pattern": "^models/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/CountTokensRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/CountTokensResponse" } } } @@ -1300,65 +1453,77 @@ } } }, - "/corpora/{corporaId}": { - "get": { - "description": "Gets information about a specific `Corpus`.", - "operationId": "corpora.get", + "/models/{modelsId}:batchGenerateContent": { + "post": { + "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", + "operationId": "models.batchGenerateContent", "parameters": [ { - "name": "corporaId", + "name": "modelsId", "in": "path", "required": true, - "description": "Required. The name of the `Corpus`. Example: `corpora/my-corpus-123`", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^corpora/[^/]+$" + "pattern": "^models/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/BatchGenerateContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Corpus" + "$ref": "#/components/schemas/Operation" } } } } } - }, - "delete": { - "description": "Deletes a `Corpus`.", - "operationId": "corpora.delete", + } + }, + "/models/{modelsId}:batchEmbedContents": { + "post": { + "description": "Generates multiple embedding vectors from the input `Content` which consists of a batch of strings represented as `EmbedContentRequest` objects.", + "operationId": "models.batchEmbedContents", "parameters": [ { - "name": "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", + "name": "modelsId", "in": "path", "required": true, - "description": "Required. The resource name of the `Corpus`. Example: `corpora/my-corpus-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": "^corpora/[^/]+$" + "pattern": "^models/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/BatchEmbedContentsRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/BatchEmbedContentsResponse" } } } @@ -1366,15 +1531,33 @@ } } }, - "/corpora": { + "/models/{modelsId}/operations": { "get": { - "description": "Lists all `Corpora` owned by the user.", - "operationId": "corpora.list", + "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": "filter", + "in": "query", + "description": "The standard list filter.", + "schema": { + "type": "string" + } + }, + { + "name": "modelsId", + "in": "path", + "required": true, + "description": "The name of the operation's parent resource.", + "schema": { + "type": "string", + "pattern": "^models/[^/]+$" + } + }, { "name": "pageSize", "in": "query", - "description": "Optional. The maximum number of `Corpora` to return (per page). The service may return fewer `Corpora`. If unspecified, at most 10 `Corpora` will be returned. The maximum size limit is 20 `Corpora` per page.", + "description": "The standard list page size.", "schema": { "type": "integer", "format": "int32" @@ -1383,44 +1566,27 @@ { "name": "pageToken", "in": "query", - "description": "Optional. A page token, received from a previous `ListCorpora` call. Provide the `next_page_token` returned in the response as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListCorpora` must match the call that provided the page token.", + "description": "The standard list page token.", "schema": { "type": "string" } - } - ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/ListCorporaResponse" - } - } - } - } - } - }, - "post": { - "description": "Creates an empty `Corpus`.", - "operationId": "corpora.create", - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Corpus" - } + }, + { + "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/Corpus" + "$ref": "#/components/schemas/ListOperationsResponse" } } } @@ -1428,13 +1594,13 @@ } } }, - "/corpora/{corporaId}/permissions/{permissionsId}": { + "/models/{modelsId}/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": "models.operations.get", "parameters": [ { - "name": "permissionsId", + "name": "operationsId", "in": "path", "required": true, "schema": { @@ -1442,13 +1608,13 @@ } }, { - "name": "corporaId", + "name": "modelsId", "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": "^models/[^/]+/operations/[^/]+$" } } ], @@ -1458,42 +1624,27 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/Operation" } } } } } - }, - "patch": { - "description": "Updates the permission.", - "operationId": "corpora.permissions.patch", + } + }, + "/dynamic/{dynamicId}:streamGenerateContent": { + "post": { + "description": "Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`.", + "operationId": "dynamic.streamGenerateContent", "parameters": [ { - "name": "permissionsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "corporaId", + "name": "dynamicId", "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. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "format": "google-fieldmask" + "pattern": "^dynamic/[^/]+$" } } ], @@ -1501,7 +1652,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/GenerateContentRequest" } } } @@ -1512,43 +1663,51 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/GenerateContentResponse" + } + }, + "text/event-stream": { + "schema": { + "$ref": "#/components/schemas/GenerateContentResponse" } } } } } - }, - "delete": { - "description": "Deletes the permission.", - "operationId": "corpora.permissions.delete", + } + }, + "/dynamic/{dynamicId}:generateContent": { + "post": { + "description": "Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details.", + "operationId": "dynamic.generateContent", "parameters": [ { - "name": "permissionsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "corporaId", + "name": "dynamicId", "in": "path", "required": true, - "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^corpora/[^/]+/permissions/[^/]+$" + "pattern": "^dynamic/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/GenerateContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/GenerateContentResponse" } } } @@ -1556,36 +1715,19 @@ } } }, - "/corpora/{corporaId}/permissions": { - "get": { - "description": "Lists permissions for the specific resource.", - "operationId": "corpora.permissions.list", + "/files/{filesId}": { + "delete": { + "description": "Deletes the `File`.", + "operationId": "files.delete", "parameters": [ { - "name": "pageSize", - "in": "query", - "description": "Optional. The maximum number of `Permission`s to return (per page). The service may return fewer permissions. If unspecified, at most 10 permissions will be returned. This method returns at most 1000 permissions per page, even if you pass larger page_size.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "Optional. A page token, received from a previous `ListPermissions` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListPermissions` must match the call that provided the page token.", - "schema": { - "type": "string" - } - }, - { - "name": "corporaId", + "name": "filesId", "in": "path", "required": true, - "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", + "description": "Required. The name of the `File` to delete. Example: `files/abc-123`", "schema": { "type": "string", - "pattern": "^corpora/[^/]+$" + "pattern": "^files/[^/]+$" } } ], @@ -1595,33 +1737,51 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListPermissionsResponse" + "$ref": "#/components/schemas/Empty" } } } } } }, - "post": { - "description": "Create a permission to a specific resource.", - "operationId": "corpora.permissions.create", + "get": { + "description": "Gets the metadata for the given `File`.", + "operationId": "files.get", "parameters": [ { - "name": "corporaId", + "name": "filesId", "in": "path", "required": true, - "description": "Required. The parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", + "description": "Required. The name of the `File` to get. Example: `files/abc-123`", "schema": { "type": "string", - "pattern": "^corpora/[^/]+$" + "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/Permission" + "$ref": "#/components/schemas/RegisterFilesRequest" } } } @@ -1632,7 +1792,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/RegisterFilesResponse" } } } @@ -1640,27 +1800,26 @@ } } }, - "/corpora/{corporaId}/operations/{operationsId}": { + "/files": { "get": { - "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "corpora.operations.get", + "description": "Lists the metadata for `File`s owned by the requesting project.", + "operationId": "files.list", "parameters": [ { - "name": "operationsId", - "in": "path", - "required": true, + "name": "pageSize", + "in": "query", + "description": "Optional. Maximum number of `File`s to return per page. If unspecified, defaults to 10. Maximum `page_size` is 100.", "schema": { - "type": "string" + "type": "integer", + "format": "int32" } }, { - "name": "corporaId", - "in": "path", - "required": true, - "description": "The name of the operation resource.", + "name": "pageToken", + "in": "query", + "description": "Optional. A page token from a previous `ListFiles` call.", "schema": { - "type": "string", - "pattern": "^corpora/[^/]+/operations/[^/]+$" + "type": "string" } } ], @@ -1670,35 +1829,21 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/ListFilesResponse" } } } } } - } - }, - "/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": "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`", - "schema": { - "type": "string", - "pattern": "^fileSearchStores/[^/]+$" - } - } - ], + "description": "Creates a `File`.", + "operationId": "media.upload", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/UploadToFileSearchStoreRequest" + "$ref": "#/components/schemas/CreateFileRequest" } } } @@ -1709,7 +1854,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CustomLongRunningOperation" + "$ref": "#/components/schemas/CreateFileResponse" } } } @@ -1717,58 +1862,55 @@ } } }, - "/tunedModels/{tunedModelsId}:batchGenerateContent": { - "post": { - "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", - "operationId": "tunedModels.batchGenerateContent", + "/fileSearchStores/{fileSearchStoresId}": { + "delete": { + "description": "Deletes a `FileSearchStore`.", + "operationId": "fileSearchStores.delete", "parameters": [ { - "name": "tunedModelsId", + "name": "force", + "in": "query", + "description": "Optional. If set to true, any `Document`s and objects related to this `FileSearchStore` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `FileSearchStore` contains any `Document`s.", + "schema": { + "type": "boolean" + } + }, + { + "name": "fileSearchStoresId", "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 of the `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^fileSearchStores/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/BatchGenerateContentRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Empty" } } } } } - } - }, - "/tunedModels/{tunedModelsId}": { + }, "get": { - "description": "Gets information about a specific TunedModel.", - "operationId": "tunedModels.get", + "description": "Gets information about a specific `FileSearchStore`.", + "operationId": "fileSearchStores.get", "parameters": [ { - "name": "tunedModelsId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Required. The resource name of the model. Format: `tunedModels/my-model-id`", + "description": "Required. The name of the `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^fileSearchStores/[^/]+$" } } ], @@ -1778,25 +1920,34 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/FileSearchStore" } } } } } - }, - "delete": { - "description": "Deletes a tuned model.", - "operationId": "tunedModels.delete", + } + }, + "/fileSearchStores": { + "get": { + "description": "Lists all `FileSearchStores` owned by the user.", + "operationId": "fileSearchStores.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 `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", - "pattern": "^tunedModels/[^/]+$" + "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.", + "schema": { + "type": "string" } } ], @@ -1806,42 +1957,21 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/ListFileSearchStoresResponse" } } } } } }, - "patch": { - "description": "Updates a tuned model.", - "operationId": "tunedModels.patch", - "parameters": [ - { - "name": "tunedModelsId", - "in": "path", - "required": true, - "description": "Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`", - "schema": { - "type": "string", - "pattern": "^tunedModels/[^/]+$" - } - }, - { - "name": "updateMask", - "in": "query", - "description": "Optional. The list of fields to update.", - "schema": { - "type": "string", - "format": "google-fieldmask" - } - } - ], + "post": { + "description": "Creates an empty `FileSearchStore`.", + "operationId": "fileSearchStores.create", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/FileSearchStore" } } } @@ -1852,7 +1982,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/FileSearchStore" } } } @@ -1860,19 +1990,19 @@ } } }, - "/tunedModels/{tunedModelsId}:generateContent": { + "/fileSearchStores/{fileSearchStoresId}:importFile": { "post": { - "description": "Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details.", - "operationId": "tunedModels.generateContent", + "description": "Imports a `File` from File Service to a `FileSearchStore`.", + "operationId": "fileSearchStores.importFile", "parameters": [ { - "name": "tunedModelsId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "Required. Immutable. The name of the `FileSearchStore` to import the file into. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^fileSearchStores/[^/]+$" } } ], @@ -1880,7 +2010,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "$ref": "#/components/schemas/ImportFileRequest" } } } @@ -1891,7 +2021,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/Operation" } } } @@ -1899,38 +2029,37 @@ } } }, - "/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", + "/fileSearchStores/{fileSearchStoresId}/operations/{operationsId}": { + "get": { + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "fileSearchStores.operations.get", "parameters": [ { - "name": "tunedModelsId", + "name": "operationsId", "in": "path", "required": true, - "description": "Required. The resource name of the tuned model to transfer ownership. Format: `tunedModels/my-model-id`", + "schema": { + "type": "string" + } + }, + { + "name": "fileSearchStoresId", + "in": "path", + "required": true, + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^fileSearchStores/[^/]+/operations/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/TransferOwnershipRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TransferOwnershipResponse" + "$ref": "#/components/schemas/Operation" } } } @@ -1938,43 +2067,37 @@ } } }, - "/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", + "/fileSearchStores/{fileSearchStoresId}/upload/operations/{operationsId}": { + "get": { + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "fileSearchStores.upload.operations.get", "parameters": [ { - "name": "tunedModelsId", + "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": "^tunedModels/[^/]+$" + "pattern": "^fileSearchStores/[^/]+/upload/operations/[^/]+$" } } ], - "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/Operation" } } } @@ -1982,23 +2105,97 @@ } } }, - "/tunedModels": { + "/fileSearchStores/{fileSearchStoresId}/documents/{documentsId}": { "get": { - "description": "Lists created tuned models.", - "operationId": "tunedModels.list", - "parameters": [ + "description": "Gets information about a specific `Document`.", + "operationId": "fileSearchStores.documents.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": "fileSearchStoresId", + "in": "path", + "required": true, + "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": "^fileSearchStores/[^/]+/documents/[^/]+$" + } + } + ], + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Document" + } + } + } + } + } + }, + "delete": { + "description": "Deletes a `Document`.", + "operationId": "fileSearchStores.documents.delete", + "parameters": [ + { + "name": "fileSearchStoresId", + "in": "path", + "required": true, "schema": { "type": "string" } }, + { + "name": "force", + "in": "query", + "description": "Optional. If set to true, any `Chunk`s and objects related to this `Document` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `Document` contains any `Chunk`s.", + "schema": { + "type": "boolean" + } + }, + { + "name": "documentsId", + "in": "path", + "required": true, + "description": "Required. The resource name of the `Document` to delete. Example: `fileSearchStores/my-file-search-store-123/documents/the-doc-abc`", + "schema": { + "type": "string", + "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" + } + } + ], + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Empty" + } + } + } + } + } + } + }, + "/fileSearchStores/{fileSearchStoresId}/documents": { + "get": { + "description": "Lists all `Document`s in a `Corpus`.", + "operationId": "fileSearchStores.documents.list", + "parameters": [ { "name": "pageSize", "in": "query", - "description": "Optional. The maximum number of `TunedModels` to return (per page). The service may return fewer tuned models. If unspecified, at most 10 tuned models will be returned. This method returns at most 1000 models per page, even if you pass a larger page_size.", + "description": "Optional. The maximum number of `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" @@ -2007,10 +2204,20 @@ { "name": "pageToken", "in": "query", - "description": "Optional. A page token, received from a previous `ListTunedModels` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListTunedModels` must match the call that provided the page token.", + "description": "Optional. A page token, received from a previous `ListDocuments` call. Provide the `next_page_token` returned in the response as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListDocuments` must match the call that provided the page token.", "schema": { "type": "string" } + }, + { + "name": "fileSearchStoresId", + "in": "path", + "required": true, + "description": "Required. The name of the `FileSearchStore` containing `Document`s. Example: `fileSearchStores/my-file-search-store-123`", + "schema": { + "type": "string", + "pattern": "^fileSearchStores/[^/]+$" + } } ], "responses": { @@ -2019,23 +2226,27 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListTunedModelsResponse" + "$ref": "#/components/schemas/ListDocumentsResponse" } } } } } - }, + } + }, + "/fileSearchStores/{fileSearchStoresId}:uploadToFileSearchStore": { "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", + "description": "Uploads data to a FileSearchStore, preprocesses and chunks before storing it in a FileSearchStore Document.", + "operationId": "media.uploadToFileSearchStore", "parameters": [ { - "name": "tunedModelId", - "in": "query", - "description": "Optional. The unique id for the tuned model if specified. This value should be up to 40 characters, the first character must be a letter, the last could be a letter or a number. The id must match the regular expression: `[a-z]([a-z0-9-]{0,38}[a-z0-9])?`.", + "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`", "schema": { - "type": "string" + "type": "string", + "pattern": "^fileSearchStores/[^/]+$" } } ], @@ -2043,7 +2254,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/UploadToFileSearchStoreRequest" } } } @@ -2054,7 +2265,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/CustomLongRunningOperation" } } } @@ -2062,27 +2273,15 @@ } } }, - "/tunedModels/{tunedModelsId}:asyncBatchEmbedContent": { + "/corpora": { "post": { - "description": "Enqueues a batch of `EmbedContent` requests for batch processing. We have a `BatchEmbedContents` handler in `GenerativeService`, but it was synchronized. So we name this one to be `Async` to avoid confusion.", - "operationId": "tunedModels.asyncBatchEmbedContent", - "parameters": [ - { - "name": "tunedModelsId", - "in": "path", - "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", - "schema": { - "type": "string", - "pattern": "^tunedModels/[^/]+$" - } - } - ], + "description": "Creates an empty `Corpus`.", + "operationId": "corpora.create", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" + "$ref": "#/components/schemas/Corpus" } } } @@ -2093,63 +2292,72 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Corpus" } } } } } - } - }, - "/tunedModels/{tunedModelsId}/permissions/{permissionsId}": { - "patch": { - "description": "Updates the permission.", - "operationId": "tunedModels.permissions.patch", + }, + "get": { + "description": "Lists all `Corpora` owned by the user.", + "operationId": "corpora.list", "parameters": [ { - "name": "tunedModelsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "permissionsId", - "in": "path", - "required": true, - "description": "Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.", + "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": "^tunedModels/[^/]+/permissions/[^/]+$" + "type": "integer", + "format": "int32" } }, { - "name": "updateMask", + "name": "pageToken", "in": "query", - "description": "Required. The list of fields to update. Accepted ones: - role (`Permission.role` field)", + "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", - "format": "google-fieldmask" + "type": "string" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Permission" + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/ListCorporaResponse" + } } } } - }, + } + } + }, + "/corpora/{corporaId}": { + "get": { + "description": "Gets information about a specific `Corpus`.", + "operationId": "corpora.get", + "parameters": [ + { + "name": "corporaId", + "in": "path", + "required": true, + "description": "Required. The name of the `Corpus`. Example: `corpora/my-corpus-123`", + "schema": { + "type": "string", + "pattern": "^corpora/[^/]+$" + } + } + ], "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/Corpus" } } } @@ -2157,25 +2365,25 @@ } }, "delete": { - "description": "Deletes the permission.", - "operationId": "tunedModels.permissions.delete", + "description": "Deletes a `Corpus`.", + "operationId": "corpora.delete", "parameters": [ { - "name": "tunedModelsId", - "in": "path", - "required": true, + "name": "force", + "in": "query", + "description": "Optional. If set to true, any `Document`s and objects related to this `Corpus` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `Corpus` contains any `Document`s.", "schema": { - "type": "string" + "type": "boolean" } }, { - "name": "permissionsId", + "name": "corporaId", "in": "path", "required": true, - "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", + "description": "Required. The resource name of the `Corpus`. Example: `corpora/my-corpus-123`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" + "pattern": "^corpora/[^/]+$" } } ], @@ -2191,13 +2399,15 @@ } } } - }, + } + }, + "/corpora/{corporaId}/operations/{operationsId}": { "get": { - "description": "Gets information about a specific Permission.", - "operationId": "tunedModels.permissions.get", + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "corpora.operations.get", "parameters": [ { - "name": "tunedModelsId", + "name": "operationsId", "in": "path", "required": true, "schema": { @@ -2205,13 +2415,13 @@ } }, { - "name": "permissionsId", + "name": "corporaId", "in": "path", "required": true, - "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" + "pattern": "^corpora/[^/]+/operations/[^/]+$" } } ], @@ -2221,7 +2431,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/Operation" } } } @@ -2229,19 +2439,19 @@ } } }, - "/tunedModels/{tunedModelsId}/permissions": { + "/corpora/{corporaId}/permissions": { "post": { "description": "Create a permission to a specific resource.", - "operationId": "tunedModels.permissions.create", + "operationId": "corpora.permissions.create", "parameters": [ { - "name": "tunedModelsId", + "name": "corporaId", "in": "path", "required": true, "description": "Required. The parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^corpora/[^/]+$" } } ], @@ -2269,7 +2479,7 @@ }, "get": { "description": "Lists permissions for the specific resource.", - "operationId": "tunedModels.permissions.list", + "operationId": "corpora.permissions.list", "parameters": [ { "name": "pageSize", @@ -2289,13 +2499,13 @@ } }, { - "name": "tunedModelsId", + "name": "corporaId", "in": "path", "required": true, "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^corpora/[^/]+$" } } ], @@ -2313,76 +2523,13 @@ } } }, - "/tunedModels/{tunedModelsId}/operations": { - "get": { - "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.", - "operationId": "tunedModels.operations.list", - "parameters": [ - { - "name": "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.", - "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" - } - } - ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/ListOperationsResponse" - } - } - } - } - } - } - }, - "/tunedModels/{tunedModelsId}/operations/{operationsId}": { + "/corpora/{corporaId}/permissions/{permissionsId}": { "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", + "description": "Gets information about a specific Permission.", + "operationId": "corpora.permissions.get", "parameters": [ { - "name": "tunedModelsId", + "name": "permissionsId", "in": "path", "required": true, "schema": { @@ -2390,13 +2537,13 @@ } }, { - "name": "operationsId", + "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": "^tunedModels/[^/]+/operations/[^/]+$" + "pattern": "^corpora/[^/]+/permissions/[^/]+$" } } ], @@ -2406,75 +2553,33 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Permission" } } } } } - } - }, - "/batches/{batchesId}:updateGenerateContentBatch": { - "patch": { - "description": "Updates a batch of GenerateContent requests for batch processing.", - "operationId": "batches.updateGenerateContentBatch", + }, + "delete": { + "description": "Deletes the permission.", + "operationId": "corpora.permissions.delete", "parameters": [ { - "name": "batchesId", + "name": "permissionsId", "in": "path", "required": true, - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", "schema": { - "type": "string", - "pattern": "^batches/[^/]+$" + "type": "string" } }, { - "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/GenerateContentBatch" - } - } - } - }, - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/GenerateContentBatch" - } - } - } - } - } - } - }, - "/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", + "name": "corporaId", "in": "path", "required": true, - "description": "The name of the operation resource to be deleted.", + "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", "schema": { "type": "string", - "pattern": "^batches/[^/]+$" + "pattern": "^corpora/[^/]+/permissions/[^/]+$" } } ], @@ -2491,107 +2596,32 @@ } } }, - "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", + "patch": { + "description": "Updates the permission.", + "operationId": "corpora.permissions.patch", "parameters": [ { - "name": "batchesId", + "name": "permissionsId", "in": "path", "required": true, - "description": "The name of the operation resource.", - "schema": { - "type": "string", - "pattern": "^batches/[^/]+$" - } - } - ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Operation" - } - } - } - } - } - } - }, - "/batches": { - "get": { - "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.", - "operationId": "batches.list", - "parameters": [ - { - "name": "filter", - "in": "query", - "description": "The standard list filter.", - "schema": { - "type": "string" - } - }, - { - "name": "pageSize", - "in": "query", - "description": "The standard list page size.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "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" - } - } - ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/ListOperationsResponse" - } - } - } - } - } - } - }, - "/batches/{batchesId}:updateEmbedContentBatch": { - "patch": { - "description": "Updates a batch of EmbedContent requests for batch processing.", - "operationId": "batches.updateEmbedContentBatch", - "parameters": [ - { - "name": "batchesId", + "name": "corporaId", "in": "path", "required": true, - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", + "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": "^corpora/[^/]+/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" @@ -2602,7 +2632,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/EmbedContentBatch" + "$ref": "#/components/schemas/Permission" } } } @@ -2613,37 +2643,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/EmbedContentBatch" - } - } - } - } - } - } - }, - "/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": "The name of the operation resource to be cancelled.", - "schema": { - "type": "string", - "pattern": "^batches/[^/]+$" - } - } - ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/Permission" } } } @@ -2654,3671 +2654,3637 @@ }, "components": { "schemas": { - "Model": { + "RetrievedContext": { "type": "object", "properties": { - "topK": { - "description": "For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. If empty, indicates the model doesn't use top-k sampling, and `top_k` isn't allowed as a generation parameter.", - "format": "int32", - "type": "integer" - }, - "baseModelId": { - "description": "Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash`", - "type": "string" - }, - "version": { - "description": "Required. The version number of the model. This represents the major version (`1.0` or `1.5`)", - "type": "string" - }, - "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" - }, - "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`", + "fileSearchStore": { + "description": "Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123`", "type": "string" }, - "outputTokenLimit": { - "description": "Maximum number of output tokens available for this model.", - "format": "int32", - "type": "integer" - }, - "maxTemperature": { - "type": "number", - "description": "The maximum temperature this model can use.", - "format": "float" - }, - "supportedGenerationMethods": { - "description": "The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`.", + "customMetadata": { "type": "array", "items": { - "type": "string" - } + "$ref": "#/components/schemas/GroundingChunkCustomMetadata" + }, + "description": "Optional. User-provided metadata about the retrieved context." }, - "description": { - "description": "A short description of the model.", + "title": { + "description": "Optional. Title of the document.", "type": "string" }, - "temperature": { - "type": "number", - "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" + "text": { + "description": "Optional. Text of the chunk.", + "type": "string" }, - "thinking": { - "description": "Whether the model supports thinking.", - "type": "boolean" + "mediaId": { + "description": "Optional. The media blob resource name for multimodal file search results. Format: fileSearchStores/{file_search_store_id}/media/{blob_id}", + "type": "string" }, - "inputTokenLimit": { + "uri": { + "description": "Optional. URI reference of the semantic retrieval document.", + "type": "string" + }, + "pageNumber": { "type": "integer", - "description": "Maximum number of input tokens allowed for this model.", + "description": "Optional. Page number of the retrieved context, if applicable.", "format": "int32" - }, - "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" } }, - "description": "Information about a Generative Language Model." + "description": "Chunk from context retrieved by the file search tool." }, - "ImageResponseFormat": { - "description": "Configuration for image output format.", + "SpeakerVoiceConfig": { "properties": { - "mimeType": { - "description": "Optional. The MIME type of the image output.", - "enum": [ - "MIME_TYPE_UNSPECIFIED", - "IMAGE_JPEG" - ], - "type": "string", - "x-enum-descriptions": [ - "Default value. This value is unused.", - "JPEG image format." - ] - }, - "imageSize": { - "enum": [ - "IMAGE_SIZE_UNSPECIFIED", - "IMAGE_SIZE_FIVE_TWELVE", - "IMAGE_SIZE_ONE_K", - "IMAGE_SIZE_TWO_K", - "IMAGE_SIZE_FOUR_K" - ], - "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." - ], + "speaker": { + "description": "Required. The name of the speaker to use. Should be the same as in the prompt.", "type": "string" }, - "delivery": { - "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", - "enum": [ - "DELIVERY_UNSPECIFIED", - "INLINE", - "URI" - ], - "description": "Optional. The delivery mode for the image output." - }, - "aspectRatio": { - "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." - ], - "type": "string" + "voiceConfig": { + "description": "Required. The configuration for the voice to use.", + "$ref": "#/components/schemas/VoiceConfig" } }, - "type": "object" + "type": "object", + "description": "The configuration for a single speaker in a multi speaker setup." }, - "TranslationConfig": { - "description": "Config for translation features.", + "InlinedEmbedContentRequest": { "type": "object", "properties": { - "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" + "request": { + "description": "Required. The request to be processed in the batch.", + "$ref": "#/components/schemas/EmbedContentRequest" }, - "targetLanguageCode": { - "description": "Required. The target language for translation. Supported values are BCP-47 language codes (e.g. \"en\", \"es\", \"fr\").", - "type": "string" + "metadata": { + "description": "Optional. The metadata to be associated with the request.", + "additionalProperties": { + "description": "Properties of the object." + }, + "type": "object" } - } - }, - "UrlContext": { - "description": "Tool to support URL context retrieval.", - "type": "object", - "properties": {} + }, + "description": "The request to be processed in the batch." }, - "GoogleAiGenerativelanguageV1betaGroundingSupport": { + "InlinedRequest": { "properties": { - "segment": { - "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaSegment", - "description": "Segment of the content this support belongs to." - }, - "renderedParts": { - "type": "array", - "items": { - "type": "integer", - "format": "int32" - }, - "description": "Output only. Indices into the `parts` field of the candidate's content. These indices specify which rendered parts are associated with this support source.", - "readOnly": true - }, - "groundingChunkIndices": { - "description": "Optional. A list of indices (into 'grounding_chunk' in `response.candidate.grounding_metadata`) specifying the citations associated with the claim. For instance [1,3,4] means that grounding_chunk[1], grounding_chunk[3], grounding_chunk[4] are the retrieved content attributed to the claim. If the response is streaming, the grounding_chunk_indices refer to the indices across all responses. It is the client's responsibility to accumulate the grounding chunks from all responses (while maintaining the same order).", - "type": "array", - "items": { - "type": "integer", - "format": "int32" - } + "request": { + "description": "Required. The request to be processed in the batch.", + "$ref": "#/components/schemas/GenerateContentRequest" }, - "confidenceScores": { - "type": "array", - "items": { - "type": "number", - "format": "float" + "metadata": { + "type": "object", + "additionalProperties": { + "description": "Properties of the object." }, - "description": "Optional. Confidence score of the support references. Ranges from 0 to 1. 1 is the most confident. This list must have the same size as the grounding_chunk_indices." + "description": "Optional. The metadata to be associated with the request." } }, "type": "object", - "description": "Grounding support." + "description": "The request to be processed in the batch." }, - "ListModelsResponse": { - "type": "object", + "CustomLongRunningOperation": { "properties": { - "models": { - "type": "array", - "items": { - "$ref": "#/components/schemas/Model" + "response": { + "type": "object", + "additionalProperties": { + "description": "Properties of the object. Contains field @type with type URL." }, - "description": "The returned Models." + "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`." }, - "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.", + "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" - } - }, - "description": "Response from `ListModel` containing a paginated list of Models." - }, - "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." }, "metadata": { - "description": "Optional. The metadata to be associated with the request.", "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" - } - } - }, - "CreateFileResponse": { - "type": "object", - "properties": { - "file": { - "$ref": "#/components/schemas/File", - "description": "Metadata for the created file." + }, + "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" + }, + "error": { + "description": "The error result of the operation in case of failure or cancellation.", + "$ref": "#/components/schemas/Status" } }, - "description": "Response for `CreateFile`." + "type": "object" }, - "EmbedContentConfig": { + "AudioResponseFormat": { + "description": "Configuration for audio output format.", + "type": "object", "properties": { - "outputDimensionality": { + "bitRate": { + "description": "Optional. Bit rate in bits per second (bps). Only applicable for compressed formats (MP3, Opus).", + "format": "int32", + "type": "integer" + }, + "sampleRate": { "type": "integer", - "description": "Optional. Reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end.", + "description": "Optional. Sample rate in Hz.", "format": "int32" }, - "audioTrackExtraction": { - "description": "Optional. Whether to extract audio from video content.", - "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": { - "enum": [ - "TASK_TYPE_UNSPECIFIED", - "RETRIEVAL_QUERY", - "RETRIEVAL_DOCUMENT", - "SEMANTIC_SIMILARITY", - "CLASSIFICATION", - "CLUSTERING", - "QUESTION_ANSWERING", - "FACT_VERIFICATION", - "CODE_RETRIEVAL_QUERY" + "mimeType": { + "type": "string", + "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." ], - "description": "Optional. The task type of the embedding.", + "enum": [ + "MIME_TYPE_UNSPECIFIED", + "AUDIO_MP3", + "AUDIO_OGG_OPUS", + "AUDIO_L16", + "AUDIO_WAV", + "AUDIO_ALAW", + "AUDIO_MULAW" + ] + }, + "delivery": { + "description": "Optional. The delivery mode for the audio output.", "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." + "Default value. This value is unused.", + "Audio data is returned inline in the response.", + "Audio data is returned as a URI." + ], + "enum": [ + "DELIVERY_UNSPECIFIED", + "INLINE", + "URI" ], "type": "string" - }, - "autoTruncate": { - "description": "Optional. Whether to silently truncate the input content if it's longer than the maximum sequence length.", - "type": "boolean" } - }, - "type": "object", - "description": "Configurations for the EmbedContent request." + } }, - "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", + "FunctionResponse": { "properties": { - "googleMaps": { - "$ref": "#/components/schemas/GoogleMaps", - "description": "Optional. Tool that allows grounding the model's response with geospatial context related to the user's query." - }, - "googleSearch": { - "description": "Optional. GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google.", - "$ref": "#/components/schemas/GoogleSearch" + "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" }, - "fileSearch": { - "description": "Optional. FileSearch tool type. Tool to retrieve knowledge from Semantic Retrieval corpora.", - "$ref": "#/components/schemas/FileSearch" + "response": { + "type": "object", + "additionalProperties": { + "description": "Properties of the object." + }, + "description": "Required. The function response in JSON object format. Callers can use any keys of their choice that fit the function's syntax to return the function output, e.g. \"output\", \"result\", etc. In particular, if the function call failed to execute, the response can have an \"error\" key to return error details to the model. 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." }, - "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.", + "parts": { "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." - }, - "googleSearchRetrieval": { - "description": "Optional. Retrieval tool that is powered by Google search.", - "$ref": "#/components/schemas/GoogleSearchRetrieval" + "$ref": "#/components/schemas/FunctionResponsePart" + }, + "description": "Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types." }, - "codeExecution": { - "$ref": "#/components/schemas/CodeExecution", - "description": "Optional. Enables the model to execute code as part of generation." + "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" }, - "urlContext": { - "$ref": "#/components/schemas/UrlContext", - "description": "Optional. Tool to support URL context retrieval." + "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" }, - "mcpServers": { - "type": "array", - "items": { - "$ref": "#/components/schemas/McpServer" - }, - "description": "Optional. MCP Servers to connect to." + "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.", + "x-enum-descriptions": [ + "This value is unused.", + "Only add the result to the conversation context, do not interrupt or trigger generation.", + "Add the result to the conversation context, and prompt to generate output without interrupting ongoing generation.", + "Add the result to the conversation context, interrupt ongoing generation and prompt to generate output." + ], + "enum": [ + "SCHEDULING_UNSPECIFIED", + "SILENT", + "WHEN_IDLE", + "INTERRUPT" + ], + "type": "string" } - } + }, + "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." }, - "SearchEntryPoint": { + "GroundingChunkCustomMetadata": { "properties": { - "renderedContent": { - "description": "Optional. Web content snippet that can be embedded in a web page or an app webview.", + "stringValue": { + "description": "Optional. The string value of the metadata.", "type": "string" }, - "sdkBlob": { - "type": "string", - "description": "Optional. Base64 encoded JSON representing array of tuple.", - "format": "byte" + "numericValue": { + "description": "Optional. The numeric value of the metadata. The expected range for this value depends on the specific `key` used.", + "format": "float", + "type": "number" + }, + "stringListValue": { + "description": "Optional. A list of string values for the metadata.", + "$ref": "#/components/schemas/GroundingChunkStringList" + }, + "key": { + "description": "The key of the metadata.", + "type": "string" } }, "type": "object", - "description": "Google search entry point." + "description": "User provided metadata about the GroundingFact." }, - "Status": { - "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).", + "BatchStats": { + "type": "object", "properties": { - "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.", + "failedRequestCount": { + "readOnly": true, + "type": "string", + "description": "Output only. The number of requests that failed to be processed.", + "format": "int64" + }, + "successfulRequestCount": { + "description": "Output only. The number of requests that were successfully processed.", + "format": "int64", + "readOnly": true, "type": "string" }, - "code": { - "type": "integer", - "description": "The status code, which should be an enum value of google.rpc.Code.", - "format": "int32" + "pendingRequestCount": { + "readOnly": true, + "type": "string", + "description": "Output only. The number of requests that are still pending processing.", + "format": "int64" }, - "details": { - "type": "array", - "items": { - "type": "object", - "additionalProperties": { - "description": "Properties of the object. Contains field @type with type URL." - } - }, - "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use." + "requestCount": { + "description": "Output only. The number of requests in the batch.", + "format": "int64", + "readOnly": true, + "type": "string" } }, - "type": "object" + "description": "Stats about the batch." }, - "UsageMetadata": { + "TuningSnapshot": { + "description": "Record for a single tuning step.", + "type": "object", "properties": { - "candidatesTokenCount": { - "description": "Total number of tokens across all the generated response candidates.", + "meanLoss": { + "description": "Output only. The mean loss of the training examples for this step.", + "format": "float", + "readOnly": true, + "type": "number" + }, + "step": { + "description": "Output only. The tuning step.", "format": "int32", + "readOnly": true, "type": "integer" }, - "toolUsePromptTokenCount": { - "type": "integer", + "epoch": { "readOnly": true, - "description": "Output only. Number of tokens present in tool-use prompt(s).", - "format": "int32" - }, - "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.", + "description": "Output only. The epoch this step was part of.", "format": "int32" }, - "serviceTier": { - "x-enum-descriptions": [ - "Default service tier, which is standard.", - "Standard service tier.", - "Flex service tier.", - "Priority service tier." - ], + "computeTime": { + "description": "Output only. The timestamp when this metric was computed.", + "format": "google-datetime", "readOnly": true, - "enum": [ - "unspecified", - "standard", - "flex", - "priority" - ], - "type": "string", - "description": "Output only. Service tier of the request." - }, - "thoughtsTokenCount": { - "type": "integer", - "readOnly": true, - "description": "Output only. Number of tokens of thoughts for thinking models.", - "format": "int32" - }, - "cacheTokensDetails": { - "type": "array", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - }, - "description": "Output only. List of modalities of the cached content in the request input.", - "readOnly": true - }, - "cachedContentTokenCount": { - "description": "Number of tokens in the cached part of the prompt (the cached content)", - "format": "int32", - "type": "integer" - }, - "totalTokenCount": { - "description": "Total token count for the generation request (prompt + thoughts + response candidates).", - "format": "int32", - "type": "integer" - }, - "promptTokensDetails": { - "description": "Output only. List of modalities that were processed in the request input.", - "readOnly": true, - "type": "array", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - } - }, - "toolUsePromptTokensDetails": { - "type": "array", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - }, - "description": "Output only. List of modalities that were processed for tool-use request inputs.", - "readOnly": true - }, - "candidatesTokensDetails": { - "description": "Output only. List of modalities that were returned in the response.", - "readOnly": true, - "type": "array", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - } + "type": "string" + } + } + }, + "ResponseFormatConfig": { + "type": "object", + "properties": { + "audio": { + "description": "Optional. Audio output format configuration.", + "$ref": "#/components/schemas/AudioResponseFormat" }, - "responseTokenCount": { - "description": "Output only. Number of tokens in the response. Used by Gemini 3.1+ Live API models instead of candidatesTokenCount.", - "type": "integer", - "format": "int32", - "readOnly": true + "image": { + "description": "Optional. Image output format configuration.", + "$ref": "#/components/schemas/ImageResponseFormat" }, - "responseTokensDetails": { - "description": "Output only. List of modalities returned in the response with per-modality token counts. Used by Gemini 3.1+ Live API models instead of candidatesTokensDetails.", + "text": { + "description": "Optional. Text output format configuration.", + "$ref": "#/components/schemas/TextResponseFormat" + } + }, + "description": "Configuration for the response output format. This is a flat object where each optional sub-field configures a specific output modality." + }, + "GroundingChunkStringList": { + "properties": { + "values": { + "description": "The string values of the list.", "type": "array", - "readOnly": true, "items": { - "$ref": "#/components/schemas/ModalityTokenCount" + "type": "string" } } }, "type": "object", - "description": "Metadata on the generation request's token usage." + "description": "A list of string values." }, - "EmbeddingUsageMetadata": { - "type": "object", + "BatchEmbedContentsRequest": { + "description": "Batch request to get embeddings from the model for a list of prompts.", "properties": { - "promptTokenCount": { - "readOnly": true, - "description": "Output only. Number of tokens in the prompt.", - "format": "int32", - "type": "integer" - }, - "promptTokenDetails": { - "description": "Output only. List of modalities that were processed in the request input.", - "readOnly": true, + "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/ModalityTokenCount" + "$ref": "#/components/schemas/EmbedContentRequest" } } }, - "description": "Metadata on the usage of the embedding request." - }, - "LogprobsResultCandidate": { - "description": "Candidate for the logprobs token and score.", - "type": "object", - "properties": { - "logProbability": { - "description": "The candidate's log probability.", - "format": "float", - "type": "number" - }, - "token": { - "description": "The candidate\u2019s token string value.", - "type": "string" - }, - "tokenId": { - "type": "integer", - "description": "The candidate\u2019s token id value.", - "format": "int32" - } - } + "type": "object" }, - "GroundingChunkCustomMetadata": { - "description": "User provided metadata about the GroundingFact.", + "TextResponseFormat": { "properties": { - "key": { - "description": "The key of the metadata.", - "type": "string" - }, - "stringValue": { - "description": "Optional. The string value of the metadata.", + "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." + ], + "enum": [ + "MIME_TYPE_UNSPECIFIED", + "APPLICATION_JSON", + "TEXT_PLAIN" + ], "type": "string" }, - "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" + "schema": { + "description": "Optional. The JSON schema that the output should conform to. Only applicable when mime_type is APPLICATION_JSON." } }, - "type": "object" + "type": "object", + "description": "Configuration for text output format." }, - "FunctionCall": { + "UrlMetadata": { "type": "object", "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.", + "retrievedUrl": { + "description": "Retrieved url by the tool.", "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`.", + "urlRetrievalStatus": { + "description": "Status of the url retrieval.", + "x-enum-descriptions": [ + "Default value. This value is unused.", + "Url retrieval is successful.", + "Url retrieval is failed due to error.", + "Url retrieval is failed because the content is behind paywall.", + "Url retrieval is failed because the content is unsafe." + ], + "enum": [ + "URL_RETRIEVAL_STATUS_UNSPECIFIED", + "URL_RETRIEVAL_STATUS_SUCCESS", + "URL_RETRIEVAL_STATUS_ERROR", + "URL_RETRIEVAL_STATUS_PAYWALL", + "URL_RETRIEVAL_STATUS_UNSAFE" + ], "type": "string" } }, - "description": "A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values." + "description": "Context of the a single url retrieval." }, - "WhiteSpaceConfig": { - "description": "Configuration for a white space chunking algorithm [white space delimited].", + "EmbedContentBatchOutput": { "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" + "inlinedResponses": { + "description": "Output only. The responses to the requests in the batch. Returned when the batch was built using inlined requests. The responses will be in the same order as the input requests.", + "$ref": "#/components/schemas/InlinedEmbedContentResponses", + "readOnly": true }, - "maxOverlapTokens": { - "type": "integer", - "description": "Maximum number of overlapping tokens between two adjacent chunks.", - "format": "int32" + "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." } }, - "type": "object" + "type": "object", + "description": "The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field." }, - "InlinedRequests": { + "UrlContextMetadata": { "type": "object", "properties": { - "requests": { + "urlMetadata": { "type": "array", "items": { - "$ref": "#/components/schemas/InlinedRequest" + "$ref": "#/components/schemas/UrlMetadata" }, - "description": "Required. The requests to be processed in the batch." + "description": "List of url context." } }, - "description": "The requests to be processed in the batch if provided as part of the batch creation request." + "description": "Metadata related to url context retrieval tool." }, - "CachedContentUsageMetadata": { - "description": "Metadata on the usage of the cached content.", + "Blob": { "type": "object", "properties": { - "totalTokenCount": { - "description": "Total number of tokens that the cached content consumes.", - "format": "int32", - "type": "integer" + "mimeType": { + "description": "The IANA standard MIME type of the source data. Examples of supported types: - Images: image/png, image/jpeg, image/jpg, image/webp, image/heic, image/heif, image/gif, image/avif - Audio: audio/*, video/audio/s16le, video/audio/wav - Video: video/* - Text: text/plain, text/html, text/css, text/javascript, text/x-typescript, text/csv, text/markdown, text/x-python, text/xml, text/rtf, video/text/timestamp - Applications: application/x-javascript, application/x-typescript, application/x-python-code, application/json, application/x-ipynb+json, application/rtf, application/pdf For additional context, see [Supported file formats](https://ai.google.dev/gemini-api/docs/file-input-methods#supported-content-types). //", + "type": "string" + }, + "data": { + "description": "Raw bytes for media formats.", + "format": "byte", + "type": "string" } - } + }, + "description": "Raw media bytes. Text should not be sent as raw bytes, use the 'text' field." }, - "TransferOwnershipResponse": { + "GenerateContentBatch": { "type": "object", - "properties": {}, - "description": "Response from `TransferOwnership`." - }, - "SafetySetting": { - "description": "Safety setting, affecting the safety-blocking behavior. Passing a safety setting for a category changes the allowed probability that content is blocked.", "properties": { - "category": { - "enum": [ - "HARM_CATEGORY_UNSPECIFIED", - "HARM_CATEGORY_DEROGATORY", - "HARM_CATEGORY_TOXICITY", - "HARM_CATEGORY_VIOLENCE", - "HARM_CATEGORY_SEXUAL", - "HARM_CATEGORY_MEDICAL", - "HARM_CATEGORY_DANGEROUS", - "HARM_CATEGORY_HARASSMENT", - "HARM_CATEGORY_HATE_SPEECH", - "HARM_CATEGORY_SEXUALLY_EXPLICIT", - "HARM_CATEGORY_DANGEROUS_CONTENT", - "HARM_CATEGORY_CIVIC_INTEGRITY" - ], - "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.", - "type": "string", - "enumDeprecated": [ - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - true - ] - }, - "threshold": { - "description": "Required. Controls the probability threshold at which harm is blocked.", - "enum": [ - "HARM_BLOCK_THRESHOLD_UNSPECIFIED", - "BLOCK_LOW_AND_ABOVE", - "BLOCK_MEDIUM_AND_ABOVE", - "BLOCK_ONLY_HIGH", - "BLOCK_NONE", - "OFF" - ], - "type": "string", - "x-enum-descriptions": [ - "Threshold is unspecified.", - "Content with NEGLIGIBLE will be allowed.", - "Content with NEGLIGIBLE and LOW will be allowed.", - "Content with NEGLIGIBLE, LOW, and MEDIUM will be allowed.", - "All content will be allowed.", - "Turn off the safety filter." - ] - } - }, - "type": "object" - }, - "TuningExample": { - "description": "A single example for tuning.", - "type": "object", - "properties": { - "textInput": { - "description": "Optional. Text model input.", + "model": { + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "type": "string" }, - "output": { - "description": "Required. The expected model output.", - "type": "string" - } - } - }, - "StringList": { - "type": "object", - "properties": { - "values": { - "items": { - "type": "string" - }, - "type": "array", - "description": "The string values of the metadata to store." - } - }, - "description": "User provided string values assigned to a single metadata key." - }, - "TransferOwnershipRequest": { - "description": "Request to transfer the ownership of the tuned model.", - "properties": { - "emailAddress": { - "description": "Required. The email address of the user to whom the tuned model is being transferred to.", - "type": "string" - } - }, - "type": "object" - }, - "CachedContent": { - "description": "Content that has been preprocessed and can be used in subsequent request to GenerativeService. Cached content can be only used with model it was created for.", - "properties": { - "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" + "inputConfig": { + "description": "Required. Input configuration of the instances on which batch processing are performed.", + "$ref": "#/components/schemas/InputConfig" }, - "model": { - "description": "Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}`", + "updateTime": { + "description": "Output only. The time at which the batch was last updated.", + "format": "google-datetime", + "readOnly": true, "type": "string" }, - "updateTime": { + "state": { + "readOnly": true, "type": "string", + "description": "Output only. The state of the batch.", + "x-enum-descriptions": [ + "The batch state is unspecified.", + "The service is preparing to run the batch.", + "The batch is in progress.", + "The batch completed successfully.", + "The batch failed.", + "The batch has been cancelled.", + "The batch has expired." + ], + "enum": [ + "BATCH_STATE_UNSPECIFIED", + "BATCH_STATE_PENDING", + "BATCH_STATE_RUNNING", + "BATCH_STATE_SUCCEEDED", + "BATCH_STATE_FAILED", + "BATCH_STATE_CANCELLED", + "BATCH_STATE_EXPIRED" + ] + }, + "endTime": { "readOnly": true, - "description": "Output only. When the cache entry was last updated in UTC time.", + "type": "string", + "description": "Output only. The time at which the batch processing completed.", "format": "google-datetime" }, - "ttl": { - "description": "Input only. New TTL for this resource, input only.", - "format": "google-duration", - "type": "string" - }, - "name": { - "type": "string", - "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`", + "batchStats": { + "description": "Output only. Stats about the batch.", + "$ref": "#/components/schemas/BatchStats", "readOnly": true }, - "tools": { - "description": "Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response", - "items": { - "$ref": "#/components/schemas/Tool" - }, - "type": "array" - }, "displayName": { - "description": "Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters.", + "description": "Required. The user-defined name of this batch.", "type": "string" }, - "toolConfig": { - "description": "Optional. Input only. Immutable. Tool config. This config is shared for all tools.", - "$ref": "#/components/schemas/ToolConfig" - }, - "createTime": { + "name": { + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", "readOnly": true, - "description": "Output only. Creation time of the cache entry.", - "format": "google-datetime", "type": "string" }, - "usageMetadata": { + "createTime": { + "description": "Output only. The time at which the batch was created.", + "format": "google-datetime", "readOnly": true, - "$ref": "#/components/schemas/CachedContentUsageMetadata", - "description": "Output only. Metadata on the usage of the cached content." + "type": "string" }, - "systemInstruction": { - "$ref": "#/components/schemas/Content", - "description": "Optional. Input only. Immutable. Developer set system instruction. Currently text only." + "output": { + "description": "Output only. The output of the batch request.", + "$ref": "#/components/schemas/GenerateContentBatchOutput", + "readOnly": true }, - "contents": { - "description": "Optional. Input only. Immutable. The content to cache.", - "type": "array", - "items": { - "$ref": "#/components/schemas/Content" - } + "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" } }, - "type": "object" + "description": "A resource representing a batch of `GenerateContent` requests." }, - "Corpus": { - "description": "A `Corpus` is a collection of `Document`s. A project can create up to 10 corpora.", + "SearchEntryPoint": { + "description": "Google search entry point.", "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\"", - "type": "string" - }, - "name": { - "readOnly": true, - "description": "Output only. Immutable. Identifier. The `Corpus` resource name. The ID (name excluding the \"corpora/\" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `corpora/my-awesome-corpora-123a456b789c`", + "renderedContent": { + "description": "Optional. Web content snippet that can be embedded in a web page or an app webview.", "type": "string" }, - "createTime": { - "type": "string", - "description": "Output only. The Timestamp of when the `Corpus` was created.", - "format": "google-datetime", - "readOnly": true - }, - "updateTime": { + "sdkBlob": { "type": "string", - "readOnly": true, - "description": "Output only. The Timestamp of when the `Corpus` was last updated.", - "format": "google-datetime" + "description": "Optional. Base64 encoded JSON representing array of tuple.", + "format": "byte" } }, "type": "object" }, - "CountTokensRequest": { - "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`.", + "AttributionSourceId": { + "type": "object", "properties": { - "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" + "groundingPassage": { + "description": "Identifier for an inline passage.", + "$ref": "#/components/schemas/GroundingPassageId" }, - "contents": { - "type": "array", - "items": { - "$ref": "#/components/schemas/Content" - }, - "description": "Optional. The input given to the model as a prompt. This field is ignored when `generate_content_request` is set." + "semanticRetrieverChunk": { + "description": "Identifier for a `Chunk` fetched via Semantic Retriever.", + "$ref": "#/components/schemas/SemanticRetrieverChunk" } }, - "type": "object" + "description": "Identifier for the source contributing to this attribution." }, - "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.", + "Document": { + "description": "A `Document` is a collection of `Chunk`s.", "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" - }, - "response": { - "$ref": "#/components/schemas/Schema", - "description": "Optional. Describes the output from this function in JSON Schema format. Reflects the Open API 3.03 Response Object. The Schema defines the type used for the response value of the function." - }, - "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`." + "sizeBytes": { + "readOnly": true, + "type": "string", + "description": "Output only. The size of raw bytes ingested into the Document.", + "format": "int64" }, - "description": { - "description": "Required. A brief description of the function.", + "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" }, - "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`." + "createTime": { + "readOnly": true, + "type": "string", + "description": "Output only. The Timestamp of when the `Document` was created.", + "format": "google-datetime" }, - "behavior": { + "state": { + "description": "Output only. Current state of the `Document`.", "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." + "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": [ - "UNSPECIFIED", - "BLOCKING", - "NON_BLOCKING" + "STATE_UNSPECIFIED", + "STATE_PENDING", + "STATE_ACTIVE", + "STATE_FAILED" ], - "description": "Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method." + "readOnly": true, + "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" - } - }, - "type": "object" - }, - "SemanticRetrieverChunk": { - "description": "Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`.", - "type": "object", - "properties": { - "source": { - "type": "string", + "customMetadata": { + "description": "Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`.", + "type": "array", + "items": { + "$ref": "#/components/schemas/CustomMetadata" + } + }, + "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" + }, + "mimeType": { + "description": "Output only. The mime type of the Document.", "readOnly": true, - "description": "Output only. Name of the source matching the request's `SemanticRetrieverConfig.source`. Example: `corpora/123` or `corpora/123/documents/abc`" + "type": "string" }, - "chunk": { - "description": "Output only. Name of the `Chunk` containing the attributed text. Example: `corpora/123/documents/abc/chunks/xyz`", + "updateTime": { + "description": "Output only. The Timestamp of when the `Document` was last updated.", + "format": "google-datetime", "readOnly": true, "type": "string" } - } + }, + "type": "object" }, - "Schema": { + "Part": { + "description": "A datatype containing media that is part of a multi-part `Content` message. A `Part` consists of data which has an associated datatype. A `Part` can only contain one of the accepted types in `Part.data`. A `Part` must have a fixed IANA MIME type identifying the type and subtype of the media if the `inline_data` field is filled with raw bytes.", "properties": { - "minLength": { - "type": "string", - "description": "Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING", - "format": "int64" + "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" }, - "minProperties": { - "type": "string", - "description": "Optional. Minimum number of the properties for Type.OBJECT.", - "format": "int64" + "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" }, - "description": { - "description": "Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown.", - "type": "string" + "executableCode": { + "description": "Code generated by the model that is meant to be executed.", + "$ref": "#/components/schemas/ExecutableCode" }, - "nullable": { - "description": "Optional. Indicates if the value may be null.", + "thought": { + "description": "Optional. Indicates if the part is thought from the model.", "type": "boolean" }, - "pattern": { - "description": "Optional. Pattern of the Type.STRING to restrict a string to a regular expression.", - "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" }, - "required": { - "type": "array", - "items": { - "type": "string" - }, - "description": "Optional. Required properties of Type.OBJECT." + "inlineData": { + "description": "Inline media bytes.", + "$ref": "#/components/schemas/Blob" }, - "minItems": { + "thoughtSignature": { "type": "string", - "description": "Optional. Minimum number of the elements for Type.ARRAY.", - "format": "int64" - }, - "default": { - "description": "Optional. Default value of the field. Per JSON Schema, this field is intended for documentation generators and doesn't affect validation. Thus it's included here and ignored so that developers who send schemas with a `default` field don't get unknown-field errors." - }, - "enum": { - "items": { - "type": "string" - }, - "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\"]}" - }, - "maximum": { - "type": "number", - "description": "Optional. Maximum value of the Type.INTEGER and Type.NUMBER", - "format": "double" - }, - "title": { - "description": "Optional. The title of the schema.", - "type": "string" - }, - "anyOf": { - "description": "Optional. The value should be validated against any (one or more) of the subschemas in the list.", - "type": "array", - "items": { - "$ref": "#/components/schemas/Schema" - } + "description": "Optional. An opaque signature for the thought so it can be reused in subsequent requests.", + "format": "byte" }, - "maxLength": { - "type": "string", - "description": "Optional. Maximum length of the Type.STRING", - "format": "int64" + "mediaResolution": { + "description": "Optional. Media resolution for the input media.", + "$ref": "#/components/schemas/MediaResolution" }, - "format": { - "description": "Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality.", - "type": "string" + "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" }, - "maxProperties": { - "description": "Optional. Maximum number of the properties for Type.OBJECT.", - "format": "int64", + "text": { + "description": "Inline text.", "type": "string" }, - "example": { - "description": "Optional. Example of the object. Will only populated when the object is the root." + "fileData": { + "description": "URI based data.", + "$ref": "#/components/schemas/FileData" }, - "propertyOrdering": { - "items": { - "type": "string" + "partMetadata": { + "additionalProperties": { + "description": "Properties of the object." }, - "type": "array", - "description": "Optional. The order of the properties. Not a standard field in open api spec. Used to determine the order of the properties in the response." - }, - "minimum": { - "type": "number", - "description": "Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER", - "format": "double" - }, - "items": { - "$ref": "#/components/schemas/Schema", - "description": "Optional. Schema of the elements of Type.ARRAY." - }, - "maxItems": { - "type": "string", - "description": "Optional. Maximum number of the elements for Type.ARRAY.", - "format": "int64" + "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" }, - "properties": { - "type": "object", - "description": "Optional. Properties of Type.OBJECT.", - "additionalProperties": { - "$ref": "#/components/schemas/Schema" - } + "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" }, - "type": { - "description": "Required. Data type.", - "enum": [ - "TYPE_UNSPECIFIED", - "STRING", - "NUMBER", - "INTEGER", - "BOOLEAN", - "ARRAY", - "OBJECT", - "NULL" - ], - "type": "string", - "x-enum-descriptions": [ - "Not specified, should not be used.", - "String type.", - "Number type.", - "Integer type.", - "Boolean type.", - "Array type.", - "Object type.", - "Null type." - ] + "codeExecutionResult": { + "description": "Result of executing the `ExecutableCode`.", + "$ref": "#/components/schemas/CodeExecutionResult" } }, - "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)." + "type": "object" }, - "ListCorporaResponse": { - "description": "Response from `ListCorpora` containing a paginated list of `Corpora`. The results are sorted by ascending `corpus.create_time`.", + "EmbeddingUsageMetadata": { "type": "object", "properties": { - "corpora": { - "items": { - "$ref": "#/components/schemas/Corpus" - }, - "type": "array", - "description": "The returned corpora." + "promptTokenCount": { + "description": "Output only. Number of tokens in the prompt.", + "format": "int32", + "readOnly": true, + "type": "integer" }, - "nextPageToken": { - "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", - "type": "string" + "promptTokenDetails": { + "description": "Output only. List of modalities that were processed in the request input.", + "readOnly": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + } } - } + }, + "description": "Metadata on the usage of the embedding request." }, - "ListFileSearchStoresResponse": { - "type": "object", + "FunctionCallingConfig": { "properties": { - "fileSearchStores": { - "description": "The returned rag_stores.", - "items": { - "$ref": "#/components/schemas/FileSearchStore" - }, - "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 more pages.", + "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\"." + ], + "enum": [ + "MODE_UNSPECIFIED", + "AUTO", + "ANY", + "NONE", + "VALIDATED" + ], "type": "string" + }, + "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" + } } }, - "description": "Response from `ListFileSearchStores` containing a paginated list of `FileSearchStores`. The results are sorted by ascending `file_search_store.create_time`." + "type": "object", + "description": "Configuration for specifying function calling behavior." }, - "Web": { - "description": "Chunk from the web.", + "GoogleSearchRetrieval": { + "description": "Tool to retrieve public web data for grounding, powered by Google.", + "properties": { + "dynamicRetrievalConfig": { + "description": "Specifies the dynamic retrieval configuration for the given source.", + "$ref": "#/components/schemas/DynamicRetrievalConfig" + } + }, + "type": "object" + }, + "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": { - "title": { - "type": "string", - "description": "Output only. Title of the chunk.", - "readOnly": true + "retirementTime": { + "description": "The time at which the model will be retired.", + "format": "google-datetime", + "type": "string" }, - "uri": { - "type": "string", - "readOnly": true, - "description": "Output only. URI reference of the chunk." + "modelStage": { + "enumDeprecated": [ + false, + true, + false, + false, + false, + false, + true, + false + ], + "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." + ], + "enum": [ + "MODEL_STAGE_UNSPECIFIED", + "UNSTABLE_EXPERIMENTAL", + "EXPERIMENTAL", + "PREVIEW", + "STABLE", + "LEGACY", + "DEPRECATED", + "RETIRED" + ], + "type": "string" + }, + "message": { + "description": "A message explaining the model status.", + "type": "string" } } }, - "FileSearch": { - "description": "The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API.", + "StringList": { + "description": "User provided string values assigned to a single metadata key.", "type": "object", "properties": { - "topK": { - "description": "Optional. The number of semantic retrieval chunks to retrieve.", - "format": "int32", - "type": "integer" - }, - "fileSearchStoreNames": { + "values": { + "description": "The string values of the metadata to store.", "type": "array", "items": { "type": "string" - }, - "description": "Required. The names of the file_search_stores to retrieve from. Example: `fileSearchStores/my-file-search-store-123`" - }, - "metadataFilter": { - "description": "Optional. Metadata filter to apply to the semantic retrieval documents and chunks.", - "type": "string" + } } } }, - "EmbedContentBatchOutput": { - "type": "object", + "Candidate": { + "description": "A response candidate generated from the model.", "properties": { - "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.", + "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." + ], + "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" + ], "readOnly": true, - "$ref": "#/components/schemas/InlinedEmbedContentResponses" + "type": "string" }, - "responsesFile": { + "avgLogprobs": { + "description": "Output only. Average log probability score of the candidate.", + "format": "double", + "readOnly": true, + "type": "number" + }, + "logprobsResult": { + "readOnly": true, + "description": "Output only. Log-likelihood scores for the response tokens and top tokens", + "$ref": "#/components/schemas/LogprobsResult" + }, + "index": { + "description": "Output only. Index of the candidate in the list of response candidates.", + "format": "int32", + "readOnly": true, + "type": "integer" + }, + "groundingMetadata": { + "description": "Output only. Grounding metadata for the candidate. This field is populated for `GenerateContent` calls.", + "$ref": "#/components/schemas/GroundingMetadata", + "readOnly": true + }, + "finishMessage": { + "readOnly": true, "type": "string", - "description": "Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `EmbedContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests.", + "description": "Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set." + }, + "tokenCount": { + "description": "Output only. Token count for this candidate.", + "format": "int32", + "readOnly": true, + "type": "integer" + }, + "content": { + "description": "Output only. Generated content returned from the model.", + "$ref": "#/components/schemas/Content", "readOnly": true - } - }, - "description": "The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field." - }, - "Maps": { - "type": "object", - "properties": { - "text": { - "description": "Text description of the place answer.", - "type": "string" }, - "placeId": { - "description": "The ID of the place, in `places/{place_id}` format. A user can use this ID to look up that place.", - "type": "string" + "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." }, - "title": { - "description": "Title of the place.", - "type": "string" + "citationMetadata": { + "readOnly": true, + "description": "Output only. Citation information for model-generated candidate. This field may be populated with recitation information for any text included in the `content`. These are passages that are \"recited\" from copyrighted material in the foundational LLM's training data.", + "$ref": "#/components/schemas/CitationMetadata" }, - "placeAnswerSources": { - "$ref": "#/components/schemas/PlaceAnswerSources", - "description": "Sources that provide answers about the features of a given place in Google Maps." + "urlContextMetadata": { + "description": "Output only. Metadata related to url context retrieval tool.", + "$ref": "#/components/schemas/UrlContextMetadata", + "readOnly": true }, - "uri": { - "description": "URI reference of the place.", - "type": "string" - } - }, - "description": "A grounding chunk from Google Maps. A Maps chunk corresponds to a single place." - }, - "GoogleSearchRetrieval": { - "properties": { - "dynamicRetrievalConfig": { - "description": "Specifies the dynamic retrieval configuration for the given source.", - "$ref": "#/components/schemas/DynamicRetrievalConfig" + "safetyRatings": { + "type": "array", + "items": { + "$ref": "#/components/schemas/SafetyRating" + }, + "description": "List of ratings for the safety of a response candidate. There is at most one rating per category." } }, - "type": "object", - "description": "Tool to retrieve public web data for grounding, powered by Google." + "type": "object" }, - "GroundingAttribution": { + "RegisterFilesResponse": { + "description": "Response for `RegisterFiles`.", "type": "object", "properties": { - "sourceId": { - "description": "Output only. Identifier for the source contributing to this attribution.", - "readOnly": true, - "$ref": "#/components/schemas/AttributionSourceId" - }, - "content": { - "description": "Grounding source content that makes up this attribution.", - "$ref": "#/components/schemas/Content" + "files": { + "type": "array", + "items": { + "$ref": "#/components/schemas/File" + }, + "description": "The registered files to be used when calling GenerateContent." } - }, - "description": "Attribution for a source that contributed to an answer." + } }, - "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", + "FunctionResponsePart": { + "description": "A datatype containing media that is part of a `FunctionResponse` message. A `FunctionResponsePart` consists of data which has an associated datatype. A `FunctionResponsePart` can only contain one of the accepted types in `FunctionResponsePart.data`. A `FunctionResponsePart` must have a fixed IANA MIME type identifying the type and subtype of the media if the `inline_data` field is filled with raw bytes.", "properties": { - "whiteSpaceConfig": { - "description": "White space chunking configuration.", - "$ref": "#/components/schemas/WhiteSpaceConfig" + "inlineData": { + "description": "Inline media bytes.", + "$ref": "#/components/schemas/FunctionResponseBlob" } }, "type": "object" }, - "RetrievalConfig": { + "ReviewSnippet": { + "description": "Encapsulates a snippet of a user review that answers a question about the features of a specific place in Google Maps.", + "type": "object", "properties": { - "latLng": { - "description": "Optional. The location of the user.", - "$ref": "#/components/schemas/LatLng" + "reviewId": { + "description": "The ID of the review snippet.", + "type": "string" }, - "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).", + "googleMapsUri": { + "description": "A link that corresponds to the user review on Google Maps.", + "type": "string" + }, + "title": { + "description": "Title of the review.", "type": "string" } - }, - "type": "object", - "description": "Retrieval config." + } }, - "AudioResponseFormat": { + "CustomMetadata": { + "description": "User provided metadata stored as key-value pairs.", + "type": "object", "properties": { - "bitRate": { - "type": "integer", - "description": "Optional. Bit rate in bits per second (bps). Only applicable for compressed formats (MP3, Opus).", - "format": "int32" - }, - "mimeType": { - "type": "string", - "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." - ], - "description": "Optional. The MIME type of the audio output.", - "enum": [ - "MIME_TYPE_UNSPECIFIED", - "AUDIO_MP3", - "AUDIO_OGG_OPUS", - "AUDIO_L16", - "AUDIO_WAV", - "AUDIO_ALAW", - "AUDIO_MULAW" - ] - }, - "sampleRate": { - "description": "Optional. Sample rate in Hz.", - "format": "int32", - "type": "integer" - }, - "delivery": { - "description": "Optional. The delivery mode for the audio output.", - "enum": [ - "DELIVERY_UNSPECIFIED", - "INLINE", - "URI" - ], - "type": "string", - "x-enum-descriptions": [ - "Default value. This value is unused.", - "Audio data is returned inline in the response.", - "Audio data is returned as a URI." - ] - } - }, - "type": "object", - "description": "Configuration for audio output format." - }, - "EmbedContentRequest": { - "properties": { - "content": { - "$ref": "#/components/schemas/Content", - "description": "Required. The content to embed. Only the `parts.text` fields will be counted." - }, - "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, + "key": { + "description": "Required. The key of the metadata to store.", "type": "string" }, - "taskType": { - "enum": [ - "TASK_TYPE_UNSPECIFIED", - "RETRIEVAL_QUERY", - "RETRIEVAL_DOCUMENT", - "SEMANTIC_SIMILARITY", - "CLASSIFICATION", - "CLUSTERING", - "QUESTION_ANSWERING", - "FACT_VERIFICATION", - "CODE_RETRIEVAL_QUERY" - ], - "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." - ], - "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`).", - "type": "string" + "stringListValue": { + "description": "The StringList value of the metadata to store.", + "$ref": "#/components/schemas/StringList" }, - "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}`", + "stringValue": { + "description": "The string value of the metadata to store.", "type": "string" }, - "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`).", - "deprecated": true, - "format": "int32", - "type": "integer" - }, - "embedContentConfig": { - "description": "Optional. Configuration for the EmbedContent request.", - "$ref": "#/components/schemas/EmbedContentConfig" + "numericValue": { + "description": "The numeric value of the metadata to store.", + "format": "float", + "type": "number" } - }, - "type": "object", - "description": "Request containing the `Content` for the model to embed." + } }, - "Permission": { - "description": "Permission resource grants user, group or the rest of the world access to the PaLM API resource (e.g. a tuned model, corpus). A role is a collection of permitted operations that allows users to perform specific actions on PaLM API resources. To make them available to users, groups, or service accounts, you assign roles. When you assign a role, you grant permissions that the role contains. There are three concentric roles. Each role is a superset of the previous role's permitted operations: - reader can use the resource (e.g. tuned model, corpus) for inference - writer has reader's permissions and additionally can edit and share - owner has writer's permissions and additionally can delete", + "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": { - "granteeType": { - "enum": [ - "GRANTEE_TYPE_UNSPECIFIED", - "USER", - "GROUP", - "EVERYONE" - ], - "description": "Optional. Immutable. The type of the grantee.", - "x-enum-descriptions": [ - "The default value. This value is unused.", - "Represents a user. When set, you must provide email_address for the user.", - "Represents a group. When set, you must provide email_address for the group.", - "Represents access to everyone. No extra information is required." - ], + "id": { + "description": "Optional. The identifier of the tool call this response is for.", "type": "string" }, - "name": { + "toolType": { "type": "string", - "readOnly": true, - "description": "Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only." - }, - "emailAddress": { - "description": "Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE.", - "type": "string" - }, - "role": { + "description": "Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`.", "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" - ], - "description": "Required. The role granted by this permission." - } - }, - "type": "object" - }, - "ListPermissionsResponse": { - "description": "Response from `ListPermissions` containing a paginated list of permissions.", - "type": "object", - "properties": { - "permissions": { - "items": { - "$ref": "#/components/schemas/Permission" - }, - "type": "array", - "description": "Returned permissions." + "TOOL_TYPE_UNSPECIFIED", + "GOOGLE_SEARCH_WEB", + "GOOGLE_SEARCH_IMAGE", + "URL_CONTEXT", + "GOOGLE_MAPS", + "FILE_SEARCH" + ] }, - "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" + "response": { + "type": "object", + "additionalProperties": { + "description": "Properties of the object." + }, + "description": "Optional. The tool response." } } }, - "LogprobsResult": { - "description": "Logprobs Result", + "TuningExamples": { + "description": "A set of tuning examples. Can be training or validation data.", "type": "object", "properties": { - "logProbabilitySum": { - "description": "Sum of log probabilities for all tokens.", - "format": "float", - "type": "number" - }, - "topCandidates": { - "description": "Length = total number of decoding steps.", - "items": { - "$ref": "#/components/schemas/TopCandidates" - }, - "type": "array" - }, - "chosenCandidates": { - "description": "Length = total number of decoding steps. The chosen candidates may or may not be in top_candidates.", + "examples": { + "type": "array", "items": { - "$ref": "#/components/schemas/LogprobsResultCandidate" + "$ref": "#/components/schemas/TuningExample" }, - "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." } } }, - "InlinedEmbedContentRequest": { - "description": "The request to be processed in the batch.", + "Web": { + "description": "Chunk from the web.", "type": "object", "properties": { - "request": { - "description": "Required. The request to be processed in the batch.", - "$ref": "#/components/schemas/EmbedContentRequest" + "uri": { + "readOnly": true, + "type": "string", + "description": "Output only. URI reference of the chunk." }, - "metadata": { - "type": "object", - "description": "Optional. The metadata to be associated with the request.", - "additionalProperties": { - "description": "Properties of the object." - } + "title": { + "readOnly": true, + "type": "string", + "description": "Output only. Title of the chunk." } } }, - "EmbedContentBatch": { - "type": "object", + "TunedModel": { + "description": "A fine-tuned model created using ModelService.CreateTunedModel.", "properties": { - "model": { - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "state": { + "readOnly": true, + "type": "string", + "description": "Output only. The state of the tuned model.", + "x-enum-descriptions": [ + "The default value. This value is unused.", + "The model is being created.", + "The model is ready to be used.", + "The model failed to be created." + ], + "enum": [ + "STATE_UNSPECIFIED", + "CREATING", + "ACTIVE", + "FAILED" + ] + }, + "tuningTask": { + "description": "Required. The tuning task that creates the tuned model.", + "$ref": "#/components/schemas/TuningTask" + }, + "topK": { + "description": "Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model.", + "format": "int32", + "type": "integer" + }, + "baseModel": { + "description": "Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001`", "type": "string" }, "updateTime": { - "type": "string", - "description": "Output only. The time at which the batch was last updated.", + "description": "Output only. The timestamp when this model was updated.", "format": "google-datetime", - "readOnly": true - }, - "state": { - "description": "Output only. The state of the batch.", - "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" - ], - "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" }, - "inputConfig": { - "$ref": "#/components/schemas/InputEmbedContentConfig", - "description": "Required. Input configuration of the instances on which batch processing are performed." + "readerProjectNumbers": { + "type": "array", + "items": { + "type": "string", + "format": "int64" + }, + "description": "Optional. List of project numbers that have read access to the tuned model." }, - "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", + "tunedModelSource": { + "description": "Optional. TunedModel to use as the starting point for training the new model.", + "$ref": "#/components/schemas/TunedModelSource" + }, + "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" + }, + "description": { + "description": "Optional. A short description of this model.", "type": "string" }, - "endTime": { - "type": "string", - "description": "Output only. The time at which the batch processing completed.", - "format": "google-datetime", - "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" }, "name": { - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_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`", "readOnly": true, "type": "string" }, + "createTime": { + "readOnly": true, + "type": "string", + "description": "Output only. The timestamp when this model was created.", + "format": "google-datetime" + }, "displayName": { - "description": "Required. The user-defined name of this batch.", + "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" + } + }, + "type": "object" + }, + "Dataset": { + "properties": { + "examples": { + "description": "Optional. Inline examples with simple input/output text.", + "$ref": "#/components/schemas/TuningExamples" + } + }, + "type": "object", + "description": "Dataset for training or validation." + }, + "TransferOwnershipRequest": { + "description": "Request to transfer the ownership of the tuned model.", + "type": "object", + "properties": { + "emailAddress": { + "description": "Required. The email address of the user to whom the tuned model is being transferred to.", + "type": "string" + } + } + }, + "Corpus": { + "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\"", "type": "string" }, - "output": { + "updateTime": { "readOnly": true, - "$ref": "#/components/schemas/EmbedContentBatchOutput", - "description": "Output only. The output of the batch request." + "type": "string", + "description": "Output only. The Timestamp of when the `Corpus` was last updated.", + "format": "google-datetime" }, - "batchStats": { - "description": "Output only. Stats about the batch.", + "name": { + "description": "Output only. Immutable. Identifier. The `Corpus` resource name. The ID (name excluding the \"corpora/\" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `corpora/my-awesome-corpora-123a456b789c`", "readOnly": true, - "$ref": "#/components/schemas/EmbedContentBatchStats" + "type": "string" }, "createTime": { - "readOnly": true, - "description": "Output only. The time at which the batch was created.", + "description": "Output only. The Timestamp of when the `Corpus` was created.", "format": "google-datetime", + "readOnly": true, "type": "string" } }, - "description": "A resource representing a batch of `EmbedContent` requests." + "type": "object", + "description": "A `Corpus` is a collection of `Document`s. A project can create up to 10 corpora." }, - "PromptFeedback": { + "ListOperationsResponse": { + "description": "The response message for Operations.ListOperations.", "properties": { - "blockReason": { - "enum": [ - "BLOCK_REASON_UNSPECIFIED", - "SAFETY", - "OTHER", - "BLOCKLIST", - "PROHIBITED_CONTENT", - "IMAGE_SAFETY" - ], - "description": "Optional. If set, the prompt was blocked and no candidates are returned. Rephrase the prompt.", - "x-enum-descriptions": [ - "Default value. This value is unused.", - "Prompt was blocked due to safety reasons. Inspect `safety_ratings` to understand which safety category blocked it.", - "Prompt was blocked due to unknown reasons.", - "Prompt was blocked due to the terms which are included from the terminology blocklist.", - "Prompt was blocked due to prohibited content.", - "Candidates blocked due to unsafe image generation content." - ], - "type": "string" - }, - "safetyRatings": { + "unreachable": { + "description": "Unordered list. Unreachable resources. Populated when the request sets `ListOperationsRequest.return_partial_success` and reads across collections. For example, when attempting to list all resources across all supported locations.", + "type": "array", "items": { - "$ref": "#/components/schemas/SafetyRating" - }, + "type": "string" + } + }, + "operations": { + "description": "A list of operations that matches the specified filter in the request.", "type": "array", - "description": "Ratings for safety of the prompt. There is at most one rating per category." + "items": { + "$ref": "#/components/schemas/Operation" + } + }, + "nextPageToken": { + "description": "The standard List next-page token.", + "type": "string" } }, - "type": "object", - "description": "A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`." + "type": "object" }, - "ListDocumentsResponse": { - "description": "Response from `ListDocuments` containing a paginated list of `Document`s. The `Document`s are sorted by ascending `document.create_time`.", + "SemanticRetrieverChunk": { + "description": "Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`.", "type": "object", "properties": { - "documents": { - "description": "The returned `Document`s.", - "items": { - "$ref": "#/components/schemas/Document" - }, - "type": "array" + "source": { + "description": "Output only. Name of the source matching the request's `SemanticRetrieverConfig.source`. Example: `corpora/123` or `corpora/123/documents/abc`", + "readOnly": true, + "type": "string" }, - "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.", + "chunk": { + "description": "Output only. Name of the `Chunk` containing the attributed text. Example: `corpora/123/documents/abc/chunks/xyz`", + "readOnly": true, "type": "string" } } }, - "ToolResponse": { + "Permission": { + "description": "Permission resource grants user, group or the rest of the world access to the PaLM API resource (e.g. a tuned model, corpus). A role is a collection of permitted operations that allows users to perform specific actions on PaLM API resources. To make them available to users, groups, or service accounts, you assign roles. When you assign a role, you grant permissions that the role contains. There are three concentric roles. Each role is a superset of the previous role's permitted operations: - reader can use the resource (e.g. tuned model, corpus) for inference - writer has reader's permissions and additionally can edit and share - owner has writer's permissions and additionally can delete", "type": "object", "properties": { - "id": { - "description": "Optional. The identifier of the tool call this response is for.", + "emailAddress": { + "description": "Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE.", "type": "string" }, - "toolType": { + "role": { + "description": "Required. The role granted by this permission.", + "x-enum-descriptions": [ + "The default value. This value is unused.", + "Owner can use, update, share and delete the resource.", + "Writer can use, update and share the resource.", + "Reader can use the resource." + ], "enum": [ - "TOOL_TYPE_UNSPECIFIED", - "GOOGLE_SEARCH_WEB", - "GOOGLE_SEARCH_IMAGE", - "URL_CONTEXT", - "GOOGLE_MAPS", - "FILE_SEARCH" + "ROLE_UNSPECIFIED", + "OWNER", + "WRITER", + "READER" ], - "description": "Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`.", + "type": "string" + }, + "granteeType": { + "description": "Optional. Immutable. The type of the grantee.", "x-enum-descriptions": [ - "Unspecified tool type.", - "Google search tool, maps to Tool.google_search.search_types.web_search.", - "Image search tool, maps to Tool.google_search.search_types.image_search.", - "URL context tool, maps to Tool.url_context.", - "Google maps tool, maps to Tool.google_maps.", - "File search tool, maps to Tool.file_search." + "The default value. This value is unused.", + "Represents a user. When set, you must provide email_address for the user.", + "Represents a group. When set, you must provide email_address for the group.", + "Represents access to everyone. No extra information is required." + ], + "enum": [ + "GRANTEE_TYPE_UNSPECIFIED", + "USER", + "GROUP", + "EVERYONE" ], "type": "string" }, - "response": { - "type": "object", - "description": "Optional. The tool response.", - "additionalProperties": { - "description": "Properties of the object." - } + "name": { + "description": "Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.", + "readOnly": true, + "type": "string" } - }, - "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`." + } }, - "GoogleSearch": { - "description": "GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google.", - "type": "object", + "LatLng": { + "description": "An object that represents a latitude/longitude pair. This is expressed as a pair of doubles to represent degrees latitude and degrees longitude. Unless specified otherwise, this object must conform to the WGS84 standard. Values must be within normalized ranges.", "properties": { - "timeRangeFilter": { - "$ref": "#/components/schemas/Interval", - "description": "Optional. Filter search results to a specific time range. If customers set a start time, they must set an end time (and vice versa)." + "longitude": { + "description": "The longitude in degrees. It must be in the range [-180.0, +180.0].", + "format": "double", + "type": "number" }, - "searchTypes": { - "$ref": "#/components/schemas/SearchTypes", - "description": "Optional. The set of search types to enable. If not set, web search is enabled by default." + "latitude": { + "description": "The latitude in degrees. It must be in the range [-90.0, +90.0].", + "format": "double", + "type": "number" } - } + }, + "type": "object" }, - "ReviewSnippet": { + "ListCachedContentsResponse": { "type": "object", "properties": { - "title": { - "description": "Title of the review.", - "type": "string" - }, - "reviewId": { - "description": "The ID of the review snippet.", - "type": "string" + "cachedContents": { + "description": "List of cached contents.", + "type": "array", + "items": { + "$ref": "#/components/schemas/CachedContent" + } }, - "googleMapsUri": { - "description": "A link that corresponds to the user review on Google Maps.", + "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": "Encapsulates a snippet of a user review that answers a question about the features of a specific place in Google Maps." + "description": "Response with CachedContents list." }, - "ComputerUse": { + "ToolConfig": { + "description": "The Tool configuration containing parameters for specifying `Tool` use in the request.", + "type": "object", "properties": { - "disabledSafetyPolicies": { - "type": "array", - "items": { - "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." - ], - "type": "string", - "enum": [ - "SAFETY_POLICY_UNSPECIFIED", - "FINANCIAL_TRANSACTIONS", - "SENSITIVE_DATA_MODIFICATION", - "COMMUNICATION_TOOL", - "ACCOUNT_CREATION", - "DATA_MODIFICATION", - "USER_CONSENT_MANAGEMENT", - "LEGAL_TERMS_AND_AGREEMENTS" - ] - }, - "description": "Optional. Disabled safety policies for computer use." - }, - "enablePromptInjectionDetection": { - "description": "Optional. Whether enable the prompt injection detection check on computer-use request.", + "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" }, - "excludedPredefinedFunctions": { - "type": "array", - "items": { - "type": "string" - }, - "description": "Optional. By default, predefined functions are included in the final model call. Some of them can be explicitly excluded from being automatically included. This can serve two purposes: 1. Using a more restricted / different action space. 2. Improving the definitions / instructions of predefined functions." + "functionCallingConfig": { + "description": "Optional. Function calling config.", + "$ref": "#/components/schemas/FunctionCallingConfig" }, - "environment": { + "retrievalConfig": { + "description": "Optional. Retrieval config.", + "$ref": "#/components/schemas/RetrievalConfig" + } + } + }, + "EmbedContentRequest": { + "description": "Request containing the `Content` for the model to embed.", + "properties": { + "content": { + "description": "Required. The content to embed. Only the `parts.text` fields will be counted.", + "$ref": "#/components/schemas/Content" + }, + "embedContentConfig": { + "description": "Optional. Configuration for the EmbedContent request.", + "$ref": "#/components/schemas/EmbedContentConfig" + }, + "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" + }, + "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", + "deprecated": true, + "type": "integer" + }, + "title": { + "deprecated": true, + "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." + }, + "taskType": { + "deprecated": true, + "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": [ - "Defaults to browser.", - "Operates in a web browser.", - "Operates in a mobile environment.", - "Operates in a desktop environment." + "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", "enum": [ - "ENVIRONMENT_UNSPECIFIED", - "ENVIRONMENT_BROWSER", - "ENVIRONMENT_MOBILE", - "ENVIRONMENT_DESKTOP" - ], - "description": "Required. The environment being operated." + "TASK_TYPE_UNSPECIFIED", + "RETRIEVAL_QUERY", + "RETRIEVAL_DOCUMENT", + "SEMANTIC_SIMILARITY", + "CLASSIFICATION", + "CLUSTERING", + "QUESTION_ANSWERING", + "FACT_VERIFICATION", + "CODE_RETRIEVAL_QUERY" + ] } }, - "type": "object", - "description": "Computer Use tool type." + "type": "object" }, - "ListOperationsResponse": { - "description": "The response message for Operations.ListOperations.", + "Model": { + "description": "Information about a Generative Language Model.", "type": "object", "properties": { - "nextPageToken": { - "description": "The standard List next-page token.", + "name": { + "description": "Required. The resource name of the `Model`. Refer to [Model variants](https://ai.google.dev/gemini-api/docs/models/gemini#model-variations) for all allowed values. Format: `models/{model}` with a `{model}` naming convention of: * \"{base_model_id}-{version}\" Examples: * `models/gemini-1.5-flash-001`", "type": "string" }, - "unreachable": { - "description": "Unordered list. Unreachable resources. Populated when the request sets `ListOperationsRequest.return_partial_success` and reads across collections. For example, when attempting to list all resources across all supported locations.", - "items": { - "type": "string" - }, - "type": "array" + "inputTokenLimit": { + "type": "integer", + "description": "Maximum number of input tokens allowed for this model.", + "format": "int32" }, - "operations": { - "items": { - "$ref": "#/components/schemas/Operation" - }, - "type": "array", - "description": "A list of operations that matches the specified filter in the request." - } - } - }, - "ListFilesResponse": { - "description": "Response for `ListFiles`.", - "type": "object", - "properties": { - "files": { + "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" + }, + "supportedGenerationMethods": { "type": "array", "items": { - "$ref": "#/components/schemas/File" + "type": "string" }, - "description": "The list of `File`s." + "description": "The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`." }, - "nextPageToken": { - "description": "A token that can be sent as a `page_token` into a subsequent `ListFiles` call.", + "description": { + "description": "A short description of the model.", "type": "string" - } - } - }, - "Hyperparameters": { - "description": "Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance", - "properties": { - "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" }, - "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" - }, - "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.", + "topP": { + "description": "For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model.", "format": "float", "type": "number" }, - "batchSize": { - "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", - "type": "integer" - } - }, - "type": "object" - }, - "Empty": { - "properties": {}, - "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); }" - }, - "InputEmbedContentConfig": { - "properties": { - "fileName": { - "description": "The name of the `File` containing the input requests.", + "version": { + "description": "Required. The version number of the model. This represents the major version (`1.0` or `1.5`)", "type": "string" }, - "requests": { - "description": "The requests to be processed in the batch.", - "$ref": "#/components/schemas/InlinedEmbedContentRequests" - } - }, - "type": "object", - "description": "Configures the input to the batch request." - }, - "EmbedContentResponse": { - "type": "object", - "properties": { - "embedding": { - "description": "Output only. The embedding generated from the input content.", - "readOnly": true, - "$ref": "#/components/schemas/ContentEmbedding" + "maxTemperature": { + "type": "number", + "description": "The maximum temperature this model can use.", + "format": "float" }, - "usageMetadata": { - "description": "Output only. The usage metadata for the request.", - "readOnly": true, - "$ref": "#/components/schemas/EmbeddingUsageMetadata" - } - }, - "description": "The response to an `EmbedContentRequest`." - }, - "CreateFileRequest": { - "description": "Request for `CreateFile`.", - "properties": { - "file": { - "$ref": "#/components/schemas/File", - "description": "Optional. Metadata for the file to create." + "temperature": { + "type": "number", + "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" + }, + "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" + }, + "outputTokenLimit": { + "type": "integer", + "description": "Maximum number of output tokens available for this model.", + "format": "int32" + }, + "baseModelId": { + "description": "Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash`", + "type": "string" } - }, - "type": "object" + } }, - "ListGeneratedFilesResponse": { + "ContentEmbedding": { + "type": "object", "properties": { - "generatedFiles": { - "description": "The list of `GeneratedFile`s.", + "shape": { + "description": "This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048]).", "type": "array", "items": { - "$ref": "#/components/schemas/GeneratedFile" + "type": "integer", + "format": "int32" } }, - "nextPageToken": { - "description": "A token that can be sent as a `page_token` into a subsequent `ListGeneratedFiles` call.", - "type": "string" + "values": { + "description": "The embedding values. This is for 3P users only and will not be populated for 1P calls.", + "type": "array", + "items": { + "type": "number", + "format": "float" + } } }, - "type": "object", - "description": "Response for `ListGeneratedFiles`." + "description": "A list of floats representing an embedding." }, - "InlinedEmbedContentResponses": { - "description": "The responses to the requests in the batch.", + "ImageResponseFormat": { "type": "object", "properties": { - "inlinedResponses": { - "readOnly": true, - "description": "Output only. The responses to the requests in the batch.", - "items": { - "$ref": "#/components/schemas/InlinedEmbedContentResponse" - }, - "type": "array" - } - } - }, - "CitationSource": { - "type": "object", - "properties": { - "uri": { - "description": "Optional. URI that is attributed as a source for a portion of the text.", - "type": "string" - }, - "endIndex": { - "description": "Optional. End of the attributed segment, exclusive.", - "format": "int32", - "type": "integer" - }, - "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" + "mimeType": { + "type": "string", + "description": "Optional. The MIME type of the image output.", + "x-enum-descriptions": [ + "Default value. This value is unused.", + "JPEG image format." + ], + "enum": [ + "MIME_TYPE_UNSPECIFIED", + "IMAGE_JPEG" + ] }, - "license": { - "description": "Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations.", + "delivery": { + "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." + ], + "enum": [ + "DELIVERY_UNSPECIFIED", + "INLINE", + "URI" + ], "type": "string" - } - }, - "description": "A citation to a source for a portion of a specific response." - }, - "GroundingPassageId": { - "type": "object", - "properties": { - "passageId": { + }, + "imageSize": { "type": "string", - "readOnly": true, - "description": "Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`." + "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." + ], + "enum": [ + "IMAGE_SIZE_UNSPECIFIED", + "IMAGE_SIZE_FIVE_TWELVE", + "IMAGE_SIZE_ONE_K", + "IMAGE_SIZE_TWO_K", + "IMAGE_SIZE_FOUR_K" + ] }, - "partIndex": { - "description": "Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`.", - "format": "int32", - "readOnly": true, - "type": "integer" + "aspectRatio": { + "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." + ], + "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" + ], + "type": "string" } }, - "description": "Identifier for a part within a `GroundingPassage`." + "description": "Configuration for image output format." }, - "VideoMetadata": { - "description": "Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content.", + "RetrievalMetadata": { + "description": "Metadata related to retrieval in the grounding flow.", "properties": { - "endOffset": { - "type": "string", - "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].", - "format": "double", + "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" - }, - "startOffset": { - "type": "string", - "description": "Optional. The start offset of the video.", - "format": "google-duration" } }, - "type": "object", - "deprecated": true + "type": "object" }, - "ListCachedContentsResponse": { - "description": "Response with CachedContents list.", + "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": { - "cachedContents": { - "description": "List of cached contents.", + "googleSearchRetrieval": { + "description": "Optional. Retrieval tool that is powered by Google search.", + "$ref": "#/components/schemas/GoogleSearchRetrieval" + }, + "codeExecution": { + "description": "Optional. Enables the model to execute code as part of generation.", + "$ref": "#/components/schemas/CodeExecution" + }, + "urlContext": { + "description": "Optional. Tool to support URL context retrieval.", + "$ref": "#/components/schemas/UrlContext" + }, + "fileSearch": { + "description": "Optional. FileSearch tool type. Tool to retrieve knowledge from Semantic Retrieval corpora.", + "$ref": "#/components/schemas/FileSearch" + }, + "functionDeclarations": { + "type": "array", "items": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/FunctionDeclaration" }, - "type": "array" + "description": "Optional. A list of `FunctionDeclarations` available to the model that can be used for function calling. The model or system does not execute the function. Instead the defined function may be returned as a FunctionCall with arguments to the client side for execution. The model may decide to call a subset of these functions by populating FunctionCall in the response. The next conversation turn may contain a FunctionResponse with the Content.role \"function\" generation context for the next model turn." }, - "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" + "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" + }, + "googleMaps": { + "description": "Optional. Tool that allows grounding the model's response with geospatial context related to the user's query.", + "$ref": "#/components/schemas/GoogleMaps" + }, + "computerUse": { + "description": "Optional. Tool to support the model interacting directly with the computer. If enabled, it automatically populates computer-use specific Function Declarations.", + "$ref": "#/components/schemas/ComputerUse" } } }, - "InlinedEmbedContentResponse": { - "type": "object", + "GoogleAiGenerativelanguageV1betaGroundingSupport": { + "description": "Grounding support.", "properties": { - "error": { - "readOnly": true, - "$ref": "#/components/schemas/Status", - "description": "Output only. The error encountered while processing the request." + "segment": { + "description": "Segment of the content this support belongs to.", + "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaSegment" }, - "metadata": { - "type": "object", + "confidenceScores": { + "type": "array", + "items": { + "type": "number", + "format": "float" + }, + "description": "Optional. Confidence score of the support references. Ranges from 0 to 1. 1 is the most confident. This list must have the same size as the grounding_chunk_indices." + }, + "renderedParts": { + "description": "Output only. Indices into the `parts` field of the candidate's content. These indices specify which rendered parts are associated with this support source.", "readOnly": true, - "description": "Output only. The metadata associated with the request.", - "additionalProperties": { - "description": "Properties of the object." + "type": "array", + "items": { + "type": "integer", + "format": "int32" } }, - "response": { - "readOnly": true, - "$ref": "#/components/schemas/EmbedContentResponse", - "description": "Output only. The response to the request." - } - }, - "description": "The response to a single request in the batch." - }, - "RetrievalMetadata": { - "description": "Metadata related to retrieval in the grounding flow.", - "properties": { - "googleSearchDynamicRetrievalScore": { - "type": "number", - "description": "Optional. Score indicating how likely information from google search could help answer the prompt. The score is in the range [0, 1], where 0 is the least likely and 1 is the most likely. This score is only populated when google search grounding and dynamic retrieval is enabled. It will be compared to the threshold to determine whether to trigger google search.", - "format": "float" + "groundingChunkIndices": { + "type": "array", + "items": { + "type": "integer", + "format": "int32" + }, + "description": "Optional. A list of indices (into 'grounding_chunk' in `response.candidate.grounding_metadata`) specifying the citations associated with the claim. For instance [1,3,4] means that grounding_chunk[1], grounding_chunk[3], grounding_chunk[4] are the retrieved content attributed to the claim. If the response is streaming, the grounding_chunk_indices refer to the indices across all responses. It is the client's responsibility to accumulate the grounding chunks from all responses (while maintaining the same order)." } }, "type": "object" }, - "TuningTask": { - "description": "Tuning tasks that create tuned models.", + "EmbedContentBatchStats": { + "description": "Stats about the batch.", "properties": { - "snapshots": { + "successfulRequestCount": { + "description": "Output only. The number of requests that were successfully processed.", + "format": "int64", "readOnly": true, - "description": "Output only. Metrics collected during tuning.", - "items": { - "$ref": "#/components/schemas/TuningSnapshot" - }, - "type": "array" + "type": "string" }, - "completeTime": { - "type": "string", + "pendingRequestCount": { "readOnly": true, - "description": "Output only. The timestamp when tuning this model completed.", - "format": "google-datetime" + "type": "string", + "description": "Output only. The number of requests that are still pending processing.", + "format": "int64" }, - "startTime": { - "description": "Output only. The timestamp when tuning this model started.", - "format": "google-datetime", + "requestCount": { + "description": "Output only. The number of requests in the batch.", + "format": "int64", "readOnly": true, "type": "string" }, - "trainingData": { - "description": "Required. Input only. Immutable. The model training data.", - "$ref": "#/components/schemas/Dataset" - }, - "hyperparameters": { - "description": "Immutable. Hyperparameters controlling the tuning process. If not provided, default values will be used.", - "$ref": "#/components/schemas/Hyperparameters" - } - }, - "type": "object" - }, - "Document": { + "failedRequestCount": { + "readOnly": true, + "type": "string", + "description": "Output only. The number of requests that failed to be processed.", + "format": "int64" + } + }, + "type": "object" + }, + "StreamableHttpTransport": { + "description": "A transport that can stream HTTP requests and responses. Next ID: 6", "type": "object", "properties": { - "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" - }, - "state": { - "description": "Output only. Current state of the `Document`.", + "timeout": { "type": "string", - "readOnly": true, - "enum": [ - "STATE_UNSPECIFIED", - "STATE_PENDING", - "STATE_ACTIVE", - "STATE_FAILED" - ], - "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." - ] - }, - "mimeType": { - "readOnly": true, - "description": "Output only. The mime type of the Document.", - "type": "string" + "description": "HTTP timeout for regular operations.", + "format": "google-duration" }, - "name": { - "description": "Immutable. Identifier. The `Document` resource name. The ID (name excluding the \"fileSearchStores/*/documents/\" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/{file_search_store_id}/documents/my-awesome-doc-123a456b789c`", - "type": "string" + "terminateOnClose": { + "description": "Whether to close the client session when the transport closes.", + "type": "boolean" }, - "updateTime": { + "sseReadTimeout": { "type": "string", - "readOnly": true, - "description": "Output only. The Timestamp of when the `Document` was last updated.", - "format": "google-datetime" + "description": "Timeout for SSE read operations.", + "format": "google-duration" }, - "customMetadata": { - "description": "Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`.", - "type": "array", - "items": { - "$ref": "#/components/schemas/CustomMetadata" + "headers": { + "type": "object", + "description": "Optional: Fields for authentication headers, timeouts, etc., if needed.", + "additionalProperties": { + "type": "string" } }, - "sizeBytes": { - "description": "Output only. The size of raw bytes ingested into the Document.", - "format": "int64", - "readOnly": true, - "type": "string" - }, - "createTime": { - "description": "Output only. The Timestamp of when the `Document` was created.", - "format": "google-datetime", - "readOnly": true, + "url": { + "description": "The full URL for the MCPServer endpoint. Example: \"https://api.example.com/mcp\"", "type": "string" } - }, - "description": "A `Document` is a collection of `Chunk`s." + } }, - "InlinedResponses": { - "type": "object", + "ToolCall": { "properties": { - "inlinedResponses": { - "items": { - "$ref": "#/components/schemas/InlinedResponse" + "id": { + "description": "Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`.", + "type": "string" + }, + "toolType": { + "description": "Required. The type of tool that was called.", + "x-enum-descriptions": [ + "Unspecified tool type.", + "Google search tool, maps to Tool.google_search.search_types.web_search.", + "Image search tool, maps to Tool.google_search.search_types.image_search.", + "URL context tool, maps to Tool.url_context.", + "Google maps tool, maps to Tool.google_maps.", + "File search tool, maps to Tool.file_search." + ], + "enum": [ + "TOOL_TYPE_UNSPECIFIED", + "GOOGLE_SEARCH_WEB", + "GOOGLE_SEARCH_IMAGE", + "URL_CONTEXT", + "GOOGLE_MAPS", + "FILE_SEARCH" + ], + "type": "string" + }, + "args": { + "type": "object", + "additionalProperties": { + "description": "Properties of the object." }, - "type": "array", - "readOnly": true, - "description": "Output only. The responses to the requests in the batch." + "description": "Optional. The tool call arguments. Example: {\"arg1\" : \"value1\", \"arg2\" : \"value2\" , ...}" } }, - "description": "The responses to the requests in the batch." + "type": "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`." }, - "SearchTypes": { - "description": "Different types of search that can be enabled on the GoogleSearch tool.", + "Maps": { "properties": { - "imageSearch": { - "description": "Optional. Enables image search. Image bytes are returned.", - "$ref": "#/components/schemas/ImageSearch" + "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" }, - "webSearch": { - "description": "Optional. Enables web search. Only text results are returned.", - "$ref": "#/components/schemas/WebSearch" - } - }, - "type": "object" - }, - "WebSearch": { - "description": "Standard web search for grounding and related configurations.", - "properties": {}, - "type": "object" - }, - "TuningExamples": { - "description": "A set of tuning examples. Can be training or validation data.", - "properties": { - "examples": { - "description": "The examples. Example input can be for text or discuss, but all examples in a set must be of the same type.", - "type": "array", - "items": { - "$ref": "#/components/schemas/TuningExample" - } + "placeAnswerSources": { + "description": "Sources that provide answers about the features of a given place in Google Maps.", + "$ref": "#/components/schemas/PlaceAnswerSources" + }, + "uri": { + "description": "URI reference of the place.", + "type": "string" + }, + "title": { + "description": "Title of the place.", + "type": "string" + }, + "text": { + "description": "Text description of the place answer.", + "type": "string" } }, - "type": "object" + "type": "object", + "description": "A grounding chunk from Google Maps. A Maps chunk corresponds to a single place." }, - "EmbedContentBatchStats": { - "description": "Stats about the batch.", + "EmbedContentBatch": { + "description": "A resource representing a batch of `EmbedContent` requests.", + "type": "object", "properties": { - "requestCount": { - "readOnly": true, - "description": "Output only. The number of requests in the batch.", - "format": "int64", + "model": { + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "type": "string" }, - "successfulRequestCount": { + "inputConfig": { + "description": "Required. Input configuration of the instances on which batch processing are performed.", + "$ref": "#/components/schemas/InputEmbedContentConfig" + }, + "updateTime": { + "readOnly": true, "type": "string", - "description": "Output only. The number of requests that were successfully processed.", - "format": "int64", + "description": "Output only. The time at which the batch was last updated.", + "format": "google-datetime" + }, + "state": { + "description": "Output only. The state of the batch.", + "x-enum-descriptions": [ + "The batch state is unspecified.", + "The service is preparing to run the batch.", + "The batch is in progress.", + "The batch completed successfully.", + "The batch failed.", + "The batch has been cancelled.", + "The batch has expired." + ], + "enum": [ + "BATCH_STATE_UNSPECIFIED", + "BATCH_STATE_PENDING", + "BATCH_STATE_RUNNING", + "BATCH_STATE_SUCCEEDED", + "BATCH_STATE_FAILED", + "BATCH_STATE_CANCELLED", + "BATCH_STATE_EXPIRED" + ], + "readOnly": true, + "type": "string" + }, + "endTime": { + "description": "Output only. The time at which the batch processing completed.", + "format": "google-datetime", + "readOnly": true, + "type": "string" + }, + "batchStats": { + "description": "Output only. Stats about the batch.", + "$ref": "#/components/schemas/EmbedContentBatchStats", "readOnly": true }, - "failedRequestCount": { - "type": "string", + "displayName": { + "description": "Required. The user-defined name of this batch.", + "type": "string" + }, + "name": { + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", "readOnly": true, - "description": "Output only. The number of requests that failed to be processed.", - "format": "int64" + "type": "string" }, - "pendingRequestCount": { + "createTime": { + "readOnly": true, "type": "string", - "description": "Output only. The number of requests that are still pending processing.", + "description": "Output only. The time at which the batch was created.", + "format": "google-datetime" + }, + "output": { + "readOnly": true, + "description": "Output only. The output of the batch request.", + "$ref": "#/components/schemas/EmbedContentBatchOutput" + }, + "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", - "readOnly": true + "type": "string" } - }, - "type": "object" + } }, - "ModalityTokenCount": { - "description": "Represents token counting info for a single modality.", + "File": { + "description": "A file uploaded to the API. Next ID: 15", + "type": "object", "properties": { - "tokenCount": { - "description": "Number of tokens.", - "format": "int32", - "type": "integer" + "sha256Hash": { + "readOnly": true, + "type": "string", + "description": "Output only. SHA-256 hash of the uploaded bytes.", + "format": "byte" }, - "modality": { - "description": "The modality associated with this token count.", - "enum": [ - "MODALITY_UNSPECIFIED", - "TEXT", - "IMAGE", - "VIDEO", - "AUDIO", - "DOCUMENT" + "state": { + "readOnly": true, + "type": "string", + "description": "Output only. Processing state of the File.", + "x-enum-descriptions": [ + "The default value. This value is used if the state is omitted.", + "File is being processed and cannot be used for inference yet.", + "File is processed and available for inference.", + "File failed processing." ], + "enum": [ + "STATE_UNSPECIFIED", + "PROCESSING", + "ACTIVE", + "FAILED" + ] + }, + "updateTime": { + "readOnly": true, + "type": "string", + "description": "Output only. The timestamp of when the `File` was last updated.", + "format": "google-datetime" + }, + "uri": { + "readOnly": true, "type": "string", + "description": "Output only. The uri of the `File`." + }, + "downloadUri": { + "description": "Output only. The download uri of the `File`.", + "readOnly": true, + "type": "string" + }, + "sizeBytes": { + "description": "Output only. Size of the file in bytes.", + "format": "int64", + "readOnly": true, + "type": "string" + }, + "error": { + "readOnly": true, + "description": "Output only. Error status if File processing failed.", + "$ref": "#/components/schemas/Status" + }, + "mimeType": { + "readOnly": true, + "type": "string", + "description": "Output only. MIME type of the file." + }, + "source": { + "description": "Source of the File.", "x-enum-descriptions": [ - "Unspecified modality.", - "Plain text.", - "Image.", - "Video.", - "Audio.", - "Document, e.g. PDF." + "Used if source is not specified.", + "Indicates the file is uploaded by the user.", + "Indicates the file is generated by Google.", + "Indicates the file is a registered, i.e. a Google Cloud Storage file." + ], + "enum": [ + "SOURCE_UNSPECIFIED", + "UPLOADED", + "GENERATED", + "REGISTERED" + ], + "type": "string" + }, + "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" + }, + "createTime": { + "description": "Output only. The timestamp of when the `File` was created.", + "format": "google-datetime", + "readOnly": true, + "type": "string" + }, + "videoMetadata": { + "description": "Output only. Metadata for a video.", + "$ref": "#/components/schemas/VideoFileMetadata", + "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" + }, + "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", + "readOnly": true, + "type": "string" + } + } + }, + "GenerationConfig": { + "description": "Configuration options for model generation and outputs. Not all parameters are configurable for every model.", + "type": "object", + "properties": { + "temperature": { + "type": "number", + "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" + }, + "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" + }, + "seed": { + "type": "integer", + "description": "Optional. Seed used in decoding. If not set, the request uses a randomly generated seed.", + "format": "int32" + }, + "topP": { + "type": "number", + "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" + }, + "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" + }, + "enableEnhancedCivicAnswers": { + "description": "Optional. Enables enhanced civic answers. It may not be available for all models.", + "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.", + "type": "array", + "items": { + "type": "string" + } + }, + "candidateCount": { + "description": "Optional. Number of generated responses to return. If unset, this will default to 1. Please note that this doesn't work for previous generation models (Gemini 1.0 family)", + "format": "int32", + "type": "integer" + }, + "maxOutputTokens": { + "type": "integer", + "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" + }, + "topK": { + "type": "integer", + "description": "Optional. The maximum number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests.", + "format": "int32" + }, + "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" + }, + "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" + }, + "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" + }, + "speechConfig": { + "description": "Optional. The speech generation config.", + "$ref": "#/components/schemas/SpeechConfig" + }, + "translationConfig": { + "description": "Optional. Config for translation.", + "$ref": "#/components/schemas/TranslationConfig" + }, + "logprobs": { + "type": "integer", + "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" + }, + "responseSchema": { + "description": "Optional. Output schema of the generated candidate text. Schemas must be a subset of the [OpenAPI schema](https://spec.openapis.org/oas/v3.0.3#schema) and can be objects, primitives or arrays. If set, a compatible `response_mime_type` must also be set. Compatible MIME types: `application/json`: Schema for JSON response. Refer to the [JSON text generation guide](https://ai.google.dev/gemini-api/docs/json-mode) for more details.", + "$ref": "#/components/schemas/Schema" + }, + "responseLogprobs": { + "description": "Optional. If true, export the logprobs results in response.", + "type": "boolean" + }, + "imageConfig": { + "description": "Optional. Config for image generation. An error will be returned if this field is set for models that don't support these config options.", + "$ref": "#/components/schemas/ImageConfig" + }, + "responseJsonSchema": { + "description": "Optional. An internal detail. Use `responseJsonSchema` rather than this field." + }, + "responseModalities": { + "type": "array", + "items": { + "x-enum-descriptions": [ + "Default value.", + "Indicates the model should return text.", + "Indicates the model should return images.", + "Indicates the model should return audio.", + "Indicates the model should return video." + ], + "enum": [ + "MODALITY_UNSPECIFIED", + "TEXT", + "IMAGE", + "AUDIO", + "VIDEO" + ], + "type": "string" + }, + "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." + }, + "mediaResolution": { + "type": "string", + "description": "Optional. If specified, the media resolution specified will be used.", + "x-enum-descriptions": [ + "Media resolution has not been set.", + "Media resolution set to low (64 tokens).", + "Media resolution set to medium (256 tokens).", + "Media resolution set to high (zoomed reframing with 256 tokens)." + ], + "enum": [ + "MEDIA_RESOLUTION_UNSPECIFIED", + "MEDIA_RESOLUTION_LOW", + "MEDIA_RESOLUTION_MEDIUM", + "MEDIA_RESOLUTION_HIGH" ] } + } + }, + "InlinedEmbedContentRequests": { + "description": "The requests to be processed in the batch if provided as part of the batch creation request.", + "properties": { + "requests": { + "description": "Required. The requests to be processed in the batch.", + "type": "array", + "items": { + "$ref": "#/components/schemas/InlinedEmbedContentRequest" + } + } }, "type": "object" }, - "GroundingMetadata": { + "ListPermissionsResponse": { + "type": "object", "properties": { - "groundingSupports": { - "description": "List of grounding support.", + "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" + }, + "permissions": { + "description": "Returned permissions.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Permission" + } + } + }, + "description": "Response from `ListPermissions` containing a paginated list of permissions." + }, + "GenerateContentRequest": { + "type": "object", + "properties": { + "toolConfig": { + "description": "Optional. Tool configuration for any `Tool` specified in the request. Refer to the [Function calling guide](https://ai.google.dev/gemini-api/docs/function-calling#function_calling_mode) for a usage example.", + "$ref": "#/components/schemas/ToolConfig" + }, + "generationConfig": { + "description": "Optional. Configuration options for model generation and outputs.", + "$ref": "#/components/schemas/GenerationConfig" + }, + "serviceTier": { + "description": "Optional. The service tier of the request.", + "x-enum-descriptions": [ + "Default service tier, which is standard.", + "Standard service tier.", + "Flex service tier.", + "Priority service tier." + ], + "enum": [ + "unspecified", + "standard", + "flex", + "priority" + ], + "type": "string" + }, + "systemInstruction": { + "description": "Optional. Developer set [system instruction(s)](https://ai.google.dev/gemini-api/docs/system-instructions). Currently, text only.", + "$ref": "#/components/schemas/Content" + }, + "contents": { + "type": "array", + "items": { + "$ref": "#/components/schemas/Content" + }, + "description": "Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request." + }, + "tools": { + "description": "Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Tool" + } + }, + "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" + }, + "store": { + "description": "Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config.", + "type": "boolean" + }, + "model": { + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "type": "string" + }, + "safetySettings": { + "type": "array", + "items": { + "$ref": "#/components/schemas/SafetySetting" + }, + "description": "Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications." + } + }, + "description": "Request to generate a completion from the model." + }, + "VideoFileMetadata": { + "type": "object", + "properties": { + "videoDuration": { + "type": "string", + "description": "Duration of the video.", + "format": "google-duration" + } + }, + "description": "Metadata for a video `File`." + }, + "RegisterFilesRequest": { + "description": "Request for `RegisterFiles`.", + "properties": { + "uris": { + "type": "array", + "items": { + "type": "string" + }, + "description": "Required. The Google Cloud Storage URIs to register. Example: `gs://bucket/object`." + } + }, + "type": "object" + }, + "UploadToFileSearchStoreRequest": { + "description": "Request for `UploadToFileSearchStore`.", + "properties": { + "displayName": { + "description": "Optional. Display name of the created document.", + "type": "string" + }, + "customMetadata": { + "type": "array", + "items": { + "$ref": "#/components/schemas/CustomMetadata" + }, + "description": "Custom metadata to be associated with the data." + }, + "chunkingConfig": { + "description": "Optional. Config for telling the service how to chunk the data. If not provided, the service will use default parameters.", + "$ref": "#/components/schemas/ChunkingConfig" + }, + "mimeType": { + "description": "Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content.", + "type": "string" + } + }, + "type": "object" + }, + "Hyperparameters": { + "description": "Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance", + "type": "object", + "properties": { + "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" + }, + "learningRateMultiplier": { + "type": "number", + "description": "Optional. Immutable. The learning rate multiplier is used to calculate a final learning_rate based on the default (recommended) value. Actual learning rate := learning_rate_multiplier * default learning rate Default learning rate is dependent on base model and dataset size. If not set, a default of 1.0 will be used.", + "format": "float" + }, + "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" + }, + "epochCount": { + "type": "integer", + "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" + } + } + }, + "ImageSearch": { + "type": "object", + "properties": {}, + "description": "Image search for grounding and related configurations." + }, + "InlinedEmbedContentResponses": { + "description": "The responses to the requests in the batch.", + "type": "object", + "properties": { + "inlinedResponses": { + "description": "Output only. The responses to the requests in the batch.", + "readOnly": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/InlinedEmbedContentResponse" + } + } + } + }, + "ListModelsResponse": { + "type": "object", + "properties": { + "models": { + "description": "The returned Models.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Model" + } + }, + "nextPageToken": { + "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", + "type": "string" + } + }, + "description": "Response from `ListModel` containing a paginated list of Models." + }, + "Schema": { + "properties": { + "items": { + "description": "Optional. Schema of the elements of Type.ARRAY.", + "$ref": "#/components/schemas/Schema" + }, + "maxLength": { + "type": "string", + "description": "Optional. Maximum length of the Type.STRING", + "format": "int64" + }, + "maxProperties": { + "description": "Optional. Maximum number of the properties for Type.OBJECT.", + "format": "int64", + "type": "string" + }, + "title": { + "description": "Optional. The title of the schema.", + "type": "string" + }, + "maxItems": { + "description": "Optional. Maximum number of the elements for Type.ARRAY.", + "format": "int64", + "type": "string" + }, + "maximum": { + "type": "number", + "description": "Optional. Maximum value of the Type.INTEGER and Type.NUMBER", + "format": "double" + }, + "minLength": { + "type": "string", + "description": "Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING", + "format": "int64" + }, + "properties": { + "description": "Optional. Properties of Type.OBJECT.", + "additionalProperties": { + "$ref": "#/components/schemas/Schema" + }, + "type": "object" + }, + "minProperties": { + "type": "string", + "description": "Optional. Minimum number of the properties for Type.OBJECT.", + "format": "int64" + }, + "pattern": { + "description": "Optional. Pattern of the Type.STRING to restrict a string to a regular expression.", + "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." + }, + "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." + }, + "required": { + "description": "Optional. Required properties of Type.OBJECT.", + "type": "array", + "items": { + "type": "string" + } + }, + "type": { + "description": "Required. Data type.", + "x-enum-descriptions": [ + "Not specified, should not be used.", + "String type.", + "Number type.", + "Integer type.", + "Boolean type.", + "Array type.", + "Object type.", + "Null type." + ], + "enum": [ + "TYPE_UNSPECIFIED", + "STRING", + "NUMBER", + "INTEGER", + "BOOLEAN", + "ARRAY", + "OBJECT", + "NULL" + ], + "type": "string" + }, + "example": { + "description": "Optional. Example of the object. Will only populated when the object is the root." + }, + "propertyOrdering": { "type": "array", "items": { - "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaGroundingSupport" - } + "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." }, - "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.", + "minimum": { + "type": "number", + "description": "Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER", + "format": "double" + }, + "format": { + "description": "Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality.", "type": "string" }, - "searchEntryPoint": { - "$ref": "#/components/schemas/SearchEntryPoint", - "description": "Optional. Google search entry for the following-up web searches." + "nullable": { + "description": "Optional. Indicates if the value may be null.", + "type": "boolean" }, - "groundingChunks": { - "description": "List of supporting references retrieved from specified grounding source. When streaming, this only contains the grounding chunks that have not been included in the grounding metadata of previous responses.", - "items": { - "$ref": "#/components/schemas/GroundingChunk" - }, - "type": "array" + "minItems": { + "type": "string", + "description": "Optional. Minimum number of the elements for Type.ARRAY.", + "format": "int64" }, - "webSearchQueries": { - "description": "Web search queries for the following-up web search.", - "items": { - "type": "string" - }, - "type": "array" + "description": { + "description": "Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown.", + "type": "string" }, - "imageSearchQueries": { - "description": "Image search queries used for grounding.", + "enum": { "type": "array", "items": { "type": "string" - } - }, - "retrievalMetadata": { - "description": "Metadata related to retrieval in the grounding flow.", - "$ref": "#/components/schemas/RetrievalMetadata" + }, + "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": "object", - "description": "Metadata returned to client when grounding is enabled." + "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)." }, - "InputConfig": { - "description": "Configures the input to the batch request.", + "LogprobsResultCandidate": { + "description": "Candidate for the logprobs token and score.", "properties": { - "fileName": { - "description": "The name of the `File` containing the input requests.", + "tokenId": { + "type": "integer", + "description": "The candidate\u2019s token id value.", + "format": "int32" + }, + "token": { + "description": "The candidate\u2019s token string value.", "type": "string" }, - "requests": { - "$ref": "#/components/schemas/InlinedRequests", - "description": "The requests to be processed in the batch." + "logProbability": { + "type": "number", + "description": "The candidate's log probability.", + "format": "float" } }, "type": "object" }, - "Image": { - "type": "object", + "GroundingAttribution": { "properties": { - "sourceUri": { - "description": "The web page URI for attribution.", - "type": "string" - }, - "title": { - "description": "The title of the web page that the image is from.", - "type": "string" - }, - "imageUri": { - "description": "The image asset URL.", - "type": "string" + "content": { + "description": "Grounding source content that makes up this attribution.", + "$ref": "#/components/schemas/Content" }, - "domain": { - "description": "The root domain of the web page that the image is from, e.g. \"example.com\".", - "type": "string" + "sourceId": { + "description": "Output only. Identifier for the source contributing to this attribution.", + "$ref": "#/components/schemas/AttributionSourceId", + "readOnly": true } }, - "description": "Chunk from image search." - }, - "BatchStats": { - "description": "Stats about the batch.", "type": "object", + "description": "Attribution for a source that contributed to an answer." + }, + "GenerateContentBatchOutput": { "properties": { - "pendingRequestCount": { - "type": "string", - "readOnly": true, - "description": "Output only. The number of requests that are still pending processing.", - "format": "int64" - }, - "requestCount": { - "type": "string", - "description": "Output only. The number of requests in the batch.", - "format": "int64", - "readOnly": true - }, - "successfulRequestCount": { - "description": "Output only. The number of requests that were successfully processed.", - "format": "int64", + "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.", "readOnly": true, "type": "string" }, - "failedRequestCount": { + "inlinedResponses": { "readOnly": true, - "description": "Output only. The number of requests that failed to be processed.", - "format": "int64", - "type": "string" - } - } - }, - "AttributionSourceId": { - "properties": { - "semanticRetrieverChunk": { - "$ref": "#/components/schemas/SemanticRetrieverChunk", - "description": "Identifier for a `Chunk` fetched via Semantic Retriever." - }, - "groundingPassage": { - "$ref": "#/components/schemas/GroundingPassageId", - "description": "Identifier for an inline passage." - } - }, - "type": "object", - "description": "Identifier for the source contributing to this attribution." - }, - "SpeakerVoiceConfig": { - "properties": { - "voiceConfig": { - "$ref": "#/components/schemas/VoiceConfig", - "description": "Required. The configuration for the voice to use." - }, - "speaker": { - "description": "Required. The name of the speaker to use. Should be the same as in the prompt.", - "type": "string" + "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" } }, "type": "object", - "description": "The configuration for a single speaker in a multi speaker setup." - }, - "AsyncBatchEmbedContentRequest": { - "description": "Request for an `AsyncBatchEmbedContent` operation.", - "properties": { - "batch": { - "$ref": "#/components/schemas/EmbedContentBatch", - "description": "Required. The batch to create." - } - }, - "type": "object" + "description": "The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field." }, - "Candidate": { - "description": "A response candidate generated from the model.", - "type": "object", + "FileSearchStore": { "properties": { - "content": { - "description": "Output only. Generated content returned from the model.", - "readOnly": true, - "$ref": "#/components/schemas/Content" - }, - "groundingMetadata": { - "description": "Output only. Grounding metadata for the candidate. This field is populated for `GenerateContent` calls.", + "updateTime": { + "description": "Output only. The Timestamp of when the `FileSearchStore` was last updated.", + "format": "google-datetime", "readOnly": true, - "$ref": "#/components/schemas/GroundingMetadata" + "type": "string" }, - "groundingAttributions": { - "readOnly": true, - "description": "Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.", - "items": { - "$ref": "#/components/schemas/GroundingAttribution" - }, - "type": "array" + "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" }, - "avgLogprobs": { - "description": "Output only. Average log probability score of the candidate.", - "format": "double", + "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`.", + "format": "int64", "readOnly": true, - "type": "number" + "type": "string" }, - "finishReason": { - "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": [ - "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." - ], - "description": "Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.", + "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" }, - "urlContextMetadata": { + "activeDocumentsCount": { + "description": "Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.", + "format": "int64", "readOnly": true, - "$ref": "#/components/schemas/UrlContextMetadata", - "description": "Output only. Metadata related to url context retrieval tool." + "type": "string" }, - "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.", + "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, - "$ref": "#/components/schemas/CitationMetadata" - }, - "safetyRatings": { - "items": { - "$ref": "#/components/schemas/SafetyRating" - }, - "type": "array", - "description": "List of ratings for the safety of a response candidate. There is at most one rating per category." - }, - "tokenCount": { - "type": "integer", - "description": "Output only. Token count for this candidate.", - "format": "int32", - "readOnly": true + "type": "string" }, - "index": { - "type": "integer", - "description": "Output only. Index of the candidate in the list of response candidates.", - "format": "int32", - "readOnly": true + "createTime": { + "description": "Output only. The Timestamp of when the `FileSearchStore` was created.", + "format": "google-datetime", + "readOnly": true, + "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.", + "pendingDocumentsCount": { + "description": "Output only. The number of documents in the `FileSearchStore` that are being processed.", + "format": "int64", "readOnly": true, "type": "string" }, - "logprobsResult": { - "description": "Output only. Log-likelihood scores for the response tokens and top tokens", + "failedDocumentsCount": { "readOnly": true, - "$ref": "#/components/schemas/LogprobsResult" + "type": "string", + "description": "Output only. The number of documents in the `FileSearchStore` that have failed processing.", + "format": "int64" } - } + }, + "type": "object", + "description": "A `FileSearchStore` is a collection of `Document`s." }, - "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.", + "Image": { + "description": "Chunk from image search.", "type": "object", "properties": { - "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" + "sourceUri": { + "description": "The web page URI for attribution.", + "type": "string" }, - "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", + "domain": { + "description": "The root domain of the web page that the image is from, e.g. \"example.com\".", + "type": "string" + }, + "imageUri": { + "description": "The image asset URL.", + "type": "string" + }, + "title": { + "description": "The title of the web page that the image is from.", "type": "string" } } }, - "FunctionCallingConfig": { - "description": "Configuration for specifying function calling behavior.", + "CreateFileRequest": { "type": "object", "properties": { - "mode": { - "type": "string", - "x-enum-descriptions": [ - "Unspecified function calling mode. This value should not be used.", - "Default model behavior, model decides to predict either a function call or a natural language response.", - "Model is constrained to always predicting a function call only. If \"allowed_function_names\" are set, the predicted function call will be limited to any one of \"allowed_function_names\", else the predicted function call will be any one of the provided \"function_declarations\".", - "Model will not predict any function call. Model behavior is same as when not passing any function declarations.", - "Model decides to predict either a function call or a natural language response, but will validate function calls with constrained decoding. If \"allowed_function_names\" are set, the predicted function call will be limited to any one of \"allowed_function_names\", else the predicted function call will be any one of the provided \"function_declarations\"." - ], - "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" - ] - }, - "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.", + "file": { + "description": "Optional. Metadata for the file to create.", + "$ref": "#/components/schemas/File" + } + }, + "description": "Request for `CreateFile`." + }, + "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.", + "type": "object", + "properties": { + "reviewSnippets": { "type": "array", "items": { - "type": "string" - } + "$ref": "#/components/schemas/ReviewSnippet" + }, + "description": "Snippets of reviews that are used to generate answers about the features of a given place in Google Maps." } } }, - "File": { - "description": "A file uploaded to the API. Next ID: 15", - "type": "object", + "Status": { + "description": "The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors).", "properties": { - "uri": { - "description": "Output only. The uri of the `File`.", - "readOnly": true, + "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" }, - "createTime": { - "type": "string", - "description": "Output only. The timestamp of when the `File` was created.", - "format": "google-datetime", - "readOnly": true + "details": { + "type": "array", + "items": { + "additionalProperties": { + "description": "Properties of the object. Contains field @type with type URL." + }, + "type": "object" + }, + "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use." }, - "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" + "code": { + "type": "integer", + "description": "The status code, which should be an enum value of google.rpc.Code.", + "format": "int32" + } + }, + "type": "object" + }, + "TopCandidates": { + "description": "Candidates with top log probabilities at each decoding step.", + "properties": { + "candidates": { + "type": "array", + "items": { + "$ref": "#/components/schemas/LogprobsResultCandidate" + }, + "description": "Sorted by log probability in descending order." + } + }, + "type": "object" + }, + "CitationSource": { + "description": "A citation to a source for a portion of a specific response.", + "properties": { + "endIndex": { + "type": "integer", + "description": "Optional. End of the attributed segment, exclusive.", + "format": "int32" }, - "sha256Hash": { - "description": "Output only. SHA-256 hash of the uploaded bytes.", - "format": "byte", - "readOnly": true, - "type": "string" + "startIndex": { + "type": "integer", + "description": "Optional. Start of segment of the response that is attributed to this source. Index indicates the start of the segment, measured in bytes.", + "format": "int32" }, - "source": { - "enum": [ - "SOURCE_UNSPECIFIED", - "UPLOADED", - "GENERATED", - "REGISTERED" - ], - "description": "Source of the File.", - "x-enum-descriptions": [ - "Used if source is not specified.", - "Indicates the file is uploaded by the user.", - "Indicates the file is generated by Google.", - "Indicates the file is a registered, i.e. a Google Cloud Storage file." - ], + "uri": { + "description": "Optional. URI that is attributed as a source for a portion of the text.", "type": "string" }, - "mimeType": { - "type": "string", - "readOnly": true, - "description": "Output only. MIME type of the file." - }, - "error": { - "readOnly": true, - "$ref": "#/components/schemas/Status", - "description": "Output only. Error status if File processing failed." - }, - "sizeBytes": { - "description": "Output only. Size of the file in bytes.", - "format": "int64", - "readOnly": true, + "license": { + "description": "Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations.", "type": "string" + } + }, + "type": "object" + }, + "InlinedResponse": { + "properties": { + "response": { + "readOnly": true, + "description": "Output only. The response to the request.", + "$ref": "#/components/schemas/GenerateContentResponse" }, - "updateTime": { - "type": "string", + "metadata": { + "description": "Output only. The metadata associated with the request.", + "additionalProperties": { + "description": "Properties of the object." + }, "readOnly": true, - "description": "Output only. The timestamp of when the `File` was last updated.", - "format": "google-datetime" + "type": "object" }, - "expirationTime": { + "error": { "readOnly": true, - "description": "Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.", + "description": "Output only. The error encountered while processing the request.", + "$ref": "#/components/schemas/Status" + } + }, + "type": "object", + "description": "The response to a single request in the batch." + }, + "Interval": { + "properties": { + "endTime": { + "description": "Optional. Exclusive end of the interval. If specified, a Timestamp matching this interval will have to be before the end.", "format": "google-datetime", "type": "string" }, - "state": { - "type": "string", - "description": "Output only. Processing state of the File.", - "x-enum-descriptions": [ - "The default value. This value is used if the state is omitted.", - "File is being processed and cannot be used for inference yet.", - "File is processed and available for inference.", - "File failed processing." - ], - "readOnly": true, - "enum": [ - "STATE_UNSPECIFIED", - "PROCESSING", - "ACTIVE", - "FAILED" - ] - }, - "videoMetadata": { - "description": "Output only. Metadata for a video.", - "readOnly": true, - "$ref": "#/components/schemas/VideoFileMetadata" - }, - "downloadUri": { + "startTime": { "type": "string", - "description": "Output only. The download 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" + "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" } - } - }, - "StreamableHttpTransport": { + }, "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." + }, + "VideoMetadata": { "properties": { - "url": { - "description": "The full URL for the MCPServer endpoint. Example: \"https://api.example.com/mcp\"", - "type": "string" - }, - "terminateOnClose": { - "description": "Whether to close the client session when the transport closes.", - "type": "boolean" + "startOffset": { + "type": "string", + "description": "Optional. The start offset of the video.", + "format": "google-duration" }, - "headers": { - "description": "Optional: Fields for authentication headers, timeouts, etc., if needed.", - "additionalProperties": { - "type": "string" - }, - "type": "object" + "fps": { + "description": "Optional. The frame rate of the video sent to the model. If not specified, the default value will be 1.0. The fps range is (0.0, 24.0].", + "format": "double", + "type": "number" }, - "timeout": { - "description": "HTTP timeout for regular operations.", + "endOffset": { + "description": "Optional. The end offset of the video.", "format": "google-duration", "type": "string" + } + }, + "deprecated": true, + "type": "object", + "description": "Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content." + }, + "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" }, - "sseReadTimeout": { - "description": "Timeout for SSE read operations.", - "format": "google-duration", + "maxOverlapTokens": { + "description": "Maximum number of overlapping tokens between two adjacent chunks.", + "format": "int32", + "type": "integer" + } + }, + "type": "object", + "description": "Configuration for a white space chunking algorithm [white space delimited]." + }, + "PrebuiltVoiceConfig": { + "properties": { + "voiceName": { + "description": "The name of the preset voice to use.", "type": "string" } }, - "description": "A transport that can stream HTTP requests and responses. Next ID: 6" + "type": "object", + "description": "The configuration for the prebuilt speaker to use." }, - "BatchEmbedContentsResponse": { + "ListTunedModelsResponse": { + "type": "object", "properties": { - "embeddings": { - "description": "Output only. The embeddings for each request, in the same order as provided in the batch request.", - "readOnly": true, + "tunedModels": { + "description": "The returned Models.", "type": "array", "items": { - "$ref": "#/components/schemas/ContentEmbedding" + "$ref": "#/components/schemas/TunedModel" } }, - "usageMetadata": { - "readOnly": true, - "$ref": "#/components/schemas/EmbeddingUsageMetadata", - "description": "Output only. The usage metadata for the request." + "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": "The response to a `BatchEmbedContentsRequest`." + "description": "Response from `ListTunedModels` containing a paginated list of Models." }, - "Dataset": { - "description": "Dataset for training or validation.", - "type": "object", + "EmbedContentResponse": { + "description": "The response to an `EmbedContentRequest`.", "properties": { - "examples": { - "description": "Optional. Inline examples with simple input/output text.", - "$ref": "#/components/schemas/TuningExamples" + "embedding": { + "readOnly": true, + "description": "Output only. The embedding generated from the input content.", + "$ref": "#/components/schemas/ContentEmbedding" + }, + "usageMetadata": { + "description": "Output only. The usage metadata for the request.", + "$ref": "#/components/schemas/EmbeddingUsageMetadata", + "readOnly": true } - } + }, + "type": "object" }, - "GroundingChunkStringList": { - "description": "A list of string values.", - "type": "object", + "MultiSpeakerVoiceConfig": { + "description": "The configuration for the multi-speaker setup.", "properties": { - "values": { - "description": "The string values of the list.", + "speakerVoiceConfigs": { + "type": "array", "items": { - "type": "string" + "$ref": "#/components/schemas/SpeakerVoiceConfig" }, - "type": "array" + "description": "Required. All the enabled speaker voices." } - } + }, + "type": "object" }, - "GenerationConfig": { - "description": "Configuration options for model generation and outputs. Not all parameters are configurable for every model.", + "BatchGenerateContentRequest": { + "description": "Request for a `BatchGenerateContent` operation.", "properties": { - "mediaResolution": { - "description": "Optional. If specified, the media resolution specified will be used.", + "batch": { + "description": "Required. The batch to create.", + "$ref": "#/components/schemas/GenerateContentBatch" + } + }, + "type": "object" + }, + "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" + }, + "outcome": { + "description": "Required. Outcome of the code execution.", + "x-enum-descriptions": [ + "Unspecified status. This value should not be used.", + "Code execution completed successfully. `output` contains the stdout, if any.", + "Code execution failed. `output` contains the stderr and stdout, if any.", + "Code execution ran for too long, and was cancelled. There may or may not be a partial `output` present." + ], "enum": [ - "MEDIA_RESOLUTION_UNSPECIFIED", - "MEDIA_RESOLUTION_LOW", - "MEDIA_RESOLUTION_MEDIUM", - "MEDIA_RESOLUTION_HIGH" + "OUTCOME_UNSPECIFIED", + "OUTCOME_OK", + "OUTCOME_FAILED", + "OUTCOME_DEADLINE_EXCEEDED" ], - "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)." - ] - }, - "topK": { - "type": "integer", - "description": "Optional. The maximum number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests.", - "format": "int32" - }, - "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" - }, - "responseJsonSchema": { - "description": "Optional. An internal detail. Use `responseJsonSchema` rather than this field." - }, - "speechConfig": { - "$ref": "#/components/schemas/SpeechConfig", - "description": "Optional. The speech generation config." - }, - "stopSequences": { - "items": { - "type": "string" - }, - "type": "array", - "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." - }, - "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" - }, - "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." - }, - "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" - }, - "responseLogprobs": { - "description": "Optional. If true, export the logprobs results in response.", - "type": "boolean" - }, - "translationConfig": { - "$ref": "#/components/schemas/TranslationConfig", - "description": "Optional. Config for translation." - }, - "responseModalities": { - "items": { - "type": "string", - "x-enum-descriptions": [ - "Default value.", - "Indicates the model should return text.", - "Indicates the model should return images.", - "Indicates the model should return audio.", - "Indicates the model should return video." - ], - "enum": [ - "MODALITY_UNSPECIFIED", - "TEXT", - "IMAGE", - "AUDIO", - "VIDEO" - ] - }, - "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." - }, - "logprobs": { - "type": "integer", - "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" - }, - "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" - }, - "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." - }, - "seed": { - "type": "integer", - "description": "Optional. Seed used in decoding. If not set, the request uses a randomly generated seed.", - "format": "int32" - }, - "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." - }, - "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" }, - "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." - }, - "temperature": { - "type": "number", - "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" - }, - "enableEnhancedCivicAnswers": { - "description": "Optional. Enables enhanced civic answers. It may not be available for all models.", - "type": "boolean" + "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." + }, + "CreateFileResponse": { + "description": "Response for `CreateFile`.", + "properties": { + "file": { + "description": "Metadata for the created file.", + "$ref": "#/components/schemas/File" + } + }, + "type": "object" + }, + "SearchTypes": { + "description": "Different types of search that can be enabled on the GoogleSearch tool.", + "properties": { + "imageSearch": { + "description": "Optional. Enables image search. Image bytes are returned.", + "$ref": "#/components/schemas/ImageSearch" }, - "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" + "webSearch": { + "description": "Optional. Enables web search. Only text results are returned.", + "$ref": "#/components/schemas/WebSearch" } }, "type": "object" }, - "CustomLongRunningOperation": { + "CodeExecution": { + "description": "Tool that executes code generated by the model, and automatically returns the result to the model. See also `ExecutableCode` and `CodeExecutionResult` which are only generated when using this tool.", + "properties": {}, + "type": "object" + }, + "Operation": { "type": "object", "properties": { "response": { - "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`.", "additionalProperties": { "description": "Properties of the object. Contains field @type with type URL." - } + }, + "description": "The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.", + "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" }, - "error": { - "description": "The error result of the operation in case of failure or cancellation.", - "$ref": "#/components/schemas/Status" - }, "metadata": { + "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.", "additionalProperties": { "description": "Properties of the object. Contains field @type with type URL." - }, - "type": "object" + } }, "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" - } - } - }, - "GroundingChunk": { - "type": "object", - "properties": { - "image": { - "$ref": "#/components/schemas/Image", - "description": "Optional. Grounding chunk from image search." - }, - "retrievedContext": { - "description": "Optional. Grounding chunk from context retrieved by the file search tool.", - "$ref": "#/components/schemas/RetrievedContext" - }, - "web": { - "description": "Grounding chunk from the web.", - "$ref": "#/components/schemas/Web" }, - "maps": { - "description": "Optional. Grounding chunk from Google Maps.", - "$ref": "#/components/schemas/Maps" + "error": { + "description": "The error result of the operation in case of failure or cancellation.", + "$ref": "#/components/schemas/Status" } }, - "description": "A `GroundingChunk` represents a segment of supporting evidence that grounds the model's response. It can be a chunk from the web, a retrieved context from a file, or information from Google Maps." + "description": "This resource represents a long-running operation that is the result of a network API call." }, - "SpeechConfig": { + "TuningTask": { + "description": "Tuning tasks that create tuned models.", "type": "object", "properties": { - "voiceConfig": { - "description": "The configuration in case of single-voice output.", - "$ref": "#/components/schemas/VoiceConfig" - }, - "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`.", + "startTime": { + "description": "Output only. The timestamp when tuning this model started.", + "format": "google-datetime", + "readOnly": true, "type": "string" }, - "multiSpeakerVoiceConfig": { - "$ref": "#/components/schemas/MultiSpeakerVoiceConfig", - "description": "Optional. The configuration for the multi-speaker setup. It is mutually exclusive with the voice_config field." - } - }, - "description": "Config for speech generation and transcription." - }, - "ImageSearch": { - "properties": {}, - "type": "object", - "description": "Image search for grounding and related configurations." - }, - "CodeExecution": { - "description": "Tool that executes code generated by the model, and automatically returns the result to the model. See also `ExecutableCode` and `CodeExecutionResult` which are only generated when using this tool.", - "type": "object", - "properties": {} - }, - "CountTokensResponse": { - "description": "A response from `CountTokens`. It returns the model's `token_count` for the `prompt`.", - "properties": { - "promptTokensDetails": { - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - }, - "type": "array", + "trainingData": { + "description": "Required. Input only. Immutable. The model training data.", + "$ref": "#/components/schemas/Dataset" + }, + "hyperparameters": { + "description": "Immutable. Hyperparameters controlling the tuning process. If not provided, default values will be used.", + "$ref": "#/components/schemas/Hyperparameters" + }, + "completeTime": { + "description": "Output only. The timestamp when tuning this model completed.", + "format": "google-datetime", "readOnly": true, - "description": "Output only. List of modalities that were processed in the request input." + "type": "string" }, - "cacheTokensDetails": { - "description": "Output only. List of modalities that were processed in the cached content.", + "snapshots": { + "description": "Output only. Metrics collected during tuning.", "readOnly": true, "type": "array", "items": { - "$ref": "#/components/schemas/ModalityTokenCount" + "$ref": "#/components/schemas/TuningSnapshot" } + } + } + }, + "FunctionCall": { + "description": "A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values.", + "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" }, - "totalTokens": { - "description": "The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative.", - "format": "int32", - "type": "integer" + "args": { + "description": "Optional. The function parameters and values in JSON object format.", + "additionalProperties": { + "description": "Properties of the object." + }, + "type": "object" }, - "cachedContentTokenCount": { - "description": "Number of tokens in the cached part of the prompt (the cached content).", - "format": "int32", - "type": "integer" + "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" } }, "type": "object" }, - "RegisterFilesResponse": { - "description": "Response for `RegisterFiles`.", + "BatchEmbedContentsResponse": { + "description": "The response to a `BatchEmbedContentsRequest`.", "type": "object", "properties": { - "files": { - "items": { - "$ref": "#/components/schemas/File" - }, + "embeddings": { + "description": "Output only. The embeddings for each request, in the same order as provided in the batch request.", + "readOnly": true, "type": "array", - "description": "The registered files to be used when calling GenerateContent." + "items": { + "$ref": "#/components/schemas/ContentEmbedding" + } + }, + "usageMetadata": { + "readOnly": true, + "description": "Output only. The usage metadata for the request.", + "$ref": "#/components/schemas/EmbeddingUsageMetadata" } } }, - "FunctionResponse": { + "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", "properties": { + "streamableHttpTransport": { + "description": "A transport that can stream HTTP requests and responses.", + "$ref": "#/components/schemas/StreamableHttpTransport" + }, "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 name of the MCPServer.", + "type": "string" + } + }, + "type": "object" + }, + "EmbedContentConfig": { + "description": "Configurations for the EmbedContent request.", + "properties": { + "taskType": { + "description": "Optional. The task type of the embedding.", + "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." + ], + "enum": [ + "TASK_TYPE_UNSPECIFIED", + "RETRIEVAL_QUERY", + "RETRIEVAL_DOCUMENT", + "SEMANTIC_SIMILARITY", + "CLASSIFICATION", + "CLUSTERING", + "QUESTION_ANSWERING", + "FACT_VERIFICATION", + "CODE_RETRIEVAL_QUERY" + ], "type": "string" }, - "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." - } - }, - "id": { - "description": "Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`.", + "title": { + "description": "Optional. The title for the text.", "type": "string" }, - "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`.", + "audioTrackExtraction": { + "description": "Optional. Whether to extract audio from video content.", "type": "boolean" }, - "scheduling": { - "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." - ], - "type": "string", - "enum": [ - "SCHEDULING_UNSPECIFIED", - "SILENT", - "WHEN_IDLE", - "INTERRUPT" - ], - "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." + "outputDimensionality": { + "type": "integer", + "description": "Optional. Reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end.", + "format": "int32" }, - "parts": { - "description": "Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types.", + "documentOcr": { + "description": "Optional. Whether to enable OCR for document content.", + "type": "boolean" + }, + "autoTruncate": { + "description": "Optional. Whether to silently truncate the input content if it's longer than the maximum sequence length.", + "type": "boolean" + } + }, + "type": "object" + }, + "ListCorporaResponse": { + "properties": { + "corpora": { "type": "array", "items": { - "$ref": "#/components/schemas/FunctionResponsePart" - } + "$ref": "#/components/schemas/Corpus" + }, + "description": "The returned corpora." + }, + "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": "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." + "description": "Response from `ListCorpora` containing a paginated list of `Corpora`. The results are sorted by ascending `corpus.create_time`." }, - "UrlMetadata": { + "FileData": { + "description": "URI based data.", "type": "object", "properties": { - "urlRetrievalStatus": { - "description": "Status of the url retrieval.", - "enum": [ - "URL_RETRIEVAL_STATUS_UNSPECIFIED", - "URL_RETRIEVAL_STATUS_SUCCESS", - "URL_RETRIEVAL_STATUS_ERROR", - "URL_RETRIEVAL_STATUS_PAYWALL", - "URL_RETRIEVAL_STATUS_UNSAFE" - ], - "type": "string", - "x-enum-descriptions": [ - "Default value. This value is unused.", - "Url retrieval is successful.", - "Url retrieval is failed due to error.", - "Url retrieval is failed because the content is behind paywall.", - "Url retrieval is failed because the content is unsafe." - ] + "mimeType": { + "description": "Optional. The IANA standard MIME type of the source data.", + "type": "string" + }, + "fileUri": { + "description": "Required. URI.", + "type": "string" + } + } + }, + "TuningExample": { + "type": "object", + "properties": { + "textInput": { + "description": "Optional. Text model input.", + "type": "string" }, - "retrievedUrl": { - "description": "Retrieved url by the tool.", + "output": { + "description": "Required. The expected model output.", "type": "string" } }, - "description": "Context of the a single url retrieval." + "description": "A single example for tuning." }, - "TunedModelSource": { + "GoogleSearch": { "type": "object", "properties": { - "tunedModel": { - "description": "Immutable. The name of the `TunedModel` to use as the starting point for training the new model. Example: `tunedModels/my-tuned-model`", - "type": "string" + "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" }, - "baseModel": { - "description": "Output only. The name of the base `Model` this `TunedModel` was tuned from. Example: `models/gemini-1.5-flash-001`", - "readOnly": true, - "type": "string" + "searchTypes": { + "description": "Optional. The set of search types to enable. If not set, web search is enabled by default.", + "$ref": "#/components/schemas/SearchTypes" } }, - "description": "Tuned model as a source for training a new model." + "description": "GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google." }, - "GoogleMaps": { + "CitationMetadata": { "type": "object", "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" + "citationSources": { + "description": "Citations to sources for a specific response.", + "type": "array", + "items": { + "$ref": "#/components/schemas/CitationSource" + } } }, - "description": "The GoogleMaps Tool that provides geospatial context for the user's query." + "description": "A collection of source attributions for a piece of content." }, - "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.", + "GoogleAiGenerativelanguageV1betaSegment": { + "description": "Segment of the content.", + "type": "object", "properties": { - "functionResponse": { - "description": "The result output of a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model.", - "$ref": "#/components/schemas/FunctionResponse" - }, - "executableCode": { - "description": "Code generated by the model that is meant to be executed.", - "$ref": "#/components/schemas/ExecutableCode" + "partIndex": { + "description": "The index of a Part object within its parent Content object.", + "format": "int32", + "type": "integer" }, - "mediaResolution": { - "description": "Optional. Media resolution for the input media.", - "$ref": "#/components/schemas/MediaResolution" + "endIndex": { + "description": "End index in the given Part, measured in bytes. Offset from the start of the Part, exclusive, starting at zero.", + "format": "int32", + "type": "integer" }, "text": { - "description": "Inline text.", + "description": "The text corresponding to the segment from the response.", "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" - }, - "toolCall": { - "$ref": "#/components/schemas/ToolCall", - "description": "Server-side tool call. This field is populated when the model predicts a tool invocation that should be executed on the server. The client is expected to echo this message back to the API." - }, - "partMetadata": { - "type": "object", - "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.", - "additionalProperties": { - "description": "Properties of the object." - } - }, - "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" - }, - "thoughtSignature": { - "type": "string", - "description": "Optional. An opaque signature for the thought so it can be reused in subsequent requests.", - "format": "byte" - }, - "inlineData": { - "description": "Inline media bytes.", - "$ref": "#/components/schemas/Blob" + "startIndex": { + "type": "integer", + "description": "Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero.", + "format": "int32" + } + } + }, + "GroundingChunk": { + "properties": { + "retrievedContext": { + "description": "Optional. Grounding chunk from context retrieved by the file search tool.", + "$ref": "#/components/schemas/RetrievedContext" }, - "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." + "web": { + "description": "Grounding chunk from the web.", + "$ref": "#/components/schemas/Web" }, - "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" + "maps": { + "description": "Optional. Grounding chunk from Google Maps.", + "$ref": "#/components/schemas/Maps" }, - "fileData": { - "description": "URI based data.", - "$ref": "#/components/schemas/FileData" + "image": { + "description": "Optional. Grounding chunk from image search.", + "$ref": "#/components/schemas/Image" } }, - "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." }, - "CodeExecutionResult": { + "TranslationConfig": { "type": "object", "properties": { - "output": { - "description": "Optional. Contains stdout when code execution is successful, stderr or other description otherwise.", - "type": "string" + "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" }, - "id": { - "description": "Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id.", + "targetLanguageCode": { + "description": "Required. The target language for translation. Supported values are BCP-47 language codes (e.g. \"en\", \"es\", \"fr\").", "type": "string" - }, - "outcome": { - "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." - ], - "type": "string", - "enum": [ - "OUTCOME_UNSPECIFIED", - "OUTCOME_OK", - "OUTCOME_FAILED", - "OUTCOME_DEADLINE_EXCEEDED" - ], - "description": "Required. Outcome of the code execution." } }, - "description": "Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used." + "description": "Config for translation features." }, - "TuningSnapshot": { - "description": "Record for a single tuning step.", + "CachedContentUsageMetadata": { + "description": "Metadata on the usage of the cached content.", "type": "object", "properties": { - "epoch": { - "readOnly": true, - "description": "Output only. The epoch this step was part of.", + "totalTokenCount": { + "description": "Total number of tokens that the cached content consumes.", "format": "int32", "type": "integer" - }, - "computeTime": { - "type": "string", - "description": "Output only. The timestamp when this metric was computed.", - "format": "google-datetime", - "readOnly": true - }, - "step": { - "type": "integer", - "description": "Output only. The tuning step.", - "format": "int32", - "readOnly": true - }, - "meanLoss": { - "type": "number", - "readOnly": true, - "description": "Output only. The mean loss of the training examples for this step.", - "format": "float" } } }, - "PrebuiltVoiceConfig": { - "description": "The configuration for the prebuilt speaker to use.", + "Empty": { + "properties": {}, + "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); }" + }, + "Content": { "type": "object", "properties": { - "voiceName": { - "description": "The name of the preset voice to use.", + "parts": { + "type": "array", + "items": { + "$ref": "#/components/schemas/Part" + }, + "description": "Ordered `Parts` that constitute a single message. Parts may have different MIME types." + }, + "role": { + "description": "Optional. The producer of the content. Must be either 'user' or 'model'. Useful to set for multi-turn conversations, otherwise can be left blank or unset.", "type": "string" } - } + }, + "description": "The 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." }, - "ToolCall": { - "description": "A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`.", - "type": "object", + "ListDocumentsResponse": { "properties": { - "id": { - "description": "Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`.", + "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" }, - "args": { - "description": "Optional. The tool call arguments. Example: {\"arg1\" : \"value1\", \"arg2\" : \"value2\" , ...}", - "additionalProperties": { - "description": "Properties of the object." + "documents": { + "type": "array", + "items": { + "$ref": "#/components/schemas/Document" }, - "type": "object" + "description": "The returned `Document`s." + } + }, + "type": "object", + "description": "Response from `ListDocuments` containing a paginated list of `Document`s. The `Document`s are sorted by ascending `document.create_time`." + }, + "TunedModelSource": { + "description": "Tuned model as a source for training a new model.", + "properties": { + "tunedModel": { + "description": "Immutable. The name of the `TunedModel` to use as the starting point for training the new model. Example: `tunedModels/my-tuned-model`", + "type": "string" }, - "toolType": { + "baseModel": { + "readOnly": true, "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." - ], - "description": "Required. The type of tool that was called.", - "enum": [ - "TOOL_TYPE_UNSPECIFIED", - "GOOGLE_SEARCH_WEB", - "GOOGLE_SEARCH_IMAGE", - "URL_CONTEXT", - "GOOGLE_MAPS", - "FILE_SEARCH" - ] + "description": "Output only. The name of the base `Model` this `TunedModel` was tuned from. Example: `models/gemini-1.5-flash-001`" } - } + }, + "type": "object" + }, + "VoiceConfig": { + "description": "The configuration for the voice to use.", + "properties": { + "prebuiltVoiceConfig": { + "description": "The configuration for the prebuilt voice to use.", + "$ref": "#/components/schemas/PrebuiltVoiceConfig" + } + }, + "type": "object" + }, + "AsyncBatchEmbedContentRequest": { + "type": "object", + "properties": { + "batch": { + "description": "Required. The batch to create.", + "$ref": "#/components/schemas/EmbedContentBatch" + } + }, + "description": "Request for an `AsyncBatchEmbedContent` operation." + }, + "GoogleMaps": { + "description": "The GoogleMaps Tool that provides geospatial context for the user's query.", + "properties": { + "enableWidget": { + "description": "Optional. Whether to return a widget context token in the GroundingMetadata of the response. Developers can use the widget context token to render a Google Maps widget with geospatial context related to the places that the model references in the response.", + "type": "boolean" + } + }, + "type": "object" }, - "FileSearchStore": { - "description": "A `FileSearchStore` is a collection of `Document`s.", + "SpeechConfig": { + "description": "Config for speech generation and transcription.", "type": "object", "properties": { - "pendingDocumentsCount": { - "description": "Output only. The number of documents in the `FileSearchStore` that are being processed.", - "format": "int64", - "readOnly": true, - "type": "string" - }, - "sizeBytes": { - "type": "string", - "description": "Output only. The size of raw bytes ingested into the `FileSearchStore`. This is the total size of all the documents in the `FileSearchStore`.", - "format": "int64", - "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" - }, - "updateTime": { - "type": "string", - "readOnly": true, - "description": "Output only. The Timestamp of when the `FileSearchStore` was last updated.", - "format": "google-datetime" - }, - "activeDocumentsCount": { - "readOnly": true, - "description": "Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.", - "format": "int64", - "type": "string" - }, - "createTime": { - "type": "string", - "description": "Output only. The Timestamp of when the `FileSearchStore` was created.", - "format": "google-datetime", - "readOnly": true - }, - "failedDocumentsCount": { - "readOnly": true, - "description": "Output only. The number of documents in the `FileSearchStore` that have failed processing.", - "format": "int64", - "type": "string" + "voiceConfig": { + "description": "The configuration in case of single-voice output.", + "$ref": "#/components/schemas/VoiceConfig" }, - "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\"", + "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" }, - "name": { - "type": "string", - "readOnly": true, - "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." + "multiSpeakerVoiceConfig": { + "description": "Optional. The configuration for the multi-speaker setup. It is mutually exclusive with the voice_config field.", + "$ref": "#/components/schemas/MultiSpeakerVoiceConfig" } } }, - "SafetyRating": { + "InputConfig": { "type": "object", "properties": { - "category": { - "enum": [ - "HARM_CATEGORY_UNSPECIFIED", - "HARM_CATEGORY_DEROGATORY", - "HARM_CATEGORY_TOXICITY", - "HARM_CATEGORY_VIOLENCE", - "HARM_CATEGORY_SEXUAL", - "HARM_CATEGORY_MEDICAL", - "HARM_CATEGORY_DANGEROUS", - "HARM_CATEGORY_HARASSMENT", - "HARM_CATEGORY_HATE_SPEECH", - "HARM_CATEGORY_SEXUALLY_EXPLICIT", - "HARM_CATEGORY_DANGEROUS_CONTENT", - "HARM_CATEGORY_CIVIC_INTEGRITY" - ], - "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 rating.", - "type": "string", - "enumDeprecated": [ - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - true - ] - }, - "probability": { - "description": "Required. The probability of harm for this content.", - "enum": [ - "HARM_PROBABILITY_UNSPECIFIED", - "NEGLIGIBLE", - "LOW", - "MEDIUM", - "HIGH" - ], - "type": "string", - "x-enum-descriptions": [ - "Probability is unspecified.", - "Content has a negligible chance of being unsafe.", - "Content has a low chance of being unsafe.", - "Content has a medium chance of being unsafe.", - "Content has a high chance of being unsafe." - ] + "requests": { + "description": "The requests to be processed in the batch.", + "$ref": "#/components/schemas/InlinedRequests" }, - "blocked": { - "description": "Was this content blocked because of this rating?", - "type": "boolean" + "fileName": { + "description": "The name of the `File` containing the input requests.", + "type": "string" } }, - "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." + "description": "Configures the input to the batch request." }, - "Operation": { + "GroundingMetadata": { "type": "object", "properties": { - "done": { - "description": "If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available.", - "type": "boolean" + "searchEntryPoint": { + "description": "Optional. Google search entry for the following-up web searches.", + "$ref": "#/components/schemas/SearchEntryPoint" }, - "metadata": { - "description": "Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any.", - "additionalProperties": { - "description": "Properties of the object. Contains field @type with type URL." + "webSearchQueries": { + "type": "array", + "items": { + "type": "string" }, - "type": "object" + "description": "Web search queries for the following-up web search." }, - "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" + "groundingSupports": { + "description": "List of grounding support.", + "type": "array", + "items": { + "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaGroundingSupport" + } }, - "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" + "imageSearchQueries": { + "description": "Image search queries used for grounding.", + "type": "array", + "items": { + "type": "string" + } }, - "error": { - "$ref": "#/components/schemas/Status", - "description": "The error result of the operation in case of failure or cancellation." - } - }, - "description": "This resource represents a long-running operation that is the result of a network API call." - }, - "ImportFileRequest": { - "properties": { - "chunkingConfig": { - "$ref": "#/components/schemas/ChunkingConfig", - "description": "Optional. Config for telling the service how to chunk the file. If not provided, the service will use default parameters." + "retrievalMetadata": { + "description": "Metadata related to retrieval in the grounding flow.", + "$ref": "#/components/schemas/RetrievalMetadata" }, - "customMetadata": { - "description": "Custom metadata to be associated with the file.", + "groundingChunks": { + "description": "List of supporting references retrieved from specified grounding source. When streaming, this only contains the grounding chunks that have not been included in the grounding metadata of previous responses.", "type": "array", "items": { - "$ref": "#/components/schemas/CustomMetadata" + "$ref": "#/components/schemas/GroundingChunk" } }, - "fileName": { - "description": "Required. The name of the `File` to import. Example: `files/abc-123`", + "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`." + "description": "Metadata returned to client when grounding is enabled." }, - "InlinedEmbedContentRequests": { - "description": "The requests to be processed in the batch if provided as part of the batch creation request.", - "type": "object", + "CountTokensRequest": { + "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": { - "requests": { + "contents": { "type": "array", "items": { - "$ref": "#/components/schemas/InlinedEmbedContentRequest" + "$ref": "#/components/schemas/Content" }, - "description": "Required. The requests to be processed in the batch." + "description": "Optional. The input given to the model as a prompt. This field is ignored when `generate_content_request` is set." + }, + "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" } - } + }, + "type": "object" }, - "GenerateContentRequest": { - "description": "Request to generate a completion from the model.", + "WebSearch": { + "properties": {}, + "type": "object", + "description": "Standard web search for grounding and related configurations." + }, + "GroundingPassageId": { + "description": "Identifier for a part within a `GroundingPassage`.", + "type": "object", "properties": { - "model": { - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", - "type": "string" - }, - "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}`", + "passageId": { + "description": "Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`.", + "readOnly": true, "type": "string" }, - "toolConfig": { - "description": "Optional. Tool configuration for any `Tool` specified in the request. Refer to the [Function calling guide](https://ai.google.dev/gemini-api/docs/function-calling#function_calling_mode) for a usage example.", - "$ref": "#/components/schemas/ToolConfig" - }, - "tools": { - "type": "array", - "items": { - "$ref": "#/components/schemas/Tool" - }, - "description": "Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more." - }, - "serviceTier": { - "enum": [ - "unspecified", - "standard", - "flex", - "priority" - ], - "description": "Optional. The service tier of the request.", + "partIndex": { + "description": "Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`.", + "format": "int32", + "readOnly": true, + "type": "integer" + } + } + }, + "ModalityTokenCount": { + "description": "Represents token counting info for a single modality.", + "type": "object", + "properties": { + "modality": { + "description": "The modality associated with this token count.", "x-enum-descriptions": [ - "Default service tier, which is standard.", - "Standard service tier.", - "Flex service tier.", - "Priority service tier." + "Unspecified modality.", + "Plain text.", + "Image.", + "Video.", + "Audio.", + "Document, e.g. PDF." + ], + "enum": [ + "MODALITY_UNSPECIFIED", + "TEXT", + "IMAGE", + "VIDEO", + "AUDIO", + "DOCUMENT" ], "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." - }, - "contents": { - "items": { - "$ref": "#/components/schemas/Content" - }, - "type": "array", - "description": "Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request." - }, - "safetySettings": { - "description": "Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications.", - "type": "array", - "items": { - "$ref": "#/components/schemas/SafetySetting" - } - }, - "generationConfig": { - "description": "Optional. Configuration options for model generation and outputs.", - "$ref": "#/components/schemas/GenerationConfig" - }, - "store": { - "description": "Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config.", - "type": "boolean" + "tokenCount": { + "description": "Number of tokens.", + "format": "int32", + "type": "integer" + } + } + }, + "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" } }, "type": "object" }, - "BatchGenerateContentRequest": { + "InlinedRequests": { "properties": { - "batch": { - "description": "Required. The batch to create.", - "$ref": "#/components/schemas/GenerateContentBatch" + "requests": { + "description": "Required. The requests to be processed in the batch.", + "type": "array", + "items": { + "$ref": "#/components/schemas/InlinedRequest" + } } }, "type": "object", - "description": "Request for a `BatchGenerateContent` operation." + "description": "The requests to be processed in the batch if provided as part of the batch creation request." }, - "Blob": { - "description": "Raw media bytes. Text should not be sent as raw bytes, use the 'text' field.", + "ListGeneratedFilesResponse": { "properties": { - "data": { - "description": "Raw bytes for media formats.", - "format": "byte", - "type": "string" + "generatedFiles": { + "description": "The list of `GeneratedFile`s.", + "type": "array", + "items": { + "$ref": "#/components/schemas/GeneratedFile" + } }, - "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). //", + "nextPageToken": { + "description": "A token that can be sent as a `page_token` into a subsequent `ListGeneratedFiles` call.", "type": "string" } }, - "type": "object" - }, - "GenerateContentResponse": { - "description": "Response from the model supporting multiple candidate responses. Safety ratings and content filtering are reported for both prompt in `GenerateContentResponse.prompt_feedback` and for each candidate in `finish_reason` and in `safety_ratings`. The API: - Returns either all requested candidates or none of them - Returns no candidates at all only if there was something wrong with the prompt (check `prompt_feedback`) - Reports feedback on each candidate in `finish_reason` and `safety_ratings`.", "type": "object", - "properties": { - "modelStatus": { - "readOnly": true, - "$ref": "#/components/schemas/ModelStatus", - "description": "Output only. The current model status of this model." - }, - "candidates": { - "description": "Candidate responses from the model.", - "items": { - "$ref": "#/components/schemas/Candidate" - }, - "type": "array" - }, - "usageMetadata": { - "readOnly": true, - "$ref": "#/components/schemas/UsageMetadata", - "description": "Output only. Metadata on the generation requests' token usage." - }, - "modelVersion": { - "type": "string", - "readOnly": true, - "description": "Output only. The model version used to generate the response." - }, - "responseId": { - "type": "string", - "description": "Output only. response_id is used to identify each response.", - "readOnly": true - }, - "promptFeedback": { - "description": "Returns the prompt's feedback related to the content filters.", - "$ref": "#/components/schemas/PromptFeedback" - } - } + "description": "Response for `ListGeneratedFiles`." }, - "TunedModel": { + "ComputerUse": { + "description": "Computer Use tool type.", "properties": { - "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" - }, - "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" + "enablePromptInjectionDetection": { + "description": "Optional. Whether enable the prompt injection detection check on computer-use request.", + "type": "boolean" }, - "updateTime": { - "type": "string", - "description": "Output only. The timestamp when this model was updated.", - "format": "google-datetime", - "readOnly": true + "disabledSafetyPolicies": { + "description": "Optional. Disabled safety policies for computer use.", + "type": "array", + "items": { + "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" + ] + } }, - "description": { - "description": "Optional. A short description of this model.", - "type": "string" + "excludedPredefinedFunctions": { + "type": "array", + "items": { + "type": "string" + }, + "description": "Optional. By default, predefined functions are included in the final model call. Some of them can be explicitly excluded from being automatically included. This can serve two purposes: 1. Using a more restricted / different action space. 2. Improving the definitions / instructions of predefined functions." }, - "state": { + "environment": { + "description": "Required. The environment being operated.", "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." + "Defaults to browser.", + "Operates in a web browser.", + "Operates in a mobile environment.", + "Operates in a desktop environment." ], - "readOnly": true, "enum": [ - "STATE_UNSPECIFIED", - "CREATING", - "ACTIVE", - "FAILED" + "ENVIRONMENT_UNSPECIFIED", + "ENVIRONMENT_BROWSER", + "ENVIRONMENT_MOBILE", + "ENVIRONMENT_DESKTOP" ], - "type": "string", - "description": "Output only. The state of the tuned model." - }, - "name": { - "type": "string", - "readOnly": true, - "description": "Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`" - }, - "baseModel": { - "description": "Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001`", "type": "string" + } + }, + "type": "object" + }, + "CountTokensResponse": { + "description": "A response from `CountTokens`. It returns the model's `token_count` for the `prompt`.", + "type": "object", + "properties": { + "totalTokens": { + "description": "The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative.", + "format": "int32", + "type": "integer" }, - "createTime": { - "type": "string", - "description": "Output only. The timestamp when this model was created.", - "format": "google-datetime", - "readOnly": true - }, - "tuningTask": { - "$ref": "#/components/schemas/TuningTask", - "description": "Required. The tuning task that creates the tuned model." - }, - "topP": { - "description": "Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model.", - "format": "float", - "type": "number" - }, - "tunedModelSource": { - "$ref": "#/components/schemas/TunedModelSource", - "description": "Optional. TunedModel to use as the starting point for training the new model." - }, - "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" + "promptTokensDetails": { + "description": "Output only. List of modalities that were processed in the request input.", + "readOnly": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + } }, - "readerProjectNumbers": { + "cacheTokensDetails": { + "description": "Output only. List of modalities that were processed in the cached content.", + "readOnly": true, "type": "array", "items": { - "type": "string", - "format": "int64" - }, - "description": "Optional. List of project numbers that have read access to the tuned model." + "$ref": "#/components/schemas/ModalityTokenCount" + } + }, + "cachedContentTokenCount": { + "description": "Number of tokens in the cached part of the prompt (the cached content).", + "format": "int32", + "type": "integer" } - }, - "type": "object", - "description": "A fine-tuned model created using ModelService.CreateTunedModel." + } }, - "ModelStatus": { - "description": "The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable.", - "properties": { - "retirementTime": { - "type": "string", - "description": "The time at which the model will be retired.", - "format": "google-datetime" - }, - "modelStage": { - "description": "The stage of the underlying model.", + "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": { + "category": { "type": "string", + "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" + ], "enumDeprecated": [ false, - true, false, false, false, false, - true, - false + false, + false, + false, + false, + false, + false, + true + ] + }, + "probability": { + "type": "string", + "description": "Required. The probability of harm for this content.", + "x-enum-descriptions": [ + "Probability is unspecified.", + "Content has a negligible chance of being unsafe.", + "Content has a low chance of being unsafe.", + "Content has a medium chance of being unsafe.", + "Content has a high chance of being unsafe." ], "enum": [ - "MODEL_STAGE_UNSPECIFIED", - "UNSTABLE_EXPERIMENTAL", - "EXPERIMENTAL", - "PREVIEW", - "STABLE", - "LEGACY", - "DEPRECATED", - "RETIRED" - ], - "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." + "HARM_PROBABILITY_UNSPECIFIED", + "NEGLIGIBLE", + "LOW", + "MEDIUM", + "HIGH" ] }, - "message": { - "description": "A message explaining the model status.", - "type": "string" + "blocked": { + "description": "Was this content blocked because of this rating?", + "type": "boolean" } - }, - "type": "object" + } }, - "McpServer": { - "description": "A MCPServer is a server that can be called by the model to perform actions. It is a server that implements the MCP protocol. Next ID: 6", + "ListFileSearchStoresResponse": { + "description": "Response from `ListFileSearchStores` containing a paginated list of `FileSearchStores`. The results are sorted by ascending `file_search_store.create_time`.", + "type": "object", "properties": { - "streamableHttpTransport": { - "description": "A transport that can stream HTTP requests and responses.", - "$ref": "#/components/schemas/StreamableHttpTransport" + "fileSearchStores": { + "description": "The returned rag_stores.", + "type": "array", + "items": { + "$ref": "#/components/schemas/FileSearchStore" + } }, - "name": { - "description": "The name of the MCPServer.", + "nextPageToken": { + "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", "type": "string" } - }, - "type": "object" + } }, - "UploadToFileSearchStoreRequest": { + "InlinedResponses": { + "description": "The responses to the requests in the batch.", + "type": "object", "properties": { - "displayName": { - "description": "Optional. Display name of the created document.", - "type": "string" - }, - "chunkingConfig": { - "description": "Optional. Config for telling the service how to chunk the data. If not provided, the service will use default parameters.", - "$ref": "#/components/schemas/ChunkingConfig" - }, - "customMetadata": { - "description": "Custom metadata to be associated with the data.", + "inlinedResponses": { + "description": "Output only. The responses to the requests in the batch.", + "readOnly": true, + "type": "array", "items": { - "$ref": "#/components/schemas/CustomMetadata" - }, - "type": "array" - }, - "mimeType": { - "description": "Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content.", - "type": "string" + "$ref": "#/components/schemas/InlinedResponse" + } } - }, - "type": "object", - "description": "Request for `UploadToFileSearchStore`." + } }, "ThinkingConfig": { "description": "Config for thinking features.", + "type": "object", "properties": { "thinkingLevel": { - "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.", @@ -6327,6 +6293,13 @@ "Medium thinking level.", "High thinking level." ], + "enum": [ + "THINKING_LEVEL_UNSPECIFIED", + "MINIMAL", + "LOW", + "MEDIUM", + "HIGH" + ], "type": "string" }, "includeThoughts": { @@ -6334,152 +6307,48 @@ "type": "boolean" }, "thinkingBudget": { - "description": "The number of thoughts tokens that the model should generate.", - "format": "int32", - "type": "integer" - } - }, - "type": "object" - }, - "ResponseFormatConfig": { - "properties": { - "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", - "description": "Configuration for the response output format. This is a flat object where each optional sub-field configures a specific output modality." - }, - "CitationMetadata": { - "type": "object", - "properties": { - "citationSources": { - "description": "Citations to sources for a specific response.", - "items": { - "$ref": "#/components/schemas/CitationSource" - }, - "type": "array" - } - }, - "description": "A collection of source attributions for a piece of content." - }, - "MultiSpeakerVoiceConfig": { - "type": "object", - "properties": { - "speakerVoiceConfigs": { - "description": "Required. All the enabled speaker voices.", - "items": { - "$ref": "#/components/schemas/SpeakerVoiceConfig" - }, - "type": "array" - } - }, - "description": "The configuration for the multi-speaker setup." - }, - "ContentEmbedding": { - "description": "A list of floats representing an embedding.", - "type": "object", - "properties": { - "shape": { - "description": "This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048]).", - "type": "array", - "items": { - "type": "integer", - "format": "int32" - } - }, - "values": { - "description": "The embedding values. This is for 3P users only and will not be populated for 1P calls.", - "items": { - "type": "number", - "format": "float" - }, - "type": "array" - } - } - }, - "RegisterFilesRequest": { - "description": "Request for `RegisterFiles`.", - "properties": { - "uris": { - "description": "Required. The Google Cloud Storage URIs to register. Example: `gs://bucket/object`.", - "type": "array", - "items": { - "type": "string" - } - } - }, - "type": "object" - }, - "GoogleAiGenerativelanguageV1betaSegment": { - "description": "Segment of the content.", - "properties": { - "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": { - "description": "The text corresponding to the segment from the response.", - "type": "string" - }, - "startIndex": { "type": "integer", - "description": "Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero.", - "format": "int32" - }, - "partIndex": { - "description": "The index of a Part object within its parent Content object.", - "format": "int32", - "type": "integer" - } - }, - "type": "object" - }, - "BatchEmbedContentsRequest": { - "type": "object", - "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`." + "description": "The number of thoughts tokens that the model should generate.", + "format": "int32" } - }, - "description": "Batch request to get embeddings from the model for a list of prompts." + } }, - "PlaceAnswerSources": { + "DynamicRetrievalConfig": { + "description": "Describes the options to customize dynamic retrieval.", + "type": "object", "properties": { - "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/ReviewSnippet" - } + "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." + ], + "enum": [ + "MODE_UNSPECIFIED", + "MODE_DYNAMIC" + ], + "type": "string" + }, + "dynamicThreshold": { + "type": "number", + "description": "The threshold to be used in dynamic retrieval. If not set, a system default value is used.", + "format": "float" } - }, - "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." + } }, - "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", + "RetrievalConfig": { + "description": "Retrieval config.", "properties": { - "inlineData": { - "description": "Inline media bytes.", - "$ref": "#/components/schemas/FunctionResponseBlob" + "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" + }, + "latLng": { + "description": "Optional. The location of the user.", + "$ref": "#/components/schemas/LatLng" } - } + }, + "type": "object" }, "GeneratedFile": { "type": "object", @@ -6492,29 +6361,95 @@ "description": "MIME type of the generatedFile.", "type": "string" }, - "error": { - "description": "Error details if the GeneratedFile ends up in the STATE_FAILED state.", - "$ref": "#/components/schemas/Status" - }, "state": { "readOnly": true, + "type": "string", + "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." + ], "enum": [ "STATE_UNSPECIFIED", "GENERATING", "GENERATED", "FAILED" - ], + ] + }, + "error": { + "description": "Error details if the GeneratedFile ends up in the STATE_FAILED state.", + "$ref": "#/components/schemas/Status" + } + }, + "description": "A file generated on behalf of a user." + }, + "TransferOwnershipResponse": { + "properties": {}, + "type": "object", + "description": "Response from `TransferOwnership`." + }, + "ImageConfig": { + "description": "Config for image generation features.", + "type": "object", + "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" + } + } + }, + "FunctionDeclaration": { + "properties": { + "behavior": { + "type": "string", + "description": "Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method.", "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." + "This value is unused.", + "If set, the system will wait to receive the function response before continuing the conversation.", + "If set, the system will not wait to receive the function response. Instead, it will attempt to handle function responses as they become available while maintaining the conversation between the user and the model." ], - "description": "Output only. The state of the GeneratedFile.", + "enum": [ + "UNSPECIFIED", + "BLOCKING", + "NON_BLOCKING" + ] + }, + "parametersJsonSchema": { + "description": "Optional. Describes the parameters to the function in JSON Schema format. The schema must describe an object where the properties are the parameters to the function. For example: ``` { \"type\": \"object\", \"properties\": { \"name\": { \"type\": \"string\" }, \"age\": { \"type\": \"integer\" } }, \"additionalProperties\": false, \"required\": [\"name\", \"age\"], \"propertyOrdering\": [\"name\", \"age\"] } ``` This field is mutually exclusive with `parameters`." + }, + "parameters": { + "description": "Optional. Describes the parameters to this function. Reflects the Open API 3.03 Parameter Object string Key: the name of the parameter. Parameter names are case sensitive. Schema Value: the Schema defining the type used for the parameter.", + "$ref": "#/components/schemas/Schema" + }, + "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" + }, + "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": { + "description": "Required. A brief description of the function.", "type": "string" + }, + "responseJsonSchema": { + "description": "Optional. Describes the output from this function in JSON Schema format. The value specified by the schema is the response value of the function. This field is mutually exclusive with `response`." } }, - "description": "A file generated on behalf of a user." + "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." + }, + "UrlContext": { + "type": "object", + "properties": {}, + "description": "Tool to support URL context retrieval." }, "ExecutableCode": { "type": "object", @@ -6523,408 +6458,473 @@ "description": "Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`.", "type": "string" }, - "code": { - "description": "Required. The code to be executed.", - "type": "string" - }, "language": { "description": "Required. Programming language of the `code`.", + "x-enum-descriptions": [ + "Unspecified language. This value should not be used.", + "Python >= 3.10, with numpy and simpy available. Python is the default language." + ], "enum": [ "LANGUAGE_UNSPECIFIED", "PYTHON" ], - "type": "string", + "type": "string" + }, + "code": { + "description": "Required. The code to be executed.", + "type": "string" + } + }, + "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." + }, + "ImportFileRequest": { + "properties": { + "fileName": { + "description": "Required. The name of the `File` to import. Example: `files/abc-123`", + "type": "string" + }, + "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": { + "type": "array", + "items": { + "$ref": "#/components/schemas/CustomMetadata" + }, + "description": "Custom metadata to be associated with the file." + } + }, + "type": "object", + "description": "Request for `ImportFile` to import a File API file with a `FileSearchStore`." + }, + "LogprobsResult": { + "description": "Logprobs Result", + "properties": { + "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." + }, + "logProbabilitySum": { + "type": "number", + "description": "Sum of log probabilities for all tokens.", + "format": "float" + }, + "topCandidates": { + "type": "array", + "items": { + "$ref": "#/components/schemas/TopCandidates" + }, + "description": "Length = total number of decoding steps." + } + }, + "type": "object" + }, + "SafetySetting": { + "properties": { + "threshold": { + "description": "Required. Controls the probability threshold at which harm is blocked.", "x-enum-descriptions": [ - "Unspecified language. This value should not be used.", - "Python >= 3.10, with numpy and simpy available. Python is the default language." + "Threshold is unspecified.", + "Content with NEGLIGIBLE will be allowed.", + "Content with NEGLIGIBLE and LOW will be allowed.", + "Content with NEGLIGIBLE, LOW, and MEDIUM will be allowed.", + "All content will be allowed.", + "Turn off the safety filter." + ], + "enum": [ + "HARM_BLOCK_THRESHOLD_UNSPECIFIED", + "BLOCK_LOW_AND_ABOVE", + "BLOCK_MEDIUM_AND_ABOVE", + "BLOCK_ONLY_HIGH", + "BLOCK_NONE", + "OFF" + ], + "type": "string" + }, + "category": { + "description": "Required. The category for this setting.", + "x-enum-descriptions": [ + "Category is unspecified.", + "**PaLM** - Negative or harmful comments targeting identity and/or protected attribute.", + "**PaLM** - Content that is rude, disrespectful, or profane.", + "**PaLM** - Describes scenarios depicting violence against an individual or group, or general descriptions of gore.", + "**PaLM** - Contains references to sexual acts or other lewd content.", + "**PaLM** - Promotes unchecked medical advice.", + "**PaLM** - Dangerous content that promotes, facilitates, or encourages harmful acts.", + "**Gemini** - Harassment content.", + "**Gemini** - Hate speech and content.", + "**Gemini** - Sexually explicit content.", + "**Gemini** - Dangerous content.", + "**Gemini** - Content that may be used to harm civic integrity. DEPRECATED: use enable_enhanced_civic_answers instead." + ], + "enum": [ + "HARM_CATEGORY_UNSPECIFIED", + "HARM_CATEGORY_DEROGATORY", + "HARM_CATEGORY_TOXICITY", + "HARM_CATEGORY_VIOLENCE", + "HARM_CATEGORY_SEXUAL", + "HARM_CATEGORY_MEDICAL", + "HARM_CATEGORY_DANGEROUS", + "HARM_CATEGORY_HARASSMENT", + "HARM_CATEGORY_HATE_SPEECH", + "HARM_CATEGORY_SEXUALLY_EXPLICIT", + "HARM_CATEGORY_DANGEROUS_CONTENT", + "HARM_CATEGORY_CIVIC_INTEGRITY" + ], + "type": "string", + "enumDeprecated": [ + false, + false, + false, + false, + false, + false, + false, + false, + false, + false, + false, + true ] } }, - "description": "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", + "description": "Safety setting, affecting the safety-blocking behavior. Passing a safety setting for a category changes the allowed probability that content is blocked." }, - "GenerateContentBatch": { - "description": "A resource representing a batch of `GenerateContent` requests.", + "ListFilesResponse": { + "description": "Response for `ListFiles`.", "type": "object", "properties": { - "endTime": { - "type": "string", - "readOnly": true, - "description": "Output only. The time at which the batch processing completed.", - "format": "google-datetime" + "files": { + "type": "array", + "items": { + "$ref": "#/components/schemas/File" + }, + "description": "The list of `File`s." }, - "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", + "nextPageToken": { + "description": "A token that can be sent as a `page_token` into a subsequent `ListFiles` call.", "type": "string" + } + } + }, + "InlinedEmbedContentResponse": { + "properties": { + "error": { + "description": "Output only. The error encountered while processing the request.", + "$ref": "#/components/schemas/Status", + "readOnly": true }, - "inputConfig": { - "$ref": "#/components/schemas/InputConfig", - "description": "Required. Input configuration of the instances on which batch processing are performed." - }, - "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." - ], + "response": { "readOnly": true, - "enum": [ - "BATCH_STATE_UNSPECIFIED", - "BATCH_STATE_PENDING", - "BATCH_STATE_RUNNING", - "BATCH_STATE_SUCCEEDED", - "BATCH_STATE_FAILED", - "BATCH_STATE_CANCELLED", - "BATCH_STATE_EXPIRED" - ], - "type": "string", - "description": "Output only. The state of the batch." + "description": "Output only. The response to the request.", + "$ref": "#/components/schemas/EmbedContentResponse" }, - "updateTime": { - "type": "string", + "metadata": { + "additionalProperties": { + "description": "Properties of the object." + }, + "description": "Output only. The metadata associated with the request.", "readOnly": true, - "description": "Output only. The time at which the batch was last updated.", - "format": "google-datetime" + "type": "object" + } + }, + "type": "object", + "description": "The response to a single request in the batch." + }, + "GenerateContentResponse": { + "description": "Response from the model supporting multiple candidate responses. Safety ratings and content filtering are reported for both prompt in `GenerateContentResponse.prompt_feedback` and for each candidate in `finish_reason` and in `safety_ratings`. The API: - Returns either all requested candidates or none of them - Returns no candidates at all only if there was something wrong with the prompt (check `prompt_feedback`) - Reports feedback on each candidate in `finish_reason` and `safety_ratings`.", + "properties": { + "candidates": { + "description": "Candidate responses from the model.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Candidate" + } }, - "model": { - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", - "type": "string" + "promptFeedback": { + "description": "Returns the prompt's feedback related to the content filters.", + "$ref": "#/components/schemas/PromptFeedback" }, - "createTime": { - "type": "string", + "responseId": { + "description": "Output only. response_id is used to identify each response.", "readOnly": true, - "description": "Output only. The time at which the batch was created.", - "format": "google-datetime" - }, - "displayName": { - "description": "Required. The user-defined name of this batch.", "type": "string" }, - "output": { - "readOnly": true, - "$ref": "#/components/schemas/GenerateContentBatchOutput", - "description": "Output only. The output of the batch request." + "usageMetadata": { + "description": "Output only. Metadata on the generation requests' token usage.", + "$ref": "#/components/schemas/UsageMetadata", + "readOnly": true }, - "batchStats": { - "description": "Output only. Stats about the batch.", - "readOnly": true, - "$ref": "#/components/schemas/BatchStats" + "modelStatus": { + "description": "Output only. The current model status of this model.", + "$ref": "#/components/schemas/ModelStatus", + "readOnly": true }, - "name": { - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", + "modelVersion": { + "description": "Output only. The model version used to generate the response.", "readOnly": true, "type": "string" } - } + }, + "type": "object" }, - "Content": { + "InputEmbedContentConfig": { "properties": { - "role": { - "description": "Optional. The producer of the content. Must be either 'user' or 'model'. Useful to set for multi-turn conversations, otherwise can be left blank or unset.", - "type": "string" + "requests": { + "description": "The requests to be processed in the batch.", + "$ref": "#/components/schemas/InlinedEmbedContentRequests" }, - "parts": { - "type": "array", - "items": { - "$ref": "#/components/schemas/Part" - }, - "description": "Ordered `Parts` that constitute a single message. Parts may have different MIME types." + "fileName": { + "description": "The name of the `File` containing the input requests.", + "type": "string" } }, "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": "Configures the input to the batch request." }, - "LatLng": { - "type": "object", + "UsageMetadata": { + "description": "Metadata on the generation request's token usage.", "properties": { - "longitude": { - "description": "The longitude in degrees. It must be in the range [-180.0, +180.0].", - "format": "double", - "type": "number" + "promptTokensDetails": { + "readOnly": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + }, + "description": "Output only. List of modalities that were processed in the request input." }, - "latitude": { - "type": "number", - "description": "The latitude in degrees. It must be in the range [-90.0, +90.0].", - "format": "double" - } - }, - "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." - }, - "ToolConfig": { - "description": "The Tool configuration containing parameters for specifying `Tool` use in the request.", - "type": "object", - "properties": { - "retrievalConfig": { - "description": "Optional. Retrieval config.", - "$ref": "#/components/schemas/RetrievalConfig" + "cacheTokensDetails": { + "readOnly": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + }, + "description": "Output only. List of modalities of the cached content in the request input." }, - "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" + "totalTokenCount": { + "type": "integer", + "description": "Total token count for the generation request (prompt + thoughts + response candidates).", + "format": "int32" }, - "functionCallingConfig": { - "$ref": "#/components/schemas/FunctionCallingConfig", - "description": "Optional. Function calling config." - } - } - }, - "TextResponseFormat": { - "type": "object", - "properties": { - "mimeType": { + "toolUsePromptTokensDetails": { + "description": "Output only. List of modalities that were processed for tool-use request inputs.", + "readOnly": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + } + }, + "candidatesTokenCount": { + "description": "Total number of tokens across all the generated response candidates.", + "format": "int32", + "type": "integer" + }, + "cachedContentTokenCount": { + "type": "integer", + "description": "Number of tokens in the cached part of the prompt (the cached content)", + "format": "int32" + }, + "candidatesTokensDetails": { + "description": "Output only. List of modalities that were returned in the response.", + "readOnly": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + } + }, + "promptTokenCount": { + "description": "Number of tokens in the prompt. When `cached_content` is set, this is still the total effective prompt size meaning this includes the number of tokens in the cached content.", + "format": "int32", + "type": "integer" + }, + "toolUsePromptTokenCount": { + "description": "Output only. Number of tokens present in tool-use prompt(s).", + "format": "int32", + "readOnly": true, + "type": "integer" + }, + "serviceTier": { + "description": "Output only. Service tier of the request.", "x-enum-descriptions": [ - "Default value. This value is unused.", - "JSON output format.", - "Plain text output format." + "Default service tier, which is standard.", + "Standard service tier.", + "Flex service tier.", + "Priority service tier." ], - "type": "string", "enum": [ - "MIME_TYPE_UNSPECIFIED", - "APPLICATION_JSON", - "TEXT_PLAIN" + "unspecified", + "standard", + "flex", + "priority" ], - "description": "Optional. The MIME type of the text output." + "readOnly": true, + "type": "string" }, - "schema": { - "description": "Optional. The JSON schema that the output should conform to. Only applicable when mime_type is APPLICATION_JSON." + "thoughtsTokenCount": { + "readOnly": true, + "type": "integer", + "description": "Output only. Number of tokens of thoughts for thinking models.", + "format": "int32" + }, + "responseTokenCount": { + "description": "Output only. Number of tokens in the response. Used by Gemini 3.1+ Live API models instead of candidatesTokenCount.", + "type": "integer", + "format": "int32", + "readOnly": true + }, + "responseTokensDetails": { + "description": "Output only. List of modalities returned in the response with per-modality token counts. Used by Gemini 3.1+ Live API models instead of candidatesTokensDetails.", + "type": "array", + "readOnly": true, + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + } } }, - "description": "Configuration for text output format." + "type": "object" }, - "FileData": { + "FileSearch": { + "description": "The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API.", "type": "object", "properties": { - "mimeType": { - "description": "Optional. The IANA standard MIME type of the source data.", - "type": "string" + "fileSearchStoreNames": { + "type": "array", + "items": { + "type": "string" + }, + "description": "Required. The names of the file_search_stores to retrieve from. Example: `fileSearchStores/my-file-search-store-123`" }, - "fileUri": { - "description": "Required. URI.", + "metadataFilter": { + "description": "Optional. Metadata filter to apply to the semantic retrieval documents and chunks.", "type": "string" + }, + "topK": { + "description": "Optional. The number of semantic retrieval chunks to retrieve.", + "format": "int32", + "type": "integer" } - }, - "description": "URI based data." + } }, - "RetrievedContext": { + "PromptFeedback": { + "description": "A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`.", "properties": { - "customMetadata": { - "description": "Optional. User-provided metadata about the retrieved context.", + "safetyRatings": { + "description": "Ratings for safety of the prompt. There is at most one rating per category.", "type": "array", "items": { - "$ref": "#/components/schemas/GroundingChunkCustomMetadata" + "$ref": "#/components/schemas/SafetyRating" } }, - "title": { - "description": "Optional. Title of the document.", - "type": "string" - }, - "text": { - "description": "Optional. Text of the chunk.", - "type": "string" - }, - "pageNumber": { - "description": "Optional. Page number of the retrieved context, if applicable.", - "format": "int32", - "type": "integer" - }, - "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" - }, - "uri": { - "description": "Optional. URI reference of the semantic retrieval document.", - "type": "string" + "blockReason": { + "type": "string", + "description": "Optional. If set, the prompt was blocked and no candidates are returned. Rephrase the prompt.", + "x-enum-descriptions": [ + "Default value. This value is unused.", + "Prompt was blocked due to safety reasons. Inspect `safety_ratings` to understand which safety category blocked it.", + "Prompt was blocked due to unknown reasons.", + "Prompt was blocked due to the terms which are included from the terminology blocklist.", + "Prompt was blocked due to prohibited content.", + "Candidates blocked due to unsafe image generation content." + ], + "enum": [ + "BLOCK_REASON_UNSPECIFIED", + "SAFETY", + "OTHER", + "BLOCKLIST", + "PROHIBITED_CONTENT", + "IMAGE_SAFETY" + ] } }, - "type": "object", - "description": "Chunk from context retrieved by the file search tool." + "type": "object" }, "FunctionResponseBlob": { - "type": "object", + "description": "Raw media bytes for function response. Text should not be sent as raw bytes, use the 'FunctionResponse.response' field.", "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": "string" + "format": "byte" } }, - "description": "Raw media bytes for function response. Text should not be sent as raw bytes, use the 'FunctionResponse.response' field." + "type": "object" }, - "ListTunedModelsResponse": { - "description": "Response from `ListTunedModels` containing a paginated list of Models.", + "CachedContent": { "type": "object", "properties": { - "tunedModels": { - "description": "The returned Models.", + "contents": { + "description": "Optional. Input only. Immutable. The content to cache.", "type": "array", "items": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/Content" } }, - "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.", + "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" + }, + "systemInstruction": { + "description": "Optional. Input only. Immutable. Developer set system instruction. Currently text only.", + "$ref": "#/components/schemas/Content" + }, + "model": { + "description": "Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}`", "type": "string" - } - } - }, - "GenerateContentBatchOutput": { - "description": "The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field.", - "type": "object", - "properties": { - "inlinedResponses": { + }, + "updateTime": { "readOnly": true, - "$ref": "#/components/schemas/InlinedResponses", - "description": "Output only. The responses to the requests in the batch. Returned when the batch was built using inlined requests. The responses will be in the same order as the input requests." + "type": "string", + "description": "Output only. When the cache entry was last updated in UTC time.", + "format": "google-datetime" }, - "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.", + "name": { + "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`", "readOnly": true, "type": "string" - } - } - }, - "DynamicRetrievalConfig": { - "properties": { - "dynamicThreshold": { - "type": "number", - "description": "The threshold to be used in dynamic retrieval. If not set, a system default value is used.", - "format": "float" }, - "mode": { - "description": "The mode of the predictor to be used in dynamic retrieval.", - "enum": [ - "MODE_UNSPECIFIED", - "MODE_DYNAMIC" - ], + "createTime": { + "readOnly": true, "type": "string", - "x-enum-descriptions": [ - "Always trigger retrieval.", - "Run retrieval only when system decides it is necessary." - ] - } - }, - "type": "object", - "description": "Describes the options to customize dynamic retrieval." - }, - "VideoFileMetadata": { - "description": "Metadata for a video `File`.", - "type": "object", - "properties": { - "videoDuration": { - "description": "Duration of the video.", - "format": "google-duration", - "type": "string" - } - } - }, - "ImageConfig": { - "description": "Config for image generation features.", - "type": "object", - "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" + "description": "Output only. Creation time of the cache entry.", + "format": "google-datetime" }, - "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" - } - } - }, - "VoiceConfig": { - "description": "The configuration for the voice to use.", - "type": "object", - "properties": { - "prebuiltVoiceConfig": { - "$ref": "#/components/schemas/PrebuiltVoiceConfig", - "description": "The configuration for the prebuilt voice to use." - } - } - }, - "TopCandidates": { - "description": "Candidates with top log probabilities at each decoding step.", - "properties": { - "candidates": { - "type": "array", - "items": { - "$ref": "#/components/schemas/LogprobsResultCandidate" - }, - "description": "Sorted by log probability in descending order." - } - }, - "type": "object" - }, - "CustomMetadata": { - "properties": { - "key": { - "description": "Required. The key of the metadata to store.", - "type": "string" + "ttl": { + "type": "string", + "description": "Input only. New TTL for this resource, input only.", + "format": "google-duration" }, - "numericValue": { - "type": "number", - "description": "The numeric value of the metadata to store.", - "format": "float" + "usageMetadata": { + "description": "Output only. Metadata on the usage of the cached content.", + "$ref": "#/components/schemas/CachedContentUsageMetadata", + "readOnly": true }, - "stringValue": { - "description": "The string value of the metadata to store.", + "expireTime": { + "description": "Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input.", + "format": "google-datetime", "type": "string" }, - "stringListValue": { - "$ref": "#/components/schemas/StringList", - "description": "The StringList value of the metadata to store." - } - }, - "type": "object", - "description": "User provided metadata stored as key-value pairs." - }, - "InlinedResponse": { - "properties": { - "response": { - "description": "Output only. The response to the request.", - "readOnly": true, - "$ref": "#/components/schemas/GenerateContentResponse" - }, - "metadata": { - "type": "object", - "description": "Output only. The metadata associated with the request.", - "additionalProperties": { - "description": "Properties of the object." - }, - "readOnly": true + "displayName": { + "description": "Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters.", + "type": "string" }, - "error": { - "description": "Output only. The error encountered while processing the request.", - "readOnly": true, - "$ref": "#/components/schemas/Status" - } - }, - "type": "object", - "description": "The response to a single request in the batch." - }, - "UrlContextMetadata": { - "description": "Metadata related to url context retrieval tool.", - "properties": { - "urlMetadata": { - "description": "List of url context.", - "type": "array", - "items": { - "$ref": "#/components/schemas/UrlMetadata" - } + "toolConfig": { + "description": "Optional. Input only. Immutable. Tool config. This config is shared for all tools.", + "$ref": "#/components/schemas/ToolConfig" } }, - "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." } } }